कस्टम तालिका / स्कीमा के साथ विचारों का उपयोग करना


19

मुझे कुछ विचार सेट करने की आवश्यकता है जो मेरे द्वारा बनाई गई एक कस्टम तालिका से कुछ डेटा खींच लेंगे। कुछ दृश्यों को नियमित रूप से और मेरी कस्टम तालिका (जहां मैं किसी विशेष nid के लिए क्वेरी कर सकता हूं , आदि) से सामग्री खींचने की आवश्यकता होगी ।

मैं यह कैसे करूं, या शोध के लिए अच्छी जगह कहां है?


7
यह लेख बिंदु पर बहुत अच्छा लगता है: mydons.com/how-to-expose-custom-module-table-to-views-in-drupal
जिमजम्मा

ऐसा लगता है कि यह वही हो सकता है जो मैं देख रहा हूं। धन्यवाद!
विनटॉर्ग

जवाबों:


25

आपके मॉड्यूल को hook_views_data () लागू करने की आवश्यकता है ।

हुक प्रलेखन में दिया गया उदाहरण निम्नलिखित एसक्यूएल से परिभाषित तालिका के लिए है।

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

धन्यवाद, @kiamlaluno - ठीक है, इसलिए मैंने देखा, नहीं मिला, फिर एक अलग प्रश्न बनाने के लिए उद्यम किया - drupal.stackexchange.com/questions/70561/…
21 फरवरी को 21 अगस्त को Vacilando

2

मुझे लगता है कि यह संभवतः डेटा मॉड्यूल की जांच के लायक होगा । यह बहुत शक्तिशाली है, क्योंकि यह आपको ड्रुपल को एक गैर-ड्रुपल तालिका घोषित करने की अनुमति देता है, जैसे कि यह दृश्य में डेटा स्रोत (जैसे "सामग्री", "वर्गीकरण", आदि) के रूप में दिखाई देता है। आप नॉन-ड्रुपल टेबल और ड्रुपल एंटिटीज के बीच जुड़ने की भी घोषणा कर सकते हैं (इसलिए उदाहरण के लिए यदि आप अपने नॉन-ड्रुपल टेबल में एनआईडी स्टॉक कर सकते हैं, तो आप किसी भी नोड के साथ एनआईडी पर जॉइन की घोषणा कर सकते हैं)।

एक सबमॉड्यूल भी है जो आपको अपने नॉन-ड्रुपल टेबल को एक इकाई के रूप में घोषित करने की अनुमति देता है, लेकिन अभी तक मैंने ऐसा प्रयास नहीं किया है।

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.