Menggunakan tampilan dengan tabel / skema khusus


19

Saya perlu mengatur beberapa tampilan yang akan menarik beberapa data dari tabel khusus yang saya buat. Beberapa tampilan perlu menarik konten dengan cara biasa dan dari tabel khusus saya (tempat saya dapat meminta nid tertentu , dll.).

Bagaimana saya melakukan ini, atau di mana tempat yang baik untuk penelitian?



Sepertinya itu yang saya cari. Terima kasih!
vintorg

Jawaban:


25

Modul Anda perlu mengimplementasikan hook_views_data () .

Contoh yang diberikan dalam dokumentasi hook adalah untuk tabel yang didefinisikan dari SQL berikut.

CREATE TABLE example_table (
  nid INT(11) NOT NULL,
  plain_text_field VARCHAR(32,
  numeric_field INT(11),
  boolean_field INT(1),
  timestamp_field INT(8),
  PRIMARY KEY(nid)
);
function mymodule_views_data() {
  $data['example_table']['table']['group'] = t('Example table');

  $data['example_table']['table']['base'] = array(
    'field' => 'nid',
    'title' => t('Example table'), 
    'help' => t('Example table contains example content and can be related to nodes.'), 
    'weight' => -10,
  );

  $data['example_table']['table']['join'] = array(
    'node' => array(
      'left_field' => 'nid', 
      'field' => 'nid',
    ),
  );

  $data['example_table']['nid'] = array(
    'title' => t('Example content'), 
    'help' => t('Some example content that references a node.'),
    'relationship' => array(
      'base' => 'node',
      'base field' => 'nid', // The name of the field on the joined table.
      // 'field' => 'nid' -- see hook_views_data_alter(); not needed here.
      'handler' => 'views_handler_relationship', 
      'label' => t('Example node'),
    ),
  );

  $data['example_table']['plain_text_field'] = array(
    'title' => t('Plain text field'), 
    'help' => t('Just a plain text field.'), 
    'field' => array(
      'handler' => 'views_handler_field', 
      'click sortable' => TRUE,
    ), 
    'sort' => array(
      'handler' => 'views_handler_sort',
    ), 
    'filter' => array(
      'handler' => 'views_handler_filter_string',
    ), 
    'argument' => array(
      'handler' => 'views_handler_argument_string',
    ),
  );

  $data['example_table']['numeric_field'] = array(
    'title' => t('Numeric field'), 
    'help' => t('Just a numeric field.'), 
    'field' => array(
      'handler' => 'views_handler_field_numeric', 
      'click sortable' => TRUE,
    ), 
    'filter' => array(
      'handler' => 'views_handler_filter_numeric',
    ), 
    'sort' => array(
      'handler' => 'views_handler_sort',
    ),
  );

  $data['example_table']['boolean_field'] = array(
    'title' => t('Boolean field'), 
    'help' => t('Just an on/off field.'), 
    'field' => array(
      'handler' => 'views_handler_field_boolean', 
      'click sortable' => TRUE,
    ), 
    'filter' => array(
      'handler' => 'views_handler_filter_boolean_operator',
      'label' => t('Published'),
      'type' => 'yes-no',
      'use equal' => TRUE,
    ), 
    'sort' => array(
      'handler' => 'views_handler_sort',
    ),
  );

  $data['example_table']['timestamp_field'] = array(
    'title' => t('Timestamp field'), 
    'help' => t('Just a timestamp field.'), 
    'field' => array(
      'handler' => 'views_handler_field_date', 
      'click sortable' => TRUE,
    ), 
    'sort' => array(
      'handler' => 'views_handler_sort_date',
    ), 
    'filter' => array(
      'handler' => 'views_handler_filter_date',
    ),
  );

  return $data;
}

Ini merupakan bantuan yang luar biasa. Namun, salah satu bidang saya multinilai, jadi saya pikir ini harus diatur secara berbeda - tetapi bagaimana caranya?
Vacilando

Perbedaannya ada pada penangan yang perlu Anda gunakan, dan apa yang Anda gunakan alih-alih "ya-tidak"; Saya tidak bisa memberi tahu Anda penangan mana yang bidang multi-nilai. Mungkin lebih baik sebagai pertanyaan, jika tidak ada yang menanyakannya.
kiamlaluno

Terima kasih, @kiamlaluno - OK, jadi saya melihat, tidak menemukan, lalu memberanikan diri untuk membuat pertanyaan terpisah - lihat drupal.stackexchange.com/questions/70561/…
Vacilando

2

Saya pikir mungkin ada baiknya menyelidiki modul Data . Ini sangat kuat, karena memungkinkan Anda untuk mendeklarasikan tabel non-Drupal ke Drupal sehingga menjadi terlihat di Tampilan sebagai sumber data (seperti "Konten", "Taksonomi", dll). Anda juga dapat mendeklarasikan gabungan antara tabel non-Drupal dan entitas Drupal (jadi misalnya jika Anda dapat menyimpan nid di tabel non-Drupal, maka Anda dapat mendeklarasikan gabungan pada nid dengan simpul apa pun).

Ada juga submodule yang memungkinkan Anda untuk mendeklarasikan tabel non-Drupal Anda sebagai entitas, tetapi sejauh ini saya belum mencobanya.

Dengan menggunakan situs kami, Anda mengakui telah membaca dan memahami Kebijakan Cookie dan Kebijakan Privasi kami.
Licensed under cc by-sa 3.0 with attribution required.