Rumah >pembangunan bahagian belakang >tutorial php >Mengekspos Jadual ke Pandangan di 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()
<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 (
<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
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
<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!