Database Tutorials Complex JSON Structure এবং Data Manipulation গাইড ও নোট

345

PostgreSQL একটি শক্তিশালী ডেটাবেস সিস্টেম যা JSON (JavaScript Object Notation) ডেটা টাইপ সাপোর্ট করে। JSON ডেটা টাইপটি PostgreSQL 9.2 সংস্করণ থেকে সাপোর্ট করা শুরু করেছে এবং এখন এটি JSONJSONB ফরম্যাটে ডেটা স্টোর করতে এবং পরিচালনা করতে ব্যবহৃত হয়। PostgreSQL JSON ডেটা টাইপের উপর আরও উন্নত কাজ করতে পারে, যেমন নেস্টেড JSON অবজেক্ট, অ্যারে, এবং বিভিন্ন ফিল্ডের মধ্যে দ্রুত অনুসন্ধান।

এখানে Complex JSON Structure এবং Data Manipulation এর কিছু গুরুত্বপূর্ণ ধারণা ও কৌশল নিয়ে আলোচনা করা হবে, যা PostgreSQL-এ JSON ডেটার সাথে কাজ করার জন্য ব্যবহৃত হয়।


1. Complex JSON Structure in PostgreSQL

Complex JSON Structure বলতে বুঝানো হয় JSON অবজেক্ট যা একটি বা একাধিক নেস্টেড অবজেক্ট (nested objects), অ্যারে (arrays), অথবা বিভিন্ন ডেটা টাইপ ধারণ করে। PostgreSQL JSON ফিল্ডগুলোর মধ্যে এই ধরনের জটিল কাঠামো সমর্থন করে এবং এর মাধ্যমে দ্রুত অ্যাক্সেস এবং পরিবর্তন করা সম্ভব।

উদাহরণ: Complex JSON Structure

{
  "user_id": 101,
  "name": "John Doe",
  "email": "john.doe@example.com",
  "address": {
    "street": "123 Main St",
    "city": "Dhaka",
    "postal_code": "1212"
  },
  "phones": [
    { "type": "mobile", "number": "1234567890" },
    { "type": "home", "number": "0987654321" }
  ]
}

এটি একটি JSON অবজেক্ট, যা user_id, name, email, একটি নেস্টেড অবজেক্ট address, এবং একটি অ্যারে phones ধারণ করে। PostgreSQL এই ধরনের জটিল JSON স্ট্রাকচার খুব সহজে সঞ্চয় করতে এবং পরিচালনা করতে পারে।


2. JSONB vs JSON in PostgreSQL

PostgreSQL দুই ধরনের JSON ডেটা টাইপ সাপোর্ট করে:

  1. JSON:
    • এটি একটি সাধারণ JSON ডেটা টাইপ যা JSON ডেটা ফরম্যাটের সাথে সম্পূর্ণ মিলে যায়। এতে ডেটা স্টোর করার পরে JSON টেক্সট 그대로 সেভ থাকে, তাই এটি পঠনযোগ্য কিন্তু দ্রুত অ্যাক্সেসে কিছুটা ধীর হতে পারে।
  2. JSONB:

    • এটি একটি বাইনারি ফরম্যাট, যা JSON ডেটাকে বাইনারি স্টোরেজে রূপান্তরিত করে। JSONB ডেটা টাইপ ডেটার স্টোরেজ ও পারফরম্যান্স অপটিমাইজ করতে সাহায্য করে, এবং এই টাইপটি সাধারণত দ্রুত অনুসন্ধান এবং আপডেট কার্যক্রমের জন্য উপযুক্ত।

    সাধারণত JSONB ব্যবহার করার পরামর্শ দেওয়া হয়, কারণ এটি দ্রুত কার্যকরী এবং কার্যকরভাবে ইনডেক্স করা যায়।


3. Manipulating Complex JSON Data

PostgreSQL JSON ডেটার সাথে বিভিন্ন রকমের ম্যানিপুলেশন করতে পারে, যেমন JSON অবজেক্ট বা অ্যারে থেকে নির্দিষ্ট ভ্যালু বের করা, নতুন ভ্যালু যোগ করা, বা JSON ডেটাকে আপডেট করা।

a. Extracting Data from JSON

PostgreSQL ->, ->>, #> এবং #>> অপারেটর ব্যবহার করে JSON ডেটা থেকে নির্দিষ্ট মান বের করতে পারে।

  1. ->: JSON অবজেক্টের একটি কীগুলির মান বের করে (JSON টাইপ ফিরে দেয়)।
  2. ->>: JSON অবজেক্টের একটি কীগুলির মান বের করে (টেক্সট হিসেবে ফিরে দেয়)।
  3. #>: নেস্টেড JSON অবজেক্টের মান বের করে।
  4. #>>: নেস্টেড JSON অবজেক্টের মান বের করে (টেক্সট হিসেবে)।

উদাহরণ:

-- JSON অবজেক্ট থেকে 'name' বের করা
SELECT user_data->>'name' FROM users WHERE user_id = 101;

-- JSON অবজেক্ট থেকে 'address.city' বের করা (নেস্টেড JSON)
SELECT user_data#>>'{address, city}' FROM users WHERE user_id = 101;

-- JSON অ্যারে থেকে 'mobile' ফোন নম্বর বের করা
SELECT user_data->'phones'->0->>'number' FROM users WHERE user_id = 101;

এখানে, JSON ডেটা থেকে নির্দিষ্ট কীগুলির মান বের করা হচ্ছে।


b. Modifying JSON Data

PostgreSQL JSON ডেটার মধ্যে পরিবর্তন করতে jsonb_set বা jsonb_insert ফাংশন ব্যবহার করা হয়।

jsonb_set: এটি একটি নির্দিষ্ট কীগুলির মান আপডেট করতে ব্যবহৃত হয়।

উদাহরণ:

-- JSONB ডেটার মধ্যে 'address.city' আপডেট করা
UPDATE users
SET user_data = jsonb_set(user_data, '{address, city}', '"Chittagong"')
WHERE user_id = 101;

এখানে user_data JSONB ডেটাতে address.city আপডেট করা হচ্ছে।

jsonb_insert: এটি JSON অ্যারে বা অবজেক্টে নতুন ডেটা ইনসার্ট করতে ব্যবহৃত হয়।

উদাহরণ:

-- JSON অ্যারে তে নতুন ফোন নম্বর যোগ করা
UPDATE users
SET user_data = jsonb_set(user_data, '{phones, 1}', '{"type": "office", "number": "1122334455"}')
WHERE user_id = 101;

এখানে phones অ্যারেতে একটি নতুন ফোন নম্বর যোগ করা হচ্ছে।


c. Appending Data to JSON Arrays

JSON অ্যারে-তে নতুন ডেটা যোগ করতে jsonb_array_append ফাংশন ব্যবহার করা যেতে পারে।

উদাহরণ:

-- JSON অ্যারেতে নতুন ফোন নম্বর যোগ করা
UPDATE users
SET user_data = jsonb_array_append(user_data, '{phones}', '{"type": "work", "number": "1239876543"}')
WHERE user_id = 101;

এখানে phones অ্যারেতে একটি নতুন ফোন নম্বর যোগ করা হচ্ছে।


4. JSON Indexing for Performance

JSON ডেটার উপর দ্রুত অনুসন্ধান এবং পারফরম্যান্স বৃদ্ধি করার জন্য, PostgreSQL JSONB ডেটা টাইপে ইনডেক্স তৈরি করতে পারে। কিছু সাধারণ ইনডেক্সিং কৌশল:

  1. GIN Index (Generalized Inverted Index):

    • JSONB ফিল্ডের জন্য সবচেয়ে সাধারণ ইনডেক্স হলো GIN ইনডেক্স, যা JSON ডেটার মধ্যে দ্রুত অনুসন্ধান করতে সহায়তা করে।
    CREATE INDEX idx_user_data ON users USING gin(user_data);
    
  2. B-tree Index for JSONB Fields:

    • যদি আপনি নির্দিষ্ট কীগুলির উপর অনুসন্ধান করতে চান, তবে B-tree ইনডেক্স ব্যবহার করা যেতে পারে।
    CREATE INDEX idx_user_data_name ON users((user_data->>'name'));
    

5. Advanced JSON Operations

PostgreSQL JSON ডেটার উপর আরও কিছু উন্নত অপারেশন সাপোর্ট করে:

  • JSON Aggregation: JSON ডেটাকে গ্রুপ করতে এবং অ্যাগ্রিগেট করতে json_agg() বা jsonb_agg() ব্যবহার করা হয়।
  • JSON Path Queries: JSON ডেটা অনুসন্ধানের জন্য PostgreSQL JSON path queries সাপোর্ট করে, যা JSON ডেটার মধ্যে বিভিন্ন পাথ অনুসরণ করে ফলাফল বের করতে সাহায্য করে।

উদাহরণ:

SELECT json_agg(user_data)
FROM users
WHERE user_data->>'city' = 'Dhaka';

এখানে users টেবিলের মধ্যে city 'Dhaka' এর সকল রেকর্ড একটি অ্যারে আকারে ফিরে আসবে।


সারাংশ

PostgreSQL JSON এবং JSONB ডেটা টাইপগুলি আপনাকে জটিল JSON ডেটার কাঠামো সংরক্ষণ, ম্যানিপুলেশন এবং বিশ্লেষণ করতে সহায়তা করে। PostgreSQL JSON ডেটার উপর একাধিক শক্তিশালী কার্যক্রম সম্পাদন করতে পারে, যেমন ডেটা এক্সট্রাকশন, ম্যানিপুলেশন, এবং ইনডেক্সিং। JSONB ব্যবহার করলে পারফরম্যান্স আরও উন্নত হয় এবং দ্রুত অনুসন্ধান করা যায়। JSON ডেটা সংরক্ষণের ক্ষেত্রে সঠিক ইনডেক্সিং এবং অপটিমাইজেশনের কৌশলগুলি পারফরম্যান্সকে উল্লেখযোগ্যভাবে বৃদ্ধি করতে পারে।

Content added By
Promotion

Are you sure to start over?

Loading...