cari
Rumahpembangunan bahagian belakangtutorial phpMengekspos Jadual ke Pandangan di Drupal 7

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

INSERT INTO `exposed` (`id`, `name`, `deadline`, `node_id`) VALUES (1, 'Danny', 1399477939, 1), (2, 'Peter', 1399477957, 2);

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

/**
 * Implements hook_views_api().
 */
function expose_views_api() {
  return array(
    'api' => 3,
    'path' => drupal_get_path('module', 'expose') . '/includes/views',
  );
}
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
/**
 * 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;
}

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.
// ... (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;

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.
// ... (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;

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
Bekerja dengan Data Sesi Flash di LaravelBekerja dengan Data Sesi Flash di LaravelMar 12, 2025 pm 05:08 PM

Laravel memudahkan mengendalikan data sesi sementara menggunakan kaedah flash intuitifnya. Ini sesuai untuk memaparkan mesej ringkas, makluman, atau pemberitahuan dalam permohonan anda. Data hanya berterusan untuk permintaan seterusnya secara lalai: $ permintaan-

Curl dalam PHP: Cara Menggunakan Pelanjutan PHP Curl dalam API RESTCurl dalam PHP: Cara Menggunakan Pelanjutan PHP Curl dalam API RESTMar 14, 2025 am 11:42 AM

Pelanjutan URL Pelanggan PHP (CURL) adalah alat yang berkuasa untuk pemaju, membolehkan interaksi lancar dengan pelayan jauh dan API rehat. Dengan memanfaatkan libcurl, perpustakaan pemindahan fail multi-protokol yang dihormati, php curl memudahkan execu yang cekap

Respons HTTP yang dipermudahkan dalam ujian LaravelRespons HTTP yang dipermudahkan dalam ujian LaravelMar 12, 2025 pm 05:09 PM

Laravel menyediakan sintaks simulasi respons HTTP ringkas, memudahkan ujian interaksi HTTP. Pendekatan ini dengan ketara mengurangkan redundansi kod semasa membuat simulasi ujian anda lebih intuitif. Pelaksanaan asas menyediakan pelbagai jenis pintasan jenis tindak balas: Gunakan Illuminate \ Support \ Facades \ http; Http :: palsu ([ 'Google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

12 skrip sembang php terbaik di codecanyon12 skrip sembang php terbaik di codecanyonMar 13, 2025 pm 12:08 PM

Adakah anda ingin memberikan penyelesaian segera, segera kepada masalah yang paling mendesak pelanggan anda? Sembang langsung membolehkan anda mempunyai perbualan masa nyata dengan pelanggan dan menyelesaikan masalah mereka dengan serta-merta. Ia membolehkan anda memberikan perkhidmatan yang lebih pantas kepada adat anda

Terangkan konsep pengikatan statik lewat dalam PHP.Terangkan konsep pengikatan statik lewat dalam PHP.Mar 21, 2025 pm 01:33 PM

Artikel membincangkan pengikatan statik lewat (LSB) dalam PHP, yang diperkenalkan dalam Php 5.3, yang membolehkan resolusi runtime kaedah statik memerlukan lebih banyak warisan yang fleksibel. Isu: LSB vs polimorfisme tradisional; Aplikasi Praktikal LSB dan Potensi Perfo

Pembalakan PHP: Amalan Terbaik untuk Analisis Log PHPPembalakan PHP: Amalan Terbaik untuk Analisis Log PHPMar 10, 2025 pm 02:32 PM

Pembalakan PHP adalah penting untuk memantau dan menyahpepijat aplikasi web, serta menangkap peristiwa kritikal, kesilapan, dan tingkah laku runtime. Ia memberikan pandangan yang berharga dalam prestasi sistem, membantu mengenal pasti isu -isu, dan menyokong penyelesaian masalah yang lebih cepat

Pengesahan Kaedah HTTP di LaravelPengesahan Kaedah HTTP di LaravelMar 05, 2025 pm 04:14 PM

Laravel memudahkan pengendalian kata kerja HTTP dalam permintaan masuk, menyelaraskan pengurusan operasi yang pelbagai dalam aplikasi anda. Kaedah () dan ismethod () kaedah mengenal pasti dan mengesahkan jenis permintaan. Ciri ini penting untuk membina

Cari muat turun fail di laravel dengan penyimpanan :: muat turunCari muat turun fail di laravel dengan penyimpanan :: muat turunMar 06, 2025 am 02:22 AM

Penyimpanan :: Kaedah Muat turun Rangka Kerja Laravel menyediakan API ringkas untuk mengendalikan muat turun fail dengan selamat sambil menguruskan abstraksi penyimpanan fail. Berikut adalah contoh menggunakan penyimpanan :: muat turun () dalam pengawal contoh:

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

SublimeText3 Linux versi baharu

SublimeText3 Linux versi baharu

SublimeText3 Linux versi terkini

Versi Mac WebStorm

Versi Mac WebStorm

Alat pembangunan JavaScript yang berguna

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan