1. Codeigniter Framework (CodeIgniter Framework Tutorial) Basic Tutorials of Codeigniter Framework
  2. কোডইগনাইটার ইনস্টল (CodeIgniter Install Tutorial in Bangla)
  3. How to create First Application in CodeIgniter
  4. কোডইগনাইটারের URL স্ট্রাকচার (structure of codeigniter)
  5. Codeigniter দিয়ে query করা এবং result দেখা (CI Query & Show Results)
  6. Database থেকে Data দেখা (CI Fetch Data from Database)
  7. Model তৈরী এবং কন্ট্রোলারে Access (Create Model & Access in Controller)
  8. Codeigniter দিয়ে ডেটাবেসে data ঢুকানো (CodeIgniter Insert Data to Database)
  9. Form দিয়ে ডেটাবেসের data সম্পাদনা (Data Edit in Database Via Form | Codeigniter Tutorials)
  10. ডেটাবেসের data delete (Data Delete in Database | Codeigniter Tutorials) | SP Foundationbd
  11. Form Validation টিউটোরিয়াল (CI Form Validation Tutorial | Codeigniter Tutorials) | SP Foundation
  12. Form validation tutorials (CI Form Validation Tutorial) - আরও উন্নত validation
  13. Codeigniter bootstrap integration এবং best প্রাকটিস | SP Foundationbd
  14. Codeigniter পেজিনেশন Tutorials (CodeIgniter Pagination Tutorial) | SP Foundationbd
  15. কোডইগনাইটার pagination tutorials (CodeIgniter Pagination Tutorial) - ২য় পদ্ধতিতে pagination
  16. Codeigniter সেশন Management (Session Management CodeIgniter) part one
  17. Codeigniter session ম্যানেজমেন্ট (Session Management CodeIgniter) - সেশন ড্রাইভার part two
  18. কোডইগনাইটার file আপলোড (CodeIgniter File Upload)
  19. কোডইগনাইটার Ajax টিউটোরিয়াল (CodeIgniter Ajax Tutorial) | SP Foundationbd
  20. কোডইগনাইটার URI রাউটিং টিউটোরিয়াল (CodeIgniter URI Routing Bangla Tutorials) | SP Foundationbd
  21. কোডইগনাইটারে একসাথে একাধিক ডেটাবেস ব্যবহার (Use Multiple Database Together in CodeIgniter)

কোডইগনাইটারে একসাথে একাধিক ডেটাবেস ব্যবহার (Use Multiple Database Together in CodeIgniter)

By default কোডইগনাইটারে একটি database ব্যবহার হয় যেটা "config/database.php" ফাইলে সেট করা থাকে। তবে আপনি চাইলে একাধিক ডেটাবেস ব্যবহার করতে পারেন। যেমন যখন "Users" কন্ট্রোলারে থাকবে তখন "abc" ডেটাবেসের সাথে অপারেশন করবে আর যখন "Shop" কন্ট্রোলারে থাকবে তখন "xyz" ডেটাবেসের সাথে কানেক্ট হবে এবং সেখানকার ডেটা নিয়ে কাজ করবে। এভাবে যেকোন সংখ্যক ডেটাবেস একটা এপ্লিকেশনে ব্যবহার করা যায়।

এছাড়াও development এবং প্রোডাকশন সার্ভারের database কনফিগারেশনের ভিন্নতার কারনে একাধিক ডেটাবেস configuration সেট করা লাগতে পারে এবং এতে কাজ সহজ হয়ে যায়। নিচে বিভিন্ন উদাহরন দেয়া হল

 ধরুন আপনি একটি কোডইগনািইটারের এপ্লিকেশনে কাজ করছেন লোকালি এবং যেটার ডেটাবেস নাম "abc", ইউজার নাম "root" এবং পাসওয়ার্ড "" আর এপ্লিকেশনটি যখন এই এপ্লিকেশনটি লাইভ করেছেন তখন ডেটাবেসটির নাম দিয়েছেন "example_abc", ইউজার নাম "example_abc" এবং পাসওয়ার্ড "^&H)&^UUHH"

এখন লোকালি কাজ করে যখন লাইভে site upload করবেন তখন কি বারবার এই database.php ফাইলে ডেটাবেস সেটিংস পরিবর্তন করবেন? যদি করেও থাকে থাকেন তাহলে এটা নিশ্চয় বিরক্তিকর লেগেছে। right? এটার জন্য একবারেই কাজ করতে পারেন শুধু লাইভে আপলোডের সময় একটা শব্দ লিখে দিলেই হয়ে যাবে। যেমন

database.php

01.$active_group = 'default';

02.$query_builder = TRUE;

03.//local db setting

04.$db['default'] = array(

05.'dsn' => '',

06.'hostname' => 'localhost',

07.'username' => 'root',

08.'password' => '',

09.'database' => 'abc',

10.'dbdriver' => 'mysqli',

11....

12.);

  1. 14.//production db setting

15.$db['prod'] = array(

16.'dsn' => '',

17.'hostname' => 'localhost',

18.'username' => 'example_abc',

19.'password' => '^&H)&^UUHH',

20.'database' => 'example_abc',

21.'dbdriver' => 'mysqli',

22....

23.);

দেখুন $db অ্যারে হচ্ছে মাল্টিডাইমেনশনাল অ্যারে এবং $db['default'] দিয়েছি লোকাল ডেটাবেস configuration এবং $active_group = "default" দেয়াতে এই্ ডেটাবেস নিয়ে কাজ হবে। এরপর যখন লাইভে upload করবেন তখন শুধু $active_group = "prod" করে দিলেই লাইভের database নিয়ে নিবে কারন $db['prod'] এখানে লাইভের ডেটাবেসের সেটিংস দিয়েছি।

আরও একটা system  আছে এখানে $active_group এটাও পরিবর্তন করতে হবেনা। automatic নিয়ে নিবে। এটা পরে দেখাব।

একাধিক ডেটাবেস

ধরুন একটা এপ্লিকেশনে ২টি ডেটাবেস নিয়ে কাজ করতে হবে। তাহলে হুবহু উপরের মতই শুধু আরেকটা database সেটিংস নিতে হবে আর উপরেরগুলি যেমন আছে থাকবে।

01.$db['notif'] = array(

02.'dsn' => '',

03.'hostname' => 'localhost',

04.'username' => 'root',

05.'password' => '',

06.'database' => 'tickets',

07.'dbdriver' => 'mysqli',

08....

09.);

এবার বাই default প্রথম ডেটাবেসটি নিয়ে কাজ করবে (যেটা $db['default'] আছে এবং যদি $active_group = "default" থাকে) তবে এখন চাইলে এপ্লিকেশনেই "tickets" ডেটাবেসটি নিয়ে কাজ করতে পারবেন যেটা ডিফাইন করলাম $db['notif'] এর ভিতর। খুব সহজ। শুধু এই নতুন ডেটাবেসটি ব্যবহারের জন্য প্রথমে ডেটাবেসটি লোড করে নিতে হবে। যেমন

1.$notify = $this->load->database('notif', TRUE);

 দেখুন load ক্লাসের database মেথডে "notif" দিয়েছি এর মানে হল notif অ্যারেতে যে ডেটাবেস (সেটিংস) দেয়া আছে সেটা লোড কর। আর ২য় প্যারামিটারে TRUE দেয়াতে ডেটাবেস object হিসেবে লোড হবে। এখন এই ডেটাবেসে যেকোন operation চালাতে $this->db এর স্থলে $notify দিলেই কাজ শেষ। কেননা $notify এখানে এখন নতুন ডেটাবেসটির হ্যান্ডেল।

উদাহরন

1.$notify = $this->load->database('notif', TRUE);

2.$query = $notify->where('is_open', 'yes')->where('dept_ID',2)->get('up_ticket');

3.$opened_tickets = $query->result_array();

 এভাবে যেকোন সংখ্যক database একই এপ্লিকেশনে load করিয়ে কোয়েরি বিল্ডার ব্যবহার করে যেকোন অপারেশন সেই ডেটাবেসে করতে পারবেন। শুধু $this->db এর জায়গায় নতুন ডেটাবেসটির হ্যান্ডেল দিতে হবে (এখানে $notify) সুতরাং এখন $this->db দিয়ে default ডেটাবেসে কাজ করবেন আর "tickets" ডেটাবেসে কাজ করতে হলে লোড করার পর $notify দিয়ে করতে হবে।