উত্তর:
আমি এই উত্তরটি বলার মাধ্যমে এই উত্তরটি উপস্থাপন করতে যাচ্ছি এই এন-ম্যাসেজটি একটি সম্ভাব্য সুরক্ষা ঝুঁকি উপস্থাপন করছে, বিশেষত যদি আপনি ফর্ম্যাটটিকে ফিল্টারগুলির আরও লেন্সেন্ট সেটটিতে পরিবর্তন করছেন। পাঠ্যের বিন্যাসগুলি সংরক্ষণের সময় নয়, প্রদর্শনের সময় ক্ষেত্রের আউটপুট পরিবর্তন করে। সুতরাং উদাহরণস্বরূপ, কোনও ক্ষেত্রের কাছে পূর্ববর্তী পালানো এইচটিএমএল বা পিএইচপি সরাসরি দুর্ঘটনাক্রমে বা ইচ্ছাকৃতভাবে ফিল্টারটি সম্পূর্ণ এইচটিএমএল বা পিএইচপি কোডে সেট করে দিলে সরাসরি রেন্ডার / রান হয়ে যায়।
এ কারণেই আপনি কোনও পাঠ্য বিন্যাস পরিবর্তন করলে দ্রুপাল সমস্ত বিদ্যমান নোড স্বয়ংক্রিয়ভাবে আপডেট করে না। অনুরূপ পরিস্থিতিতে টেক্সট ফর্ম্যাটগুলির আচরণ এখনও একটি মুক্ত বিষয় ।
তাই আবার: সাবধান, ড্রাগন আছে।
সঙ্গে বলেন যে, প্রতিটি ক্ষেত্রের নামে একটি কলাম হিসাবে পাঠ্য সঞ্চয় করে field_foo_format
, যেখানে field_foo
মাঠের মেশিন নাম। আপনাকে এই কলামটি টেবিলগুলিতে আপডেট করতে হবে field_revision_field_foo
এবং field_data_field_foo
।
কলামটির মান হ'ল একটি মেশিনের নাম format
যা filter_format
টেবিলের কলাম হিসাবে সংজ্ঞায়িত হয় । সুতরাং, সমস্ত ক্ষেত্র আপডেট করা একটি কোয়েরির মতো বিষয় হবে:
UPDATE field_revision_foo SET field_foo_format = 'new_format';
UPDATE field_data_foo SET field_foo_format = 'new_format';
প্রতিটি ক্ষেত্রের জন্য যা পরিবর্তনের প্রয়োজন।
আপনি new_format
এখানে মান নির্ধারণ করতে পারেন : http://YOURSITE.com/admin/config/content/formats - লিঙ্ক কনফিগার - নম্বর বা স্ট্রিং new_format.
আপডেটের পরে আপনার সাফ ক্যাশে।
মর্টেন এখানে যেমন করেছিলেন ঠিক একই অবস্থানে চলে এসেছিলেন, একটি ডি 6 => ডি 7 আপগ্রেড যা দৃশ্যত ইনপুট ফর্ম্যাটগুলি শেষ করেনি finish
ইতিমধ্যে এখানে উত্তরগুলির চেয়ে ক্রুডার পদ্ধতির সাহায্য নিয়েছেন এবং একটি মডিউল লিখেছেন যা ডিবি স্কিমার মধ্য দিয়ে চলেছে এবং D7 মেশিনের নামগুলির সাথে ডি 6 ফর্ম্যাট মান (1, 2, 3) প্রতিস্থাপন করে স্ট্রিং 'ফর্ম্যাট' সহ সমস্ত কলামকে আপডেট করেছে ( filtered_html
, full_html
, plain_text
)।
https://gist.github.com/xurizaemon/9824872
এর ম্যাপিং সমর্থন করার জন্য হার্ডকোডযুক্ত
1 => filtered_html,
2 => full_html,
3 => plain_text,
এছাড়াও 'ফর্ম্যাট' নামযুক্ত ক্ষেত্রগুলি পুনরায় লেখার চেষ্টা করতে পারে (উদাঃ "ডেট_ফর্ম্যাট", তবে আপনার যদি '2' মান সহ একটি তারিখ বিন্যাস থাকে তবে এটি আপনার সমস্যা)।
আমার জন্য, নিম্নলিখিতগুলি কাজ করেছে:
update `field_revision_body` set `body_format` = 'new_body_forma' WHERE `bundle` = 'node_type'
update `field_data_body` set `body_format` = 'new_body_forma' WHERE `bundle` = 'node_type'
অবশ্যই আপনাকে অবশ্যই নতুন_বডি_ফর্ম এবং নোড_প্রকার পরিবর্তন করতে হবে
আপনি সত্তা.মডিউল ইনস্টলড থাকলে নিম্নলিখিত কোডগুলি ব্যবহার করতে পারেন।
// I'm using node_save($node);
$wrapper = entity_metadata_wrapper('node', $node->nid);
$wrapper->body->set(array('value' => body_text, 'format'=>'full_html'));
সম্ভবত আপনি কোন ক্ষেত্রগুলি আপডেট করার প্রয়োজন তা জানতে চাইবেন, সম্ভবত কিছু লগিং করতে বা ডেটাতে চেক করতে। এটি করতে, সমস্ত টেবিল এবং কলামের নাম পান যাতে একটি _format
কলাম রয়েছে:
select distinct TABLE_NAME, column_name
from information_schema.columns
where TABLE_SCHEMA = 'my_drupal_database_name' and column_name like '%_format';
এই ডেটা দিয়ে সজ্জিত আপনি সেই মানগুলি থেকে আলাদা প্রশ্ন তৈরি করতে পারেন। প্রথমে আউটপুট পরীক্ষা করে দেখুন; আপনাকে এমন কিছু এন্ট্রি অপসারণ করতে হবে যা সামগ্রী / সংশোধন সম্পর্কিত নয়। আমি কোয়েরিগুলি তৈরির জন্য একটি রেজেক্স-সক্ষম সম্পাদক ব্যবহার করার পরামর্শ দিচ্ছি। আমি ডেটাটিকে একটি বড় select [...] union
বিবৃতিতে পরিণত করেছি এবং তারপরে আপডেট অনুসন্ধানগুলি চালিয়েছি।
যখন হাজার হাজার নোড / রিভিশনগুলি আপডেট করার দরকার হয়েছিল তখন এই পদ্ধতির ব্যবহার আমাকে বেশ কিছুটা সময় সাশ্রয় করেছিল। ক্ষেত্রের ক্যাশেটি মুছে ফেলতে ভুলবেন না (এর দ্বারা আচ্ছাদিত নয় drush cc all
!):
field_cache_clear();
বা ড্রাশ সহ:
drush sqlq "truncate table cache_field;"
আপনি যদি কোনও পাঠ্য ফিল্টারও অবসর নিচ্ছেন, তারপরে আপনাকে সিটিগুলির ক্ষেত্রে ডিফল্ট পাঠ্য বিন্যাসটি পরিবর্তন করতে হবে যা ক্ষেত্রগুলি ব্যবহার করেছিল। আপনি যদি এটি না করেন তবে আপনার ব্যবহারকারীরা যে ক্ষেত্রগুলি ব্যবহার করেছেন সেগুলির মধ্যে অনুমতি প্রত্যাখ্যান বার্তাগুলি পাবেন old_format
। আমি এই জিজ্ঞাসাটি অপরাধীদের সন্ধানের জন্য করেছি:
select * from field_config_instance where `data` LIKE '%old_format%';
পরিবর্তনগুলি করতে, আমি প্রতিটি ফিল্ড সেটিংস পৃষ্ঠাতে গিয়ে ইন্টারফেসটি ব্যবহার করা সহজ করে সংরক্ষণ করে টিপে (ডেটা লংব্লব হিসাবে সঞ্চিত থাকে এবং ভাল ফর্ম্যাটগুলির মডিউল ডেটা ইনজেকশনের কারণে অনুসন্ধান এবং প্রতিস্থাপনের জন্য অনর্থক ছিল)। এমনকি পাঠ্য প্রসেসিং রয়েছে এমন ক্ষেত্রগুলিতে Plain text
পুরানো_ফর্ম্যাট রয়েছে! পাঠ্য প্রসেসিং রয়েছে এমন ক্ষেত্রগুলির জন্য Filtered text (user selects text format)
, আপনাকে অতিরিক্তভাবে একটি নতুন ডিফল্ট মান নির্বাচন করতে হবে এবং সংরক্ষণ টিপতে হবে।
আপনি একটি ফিল্টার অপসারণের পরে ফিল্টার ক্যাশে সাফ করা উচিত (আবার, এর দ্বারা আবৃত নয় drush cc all
!):
cache_clear_all('*', 'cache_filter', TRUE);
বা ড্রাশ সহ:
drush sqlq "truncate table cache_filter;"
field_cache_clear();
পরিবর্তনগুলিfield_data_...
এবংfield_revision_...
টেবিলগুলির পরেও করা উচিত