একটি কাস্টম টেবিল / স্কিমা সহ দর্শন ব্যবহার করে


19

আমাকে এমন কিছু ভিউ সেট আপ করতে হবে যা আমার তৈরি কাস্টম টেবিল থেকে কিছু তথ্য টানবে। কিছু দৃশ্যের নিয়মিত উপায়ে এবং আমার কাস্টম টেবিল থেকে (যেখানে আমি কোনও বিশেষ নিড ইত্যাদির জন্য জিজ্ঞাসা করতে পারি ) কন্টেন্টটি টানতে হবে ।

আমি এটি কীভাবে করব, বা গবেষণার জন্য ভাল জায়গা কোথায়?


7
এই নিবন্ধটি বিন্দুটিতে সুন্দর বলে মনে হচ্ছে: mydons.com/how-to-expose-custom-module-table-to-views-in-drupal
Jimajamma

দেখে মনে হচ্ছে এটি আমি যা খুঁজছি তা হতে পারে। ধন্যবাদ!
ভিন্টরগ

উত্তর:


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;
}

এটি একটি দুর্দান্ত সাহায্য হয়েছে। যাইহোক, আমার একটি ক্ষেত্র মাল্টিভ্যালু, এবং তাই আমি মনে করি এটি অবশ্যই আলাদাভাবে সেট আপ করা উচিত - তবে কীভাবে?
ভ্যাকিল্যান্ডো

পার্থক্যটি হ্যান্ডলারের মধ্যে আপনার ব্যবহার করা দরকার এবং আপনি "হ্যাঁ-না" পরিবর্তে যা ব্যবহার করেন; যদিও আমি আপনাকে বলতে পারি না যে কোন হ্যান্ডলারগুলি বহু-মান ক্ষেত্রের জন্য। সম্ভবত এটি প্রশ্ন হিসাবে ভাল, যদি কেউ এটি ইতিমধ্যে জিজ্ঞাসা না করে।
কিমলালুনো

ধন্যবাদ, @
কাইমালালুনো

2

আমি মনে করি এটি সম্ভবত ডেটা মডিউলটি তদন্ত করার উপযুক্ত হবে । এটি অত্যন্ত শক্তিশালী, যেহেতু এটি আপনাকে দ্রুপলের কাছে একটি অ-দ্রুপাল সারণী ঘোষণা করার মঞ্জুরি দেয় যাতে এটি ভিউতে ডেটা উত্স হিসাবে দৃশ্যমান হয় (যেমন "বিষয়বস্তু", "শ্রেণিবিন্যাস" ইত্যাদি)। আপনি নন-ড্রুপাল টেবিল এবং ড্রুপাল সত্তার মধ্যে যোগদানের ঘোষণাও করতে পারেন (উদাহরণস্বরূপ আপনি যদি আপনার নন-দ্রুপাল টেবিলের মধ্যে একটি নিড স্টক করতে পারেন তবে আপনি কোনও নোডের সাথে নীডে যোগদানের ঘোষণা দিতে পারেন)।

এখানে একটি সাবমডিউল রয়েছে যা আপনাকে আপনার অ-ড্রুপাল টেবিলটিকে সত্তা হিসাবে ঘোষণা করার অনুমতি দেয়, তবে এখনও পর্যন্ত আমি এটি চেষ্টা করি নি।

আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.