Rumah >pembangunan bahagian belakang >tutorial php >Mengekspos Jadual ke Pandangan di Drupal 7

Mengekspos Jadual ke Pandangan di Drupal 7

尊渡假赌尊渡假赌尊渡假赌
尊渡假赌尊渡假赌尊渡假赌asal
2025-02-21 08:39:10267semak imbas

Exposing Tables to Views in Drupal 7

Konsep Utama

Tutorial ini menunjukkan cara mengintegrasikan jadual pangkalan data DRUPAL 7 adat dengan modul pandangan, membolehkan pertanyaan yang kuat dan keupayaan persembahan data. Kami akan meliputi pandangan yang menyedari struktur jadual modul anda, menentukan pengendali medan untuk paparan, penapisan, dan penyortiran, dan mewujudkan hubungan antara jadual menggunakan gabungan. Proses ini memanfaatkan Pandangan Pengendali - Kelas Menguruskan Paparan, Menyortir, dan Penapisan Operasi - Membolehkan Penyesuaian Di Luar Fungsi Lalai.

Panduan ini memberi tumpuan kepada jadual yang tidak diwakili sebagai entiti Drupal. Untuk integrasi entiti dengan pandangan, sila rujuk sumber lain.

Modul sampel, "dedahkan," tersedia (butiran repositori yang ditinggalkan untuk keringkasan). Jadual

(struktur terperinci di bawah) akan digunakan untuk demonstrasi. Data sampel boleh dimasukkan menggunakan arahan MySQL ini: exposed

<code class="language-sql">INSERT INTO `exposed` (`id`, `name`, `deadline`, `node_id`) VALUES (1, 'Danny', 1399477939, 1), (2, 'Peter', 1399477957, 2);</code>

Mengintegrasikan jadual anda dengan pandangan

Integrasi melibatkan dua langkah utama: memaklumkan pandangan mengenai modul anda dan menentukan struktur meja anda.

Langkah 1: memaklumkan pandangan mengenai modul anda

pelaksanaan

dalam fail hook_views_api() modul anda: .module

<code class="language-php">/**
 * Implements hook_views_api().
 */
function expose_views_api() {
  return array(
    'api' => 3,
    'path' => drupal_get_path('module', 'expose') . '/includes/views',
  );
}</code>
Ini menentukan versi API pandangan dan lokasi fail yang berkaitan dengan pandangan anda.

Langkah 2: Menentukan struktur meja anda 3

Kod ini mentakrifkan kumpulan meja dan menetapkannya sebagai jadual asas, menjadikannya tersedia dalam antara muka pandangan. Definisi medan (terperinci seterusnya) akan ditambah di sini. expose.views.inc hook_views_data()

Langkah 3: Menentukan bidang
<code class="language-php">/**
 * Implements hook_views_data().
 */
function expose_views_data() {
  $data = array();
  $data['exposed']['table']['group'] = t('Exposed');
  $data['exposed']['table']['base'] = array(
    'title' => t('Exposed'),
    'help' => t('Contains records exposed to Views.'),
  );
  // Field definitions (see below)
  return $data;
}</code>

dalam

, tambahkan definisi medan untuk setiap lajur:

Ini menentukan pengendali untuk paparan (

), menyusun (hook_views_data()), dan penapisan (

) untuk setiap lajur. Pengendali yang sesuai (mis., Numerik, rentetan, tarikh) dipilih berdasarkan jenis data.
<code class="language-php">// ... (previous code) ...

// ID field
$data['exposed']['id'] = array(
  'title' => t('ID'),
  'help' => t('Record ID'),
  'field' => array('handler' => 'views_handler_field_numeric'),
  'sort' => array('handler' => 'views_handler_sort'),
  'filter' => array('handler' => 'views_handler_filter_numeric'),
);

// Name field
$data['exposed']['name'] = array(
  'title' => t('Name'),
  'help' => t('Record name'),
  'field' => array('handler' => 'views_handler_field'),
  'sort' => array('handler' => 'views_handler_sort'),
  'filter' => array('handler' => 'views_handler_filter_string'),
);

// Deadline field
$data['exposed']['deadline'] = array(
  'title' => t('Deadline'),
  'help' => t('Record deadline'),
  'field' => array('handler' => 'views_handler_field_date'),
  'sort' => array('handler' => 'views_handler_sort_date'),
  'filter' => array('handler' => 'views_handler_filter_date'),
);

// ... (Node ID field and join definition - see below) ...

return $data;</code>

field Langkah 4: Mengendalikan hubungan (bergabung) sort filter

untuk bergabung dengan jadual

menggunakan lajur :

Ini mentakrifkan gabungan dan menentukan pengendali node untuk paparan, membolehkan akses ke medan berkaitan nod. Hubungan dan hujah juga ditakrifkan untuk penapisan dan penapisan kontekstual berdasarkan id nod. node_id

Selepas melaksanakan langkah -langkah ini, Clear Drupal Cache. Jadual tersuai anda kini boleh diakses dalam antara muka pandangan.
<code class="language-php">// ... (previous code) ...

// Join definition
$data['exposed']['table']['join'] = array(
  'node' => array(
    'left_field' => 'nid',
    'field' => 'node_id',
  ),
);

// Node ID field
$data['exposed']['node_id'] = array(
  'title' => t('Node ID'),
  'help' => t('Node ID'),
  'field' => array('handler' => 'views_handler_field_node'),
  'sort' => array('handler' => 'views_handler_sort'),
  'filter' => array('handler' => 'views_handler_filter_numeric'),
  'relationship' => array(
    'base' => 'node',
    'field' => 'node_id',
    'handler' => 'views_handler_relationship',
    'label' => t('Node'),
  ),
  'argument' => array(
    'handler' => 'views_handler_argument_node_nid',
    'numeric' => TRUE,
    'validate type' => 'nid',
  ),
);

return $data;</code>

views_handler_field_node Kesimpulan

Penjelasan terperinci ini menyediakan panduan komprehensif untuk mengintegrasikan jadual tersuai dengan modul pandangan Drupal 7. Ingatlah untuk menyesuaikan pilihan pengendali ke jenis data khusus anda dan memanfaatkan fleksibiliti pengendali tersuai untuk fungsi lanjutan. Seksyen Soalan Lazim dari input asal telah ditinggalkan kerana ia sebahagian besarnya diliputi dalam tindak balas halus ini.

Atas ialah kandungan terperinci Mengekspos Jadual ke Pandangan di Drupal 7. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel sebelumnya:Php 5.6 akhir betaArtikel seterusnya:Php 5.6 akhir beta