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?

Vintorg
sumber
7
Artikel ini tampaknya cukup tepat: mydons.com/how-to-expose-custom-module-table-to-views-in-drupal
Jimajamma
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;
}
kiamlaluno
sumber
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.

Martin K
sumber