Database Tutorials PostgreSQL তে JSON এবং JSONB Data Type গাইড ও নোট

380

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


1. JSON Data Type

JSON (JavaScript Object Notation) হল একটি ওপেন স্ট্যান্ডার্ড ডেটা ফরম্যাট যা হিউম্যান-রিডেবল এবং কম্পিউটার-ফ্রেন্ডলি উভয়ই। PostgreSQL-এর JSON ডেটা টাইপ JSON ফরম্যাটে ডেটা সংরক্ষণ করে, তবে JSON ফরম্যাটের তথ্য স্টোর করা হলে এটি স্টোরেজে কিছুটা বেশি স্পেস নিলেও তার পারফরম্যান্স একটু কম হতে পারে।

JSON ডেটা টাইপ ব্যবহার

  1. টেবিল তৈরি করা JSON ডেটা টাইপ সহ:
CREATE TABLE users (
    id SERIAL PRIMARY KEY,
    name VARCHAR(100),
    info JSON
);

এখানে, info কলামটি JSON ডেটা টাইপের কলাম, যেখানে JSON ফরম্যাটে ডেটা সংরক্ষণ করা হবে।

  1. JSON ডেটা ইনসার্ট করা:
INSERT INTO users (name, info) 
VALUES ('John Doe', '{"age": 30, "email": "john.doe@example.com"}');

এটি users টেবিলের info কলামে একটি JSON অবজেক্ট ইনসার্ট করবে, যেখানে age এবং email গুলি মূলত কী-ভ্যালু পেয়ার হিসেবে সংরক্ষিত হবে।

  1. JSON ডেটা পড়া:
SELECT info->'age' AS age FROM users;

এখানে, -> অপারেটরটি JSON অবজেক্ট থেকে নির্দিষ্ট কী-এর মান বের করতে ব্যবহার করা হয়। এই কুয়েরি age কী-এর মান রিটার্ন করবে।


2. JSONB Data Type

JSONB হল "Binary JSON"। এটি JSON ডেটা টাইপের একটি উন্নত সংস্করণ যা ডেটাকে বাইনারি ফর্ম্যাটে সংরক্ষণ করে এবং JSON ডেটা পার্স করার জন্য কিছু অপটিমাইজেশন প্রদান করে, ফলে এটি দ্রুত এবং আরও কার্যকরীভাবে কাজ করে। JSONB ডেটা টাইপ JSON এর মতোই ফরম্যাটে ডেটা সংরক্ষণ করে, তবে এটি কিছু অতিরিক্ত সুবিধা প্রদান করে, যেমন ইনডেক্সিং সমর্থন এবং দ্রুত অনুসন্ধান।

JSONB ডেটা টাইপ ব্যবহার

  1. টেবিল তৈরি করা JSONB ডেটা টাইপ সহ:
CREATE TABLE users (
    id SERIAL PRIMARY KEY,
    name VARCHAR(100),
    info JSONB
);

এখানে, info কলামটি JSONB ডেটা টাইপ ধারণ করে, যার মাধ্যমে দ্রুত এবং কার্যকরী JSON ডেটা পার্সিং সম্ভব।

  1. JSONB ডেটা ইনসার্ট করা:
INSERT INTO users (name, info) 
VALUES ('Alice Smith', '{"age": 28, "email": "alice.smith@example.com"}'::jsonb);

এটি users টেবিলের info কলামে JSONB ডেটা ইনসার্ট করবে, যেখানে age এবং email কী-ভ্যালু পেয়ার হিসেবে সংরক্ষিত হবে।

  1. JSONB ডেটা পড়া:
SELECT info->'age' AS age FROM users;

এটি JSONB ডেটা থেকে age কী-এর মান রিটার্ন করবে।


3. JSON এবং JSONB এর মধ্যে পার্থক্য

বৈশিষ্ট্যJSONJSONB
স্টোরেজJSON ডেটা টেক্সট ফরম্যাটে সংরক্ষণ করা হয়।JSONB ডেটা বাইনারি ফরম্যাটে সংরক্ষণ করা হয়।
পারফরম্যান্সপার্সিং এবং অনুসন্ধান ধীর হতে পারে।দ্রুত অনুসন্ধান এবং পারফরম্যান্স প্রদান করে।
ডেটা ইনডেক্সিংইনডেক্সিং সমর্থন করে না।JSONB ইনডেক্সিং সমর্থন করে, ফলে দ্রুত অনুসন্ধান হয়।
ডেটা পুনরায় সাজানোসাজানো অবস্থা বজায় থাকে।ডেটা সাজানো থাকে না, তবে বাইনারি ফরম্যাটে সংরক্ষণ করা হয়।
অপারেশনকম্প্যাক্ট কিন্তু কিছু অপারেশন ধীর।অনেক দ্রুত এবং আরও অপটিমাইজড অপারেশন সরবরাহ করে।
ফ্লেক্সিবিলিটিডেটা ফরম্যাট একই থাকে (কী-ভ্যালু পেয়ার)।JSONB আরো স্ট্রাকচারড ডেটা এবং দ্রুত কুয়েরি রেসপন্স প্রদান করে।

4. JSON এবং JSONB-এ ইনডেক্সিং

JSONB ডেটা টাইপে ইনডেক্সিং অত্যন্ত কার্যকরী, বিশেষত যখন ডেটাবেসে বড় JSON ডেটা থাকে এবং দ্রুত অনুসন্ধানের প্রয়োজন হয়। PostgreSQL-এ JSONB ডেটা টাইপে ইনডেক্স তৈরি করার জন্য GIN (Generalized Inverted Index) ব্যবহৃত হয়।

JSONB ডেটা টাইপে ইনডেক্স তৈরি করা

CREATE INDEX idx_users_info ON users USING gin (info);

এটি info কলামের উপর একটি GIN ইনডেক্স তৈরি করবে, যা JSONB ডেটা টাইপের অনুসন্ধানকে আরও দ্রুততর করবে।


সারাংশ

  1. JSON হল একটি সহজ JSON ডেটা টাইপ, যা পাঠযোগ্য (human-readable) ফরম্যাটে ডেটা সংরক্ষণ করে, তবে কিছু পারফরম্যান্স সীমাবদ্ধতা রয়েছে।
  2. JSONB হল একটি উন্নত সংস্করণ যা বাইনারি ফরম্যাটে ডেটা সংরক্ষণ করে এবং দ্রুত পারফরম্যান্স, ইনডেক্সিং এবং কার্যকরী অপারেশন সরবরাহ করে।
  3. JSONB ব্যবহার করার পরামর্শ দেওয়া হয় যদি আপনি দ্রুত পারফরম্যান্স এবং ডেটার উপর জটিল কুয়েরি অপারেশন করতে চান। JSON ব্যবহার করা যেতে পারে যদি আপনি ডেটার পাঠযোগ্যতা এবং সিম্পল ডেটা কাঠামো চান।
  4. PostgreSQL JSON এবং JSONB-তে ইনডেক্সিং সমর্থন করে, তবে JSONB আরও বেশি কার্যকরী ইনডেক্সিং সমর্থন করে।

এই ডেটা টাইপগুলি PostgreSQL-এ JSON এবং JSONB ডেটা সংরক্ষণ এবং প্রক্রিয়া করার জন্য অত্যন্ত কার্যকরী।

Content added By

JSON এবং JSONB কী এবং কেন ব্যবহার করবেন?

261

JSON (JavaScript Object Notation) এবং JSONB (Binary JSON) হল দুটি ডেটা টাইপ যা PostgreSQL-এ JSON ডেটা সংরক্ষণ এবং প্রক্রিয়া করার জন্য ব্যবহৃত হয়। এই দুটি ডেটা টাইপে ডেটা স্টোরেজ এবং অপারেশন সম্পর্কিত কিছু পার্থক্য রয়েছে। PostgreSQL-এ JSON এবং JSONB ডেটা টাইপ ব্যবহার করার মাধ্যমে আপনি সুনির্দিষ্ট স্ট্রাকচার্ড ডেটা সহজে সংরক্ষণ এবং পরিচালনা করতে পারেন।


1. JSON

JSON (JavaScript Object Notation) একটি টেক্সট ভিত্তিক ডেটা ফরম্যাট যা মূলত JavaScript-এ ব্যবহৃত হয়, তবে এটি অন্যান্য প্রোগ্রামিং ভাষাতেও জনপ্রিয়। এটি ডেটার উপস্থাপনা এবং স্টোরেজের জন্য মানব-পঠনযোগ্য এবং কম্পিউটার দ্বারা পার্সযোগ্য ফরম্যাট। PostgreSQL-এ JSON টাইপ ডেটা স্টোর করার জন্য ব্যবহৃত হয়।

JSON এর বৈশিষ্ট্য:

  • স্টোরেজ ফরম্যাট: JSON ফরম্যাট সাধারণত টেক্সট হিসাবে স্টোর করা হয়।
  • ডেটার অর্ডার: JSON ডেটায় কী-ভ্যালু পেয়ারসের অর্ডার গুরুত্বপূর্ণ। তবে, JSON ডেটা টাইপের মধ্যে অর্ডার সংরক্ষিত হয় না।
  • মানব-পঠনযোগ্য: JSON ডেটা সাধারণত মানব-পঠনযোগ্য এবং সহজে পাঠযোগ্য।

JSON উদাহরণ:

{
    "name": "John Doe",
    "email": "john.doe@example.com",
    "age": 30,
    "address": {
        "street": "123 Main St",
        "city": "New York"
    }
}

এই উদাহরণে একটি সাধারণ JSON ডেটা রয়েছে যা name, email, age, এবং address কীগুলির সাথে মান সংরক্ষণ করেছে।


2. JSONB

JSONB হল PostgreSQL-এ একটি উন্নত এবং বাইনারি ফরম্যাট JSON ডেটার জন্য। এটি JSON এর মতো একই ধরনের ডেটা সংরক্ষণ করে, তবে JSONB-তে ডেটা বাইনারি ফরম্যাটে সংরক্ষিত হয়, যা দ্রুততার সাথে অনুসন্ধান এবং প্রসেসিংয়ের জন্য উপযোগী।

JSONB এর বৈশিষ্ট্য:

  • স্টোরেজ ফরম্যাট: JSONB ফরম্যাটটি বাইনারি ডেটা ফরম্যাটে স্টোর করা হয়, যা পারফরম্যান্স এবং অনুসন্ধানের ক্ষেত্রে JSON থেকে অনেক উন্নত।
  • ডেটার অর্ডার: JSONB ডেটাতে কী-ভ্যালু পেয়ারসের অর্ডার গুরুত্বপূর্ণ নয়, এবং অর্ডার কিপিং (যেমন JSON) এর মতো সংরক্ষিত থাকে না।
  • দ্রুত অনুসন্ধান এবং ইনডেক্সিং: JSONB ডেটা দ্রুত অনুসন্ধান এবং কার্যকরী ইনডেক্সিংয়ের জন্য তৈরি করা হয়েছে।
  • এডভান্সড অপারেশন: JSONB বিভিন্ন এডভান্সড অপারেশন এবং কুয়েরি ফাংশন সমর্থন করে যেমন গিন ইনডেক্সিং এবং অন্যান্য।

JSONB উদাহরণ:

{
    "name": "John Doe",
    "email": "john.doe@example.com",
    "age": 30,
    "address": {
        "street": "123 Main St",
        "city": "New York"
    }
}

এটি JSON ডেটার মতোই দেখতে কিন্তু বাইনারি ফরম্যাটে সংরক্ষিত।


3. JSON এবং JSONB এর মধ্যে পার্থক্য

বৈশিষ্ট্যJSONJSONB
স্টোরেজ ফরম্যাটটেক্সট ভিত্তিকবাইনারি ফরম্যাট
ডেটার অর্ডারগুরুত্বপূর্ণ (কী-ভ্যালু পেয়ারসের অর্ডার সংরক্ষিত)অর্ডার গুরুত্বপূর্ণ নয়
পারফরম্যান্সস্লো, কারণ টেক্সট ফরম্যাটের জন্য অপারেশনগুলি ধীর হতে পারেদ্রুত, বাইনারি ফরম্যাট এবং কার্যকরী ইনডেক্সিং
অনুসন্ধান এবং ইনডেক্সিংতুলনামূলকভাবে ধীরদ্রুত এবং কার্যকরী ইনডেক্সিং সমর্থন করে
ডেটার প্রক্রিয়াকরণকেবল সাধারণ কুয়েরি সাপোর্ট করেঅধিক কার্যকরী এবং কাস্টম ফাংশন সাপোর্ট করে
দুর্বল পয়েন্টউন্নত অনুসন্ধান এবং বিশ্লেষণের জন্য কম কার্যকরJSONB এর তুলনায় স্টোরেজে কিছু অতিরিক্ত জায়গা নেয়

4. কেন JSON এবং JSONB ব্যবহার করবেন?

JSON ব্যবহারের সুবিধা:

  • মানব-পঠনযোগ্য ফরম্যাট: JSON সহজেই মানব-পঠনযোগ্য হওয়ায়, ডেটার সাথে কাজ করার জন্য এটি অনেক সুবিধাজনক।
  • লাইটওয়েট: ছোট ডেটাসেটের জন্য JSON উপযুক্ত এবং সহজেই সরবরাহযোগ্য এবং পাঠযোগ্য হয়।

JSONB ব্যবহারের সুবিধা:

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

কোন পরিস্থিতিতে JSONB ব্যবহার করবেন?

  • যখন আপনার দ্রুত ডেটা অনুসন্ধান, ইনডেক্সিং এবং বড় ডেটাসেট নিয়ে কাজ করার প্রয়োজন হয়।
  • যদি আপনি JSON ডেটাকে ডেটাবেসে আরও দ্রুত এবং কার্যকরীভাবে প্রসেস করতে চান।

কোন পরিস্থিতিতে JSON ব্যবহার করবেন?

  • যখন ডেটার ছোট সাইজ বা সামান্য পরিবর্তন প্রয়োজন হয় এবং আপনি ডেটাকে সহজে পড়তে বা লিখতে চান।
  • যদি আপনার JSON ডেটার অর্ডার গুরুত্বপূর্ণ হয় এবং পারফরম্যান্স খুব বেশি গুরুত্বপূর্ণ না হয়।

5. JSON এবং JSONB এর ব্যবহারের বাস্তব উদাহরণ

JSON Example:

ডেটার মাঝে কিছু পরিবর্তন না করেও সরাসরি ডেটা ইনসার্ট করা:

CREATE TABLE users (
  id SERIAL PRIMARY KEY,
  data JSON
);

INSERT INTO users (data) 
VALUES ('{"name": "John Doe", "email": "john.doe@example.com"}');

JSONB Example:

ডেটার জন্য ইনডেক্সিং এবং দ্রুত অনুসন্ধান ব্যবহারের জন্য JSONB:

CREATE TABLE users (
  id SERIAL PRIMARY KEY,
  data JSONB
);

INSERT INTO users (data) 
VALUES ('{"name": "John Doe", "email": "john.doe@example.com"}');

-- গিন ইনডেক্সিং
CREATE INDEX idx_users_data ON users USING gin (data);

সারাংশ

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

PostgreSQL-এ JSON এবং JSONB-র সুবিধাগুলি আপনার ডেটাবেস ডিজাইন এবং ব্যবহারের প্রয়োজন অনুযায়ী নির্বাচন করা উচিত।

Content added By

JSONB এর সুবিধা এবং JSON এর সাথে পার্থক্য

260

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


JSON (JavaScript Object Notation)

JSON হল একটি টেক্সট-ভিত্তিক ডেটা ফরম্যাট যা সাধারণত ডেটা স্টোরেজ এবং ট্রান্সফার করার জন্য ব্যবহৃত হয়। এটি পাঠযোগ্য এবং সহজে বুঝতে পারা যায়।

JSON এর সুবিধা:

  1. মানব-পাঠযোগ্য (Human-readable):
    • JSON ডেটা সাধারণত পাঠযোগ্য হয়, কারণ এটি টেক্সট-ভিত্তিক এবং ডেভেলপারদের জন্য সহজে ব্যবহারযোগ্য।
  2. ফ্লেক্সিবিলিটি:
    • JSON ডেটা স্কিমা-লেস, অর্থাৎ এটি যেকোনো ধরনের ডেটা স্ট্রাকচার ধারণ করতে পারে। প্রতিটি ডেটা পয়েন্টকে JSON অবজেক্টের মাধ্যমে সংরক্ষণ করা যায়, এবং এতে আনস্ট্রাকচারড ডেটা বা ভেরিয়েবল আর্গুমেন্ট রাখা যেতে পারে।
  3. অ্যাক্সেস করা সহজ:
    • JSON ডেটা অবজেক্ট হিসেবে তৈরি করা যায়, যা দ্রুত এক্সেস করা যায় এবং বড় ডেটাসেটের মধ্যে খোঁজা সহজ হয়।

JSON এর সীমাবদ্ধতা:

  • পার্থক্যপূর্ণ পারফরম্যান্স: JSON ডেটা পার্স করার সময়, তা একেবারে টেক্সট ফরম্যাটে থাকে, ফলে তা কম্পিউটেশনে বেশি সময় নেবে। এবং JSON ডেটাতে ডেটা স্ট্রাকচারের মধ্যে কোনো ইনডেক্সিং, বাছাই বা অপটিমাইজেশন থাকে না।
  • অপারেশন সীমিত: JSON ডেটার ওপর কিছু নির্দিষ্ট অপারেশন (যেমন সংশোধন, সাজানো) করার সময় কম কার্যক্ষম হতে পারে।

JSONB (Binary JSON)

JSONB হল JSON এর একটি বাইনারি সংস্করণ। এটি JSON ডেটাকে বাইনারি ফরম্যাটে সংরক্ষণ করে এবং তা দ্রুত প্রসেস করার জন্য অপটিমাইজড। এটি JSON এর মতনই তথ্য ধারণ করে, তবে পারফরম্যান্স এবং কার্যকারিতায় অনেক উন্নত।

JSONB এর সুবিধা:

  1. দ্রুত পারফরম্যান্স:
    • JSONB বাইনারি ফরম্যাটে ডেটা সংরক্ষণ করে, ফলে এটি JSON এর তুলনায় অনেক দ্রুত। বিশেষ করে, যখন আপনি ডেটা খোঁজা, বাছাই বা আপডেট করেন, তখন JSONB দ্রুত কাজ করে।
  2. ডেটা ইনডেক্সিং:
    • JSONB ডেটা ইন্ডেক্স করতে সহায়ক, যা JSON-এ সম্ভব নয়। এর ফলে বৃহৎ ডেটাবেসে দ্রুত অনুসন্ধান করা যায়। PostgreSQL JSONB ডেটার উপর GIN (Generalized Inverted Index) এবং GiST (Generalized Search Tree) ইনডেক্স সমর্থন করে।
  3. অপারেশন সুবিধা:
    • JSONB ডেটাতে কিছু নির্দিষ্ট অপারেশন (যেমন: ক্ষেত্র গোনা, ডেটা আপডেট করা) দ্রুত এবং দক্ষভাবে করা যায়।
    • JSONB এ সন্নিবেশ, আপডেট এবং মুছে ফেলা অপারেশনগুলি দ্রুত এবং কার্যকরী।
  4. ডুপ্লিকেট কী অ্যালাউ:
    • JSONB ডেটাতে কী-ভ্যালু পেয়ারগুলি duplicate keys ধরতে পারে না, তবে এটি স্টোরেজ এবং অনুসন্ধানে আরো দক্ষ।
  5. প্রক্রিয়া উন্নতি:
    • JSONB ডেটাকে প্রসেস করার জন্য বিভিন্ন অপটিমাইজেশন রয়েছে, যার ফলে আপনি দ্রুত এক্সিকিউটেবল কোড চালাতে পারেন।

JSON এবং JSONB এর মধ্যে পার্থক্য

বৈশিষ্ট্যJSONJSONB
স্টোরেজ ফরম্যাটটেক্সট ফরম্যাটবাইনারি ফরম্যাট
পারফরম্যান্সকম কার্যক্ষম, কারণ এটি টেক্সট হিসেবে সংরক্ষিত হয়দ্রুত পারফরম্যান্স, বাইনারি ফরম্যাটে সংরক্ষিত
ইনডেক্সিংJSON ডেটায় ইনডেক্সিং করা যায় নাJSONB ডেটায় ইনডেক্সিং করা যায় (GIN, GiST)
ডেটা সংরক্ষণJSON ডেটা টেক্সট ফরম্যাটে সংরক্ষণ হয়JSONB ডেটা বাইনারি ফরম্যাটে সংরক্ষণ হয়
ডুপ্লিকেট কীJSON ডুপ্লিকেট কী সমর্থন করেJSONB ডুপ্লিকেট কী সমর্থন করে না (শেষের কী বজায় থাকে)
প্রসেসিংপ্রসেসিং ধীর, কারণ এটি পাঠযোগ্য এবং টেক্সট ফরম্যাটদ্রুত প্রসেসিং, কারণ এটি বাইনারি ফরম্যাট
অনুসন্ধানঅনুসন্ধান ধীর (বিশেষ অপারেশনগুলো সঠিকভাবে করা কঠিন)দ্রুত অনুসন্ধান এবং বাছাই অপারেশন (ইনডেক্সিং সাপোর্ট)
সুপারফ্লাস এবং রিডান্ডেন্ট ডেটাঅনুমতি দেয়রিডান্ডেন্ট ডেটা সরিয়ে ফেলে

কখন JSON এবং JSONB ব্যবহার করবেন?

  • JSON: যদি আপনি শুধুমাত্র ডেটা স্টোর করতে চান এবং ডেটার মধ্যে কম পারফরম্যান্স সম্পর্কিত কাজ করছেন (যেমন: ডেটা ট্রান্সফার বা সামান্য পরিবর্তন), তবে JSON ব্যবহার করতে পারেন।
  • JSONB: যদি আপনি একটি বড় ডেটাবেসের মধ্যে ডেটার ওপর উচ্চ কার্যক্ষমতা ও অনুসন্ধান করতে চান, বিশেষ করে যেখানে আপনি অনেক পরিবর্তন বা ফিল্টারিং করছেন, তবে JSONB ব্যবহার করা উত্তম।

সারাংশ

  • JSON একটি টেক্সট-ভিত্তিক ডেটা ফরম্যাট যা মানব-পাঠযোগ্য এবং সহজে পাঠযোগ্য হলেও এটি প্রসেসিং এবং অনুসন্ধানে ধীর।
  • JSONB একটি বাইনারি ফরম্যাট যা দ্রুত পারফরম্যান্স এবং ইনডেক্সিং সুবিধা প্রদান করে এবং বড় ডেটাসেটের জন্য আরও উপযুক্ত।

JSONB সাধারণত পরবর্তী প্রজেক্টে JSON এর তুলনায় বেশি কার্যকরী এবং পছন্দসই, বিশেষ করে যখন ডেটাবেসের মধ্যে একাধিক কুয়েরি বা জটিল অপারেশন করা হয়।

Content added By

JSON Data Query করা (Operators এবং Functions)

307

PostgreSQL একটি শক্তিশালী ডেটাবেস সিস্টেম যা JSON এবং JSONB ডেটা টাইপ সাপোর্ট করে। JSON ডেটা ফরম্যাট বেশিরভাগ ওয়েব অ্যাপ্লিকেশন ও API ইন্টিগ্রেশনে ব্যবহৃত হয়, এবং PostgreSQL এর মধ্যে JSON ডেটা কার্যকরভাবে অনুসন্ধান এবং পরিচালনা করার জন্য বিভিন্ন Operators এবং Functions সরবরাহ করে।

এই টিউটোরিয়ালে PostgreSQL তে JSON ডেটা Query করার জন্য ব্যবহৃত সাধারণ Operators এবং Functions সম্পর্কে বিস্তারিত আলোচনা করা হবে।


1. JSON Data Types in PostgreSQL

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

  • JSON: এটি স্টোর করে মূল JSON ডেটা ফরম্যাটে (টেক্সট হিসাবে), কিন্তু পারফরম্যান্স কিছুটা কম হতে পারে।
  • JSONB: এটি একটি বাইনারি ফরম্যাটে JSON ডেটা স্টোর করে এবং এর পারফরম্যান্স সাধারণত আরও ভালো হয়, কারণ এটি ইনডেক্সিং সাপোর্ট করে এবং দ্রুত পার্সিং করতে সক্ষম।

JSON এবং JSONB উভয়ের সাথে বিভিন্ন অপারেটর এবং ফাংশন ব্যবহার করা যেতে পারে।


2. JSON Querying Operators

PostgreSQL JSON ডেটার উপর কাজ করতে বিভিন্ন অপারেটর ব্যবহার করা যায়, যার মাধ্যমে আপনি JSON ডেটার ভিতরের অংশে অ্যাক্সেস করতে পারেন এবং তাদের উপর কাজ করতে পারেন।

a. -> Operator

-> অপারেটরটি JSON ডেটার একটি কী এর মান ফিরিয়ে দেয় (যদি তা একটি অবজেক্ট বা অ্যারে হয়)।

  • JSONB বা JSON Object থেকে একটি কী এর মান:

    SELECT data->'name' FROM users;
    

    এখানে data JSON বা JSONB কলাম হতে name কী এর মান বের করা হয়েছে।

b. ->> Operator

->> অপারেটরটি JSON ডেটার একটি কী এর মানকে টেক্সট হিসাবে ফিরিয়ে দেয়।

  • JSONB বা JSON Object থেকে একটি কী এর মান টেক্সট আকারে:

    SELECT data->>'name' FROM users;
    

    এখানে, name কী এর মান টেক্সট আকারে ফিরে আসবে, যেমন "John"।

c. #>> Operator

#>> অপারেটরটি JSONB অথবা JSON ডেটার একটি নেস্টেড কী এর মান টেক্সট হিসেবে ফিরিয়ে দেয়। এটি JSON অবজেক্টের গভীরে একটি কী পর্যন্ত অ্যাক্সেস করতে ব্যবহৃত হয়।

  • Nested JSON এর মান টেক্সট আকারে:

    SELECT data#>>'{address, city}' FROM users;
    

    এখানে address অবজেক্টের ভিতরে থাকা city কী এর মান টেক্সট হিসেবে বের করা হচ্ছে।

d. @> Operator

@> অপারেটরটি চেক করে যে একটি JSONB ডেটা অন্য একটি JSONB ডেটাকে অন্তর্ভুক্ত করছে কি না। এটি JSONB containment অপারেটর নামে পরিচিত।

  • JSONB ডেটা containment চেক:

    SELECT * FROM users WHERE data @> '{"name": "John"}';
    

    এই কুয়েরি data কলামে name কী এর মান "John" রয়েছে এমন রেকর্ডগুলি ফিরিয়ে আনবে।

e. <@ Operator

<@ অপারেটরটি চেক করে যে একটি JSONB ডেটা আরেকটি JSONB ডেটার মধ্যে অন্তর্ভুক্ত কিনা।

  • JSONB containment উল্টো চেক:

    SELECT * FROM users WHERE '{"name": "John"}' <@ data;
    

f. || Operator

|| অপারেটরটি দুটি JSONB অবজেক্ট একত্রিত করতে ব্যবহৃত হয়। এটি দুটি JSONB অবজেক্টকে একসাথে যুক্ত করে।

  • JSONB objects combine:

    SELECT data || '{"city": "New York"}' FROM users;
    

g. - Operator

- অপারেটরটি JSONB থেকে একটি নির্দিষ্ট কী মুছে ফেলার জন্য ব্যবহৃত হয়।

  • JSONB থেকে কী মুছে ফেলা:

    SELECT data - 'name' FROM users;
    

3. JSON Functions

PostgreSQL JSON ডেটার সাথে আরও কার্যকরভাবে কাজ করতে একটি সিরিজ ফাংশন সরবরাহ করে। এখানে কিছু গুরুত্বপূর্ণ JSON ফাংশন আলোচনা করা হলো:

a. jsonb_array_elements()

এই ফাংশনটি JSONB অ্যারে থেকে প্রতিটি উপাদানকে আলাদাভাবে বের করে। এটি একটি সেট-ভ্যালু ফাংশন (set-returning function) যা একাধিক রেকর্ড ফেরত দেয়।

  • JSONB অ্যারে উপাদান বের করা:

    SELECT jsonb_array_elements(data->'tags') FROM users;
    

    এখানে tags অ্যারে থেকে প্রতিটি উপাদান আলাদাভাবে বের করা হচ্ছে।

b. jsonb_each()

এই ফাংশনটি JSONB অবজেক্টের প্রতিটি কী এবং মানকে একটি সেট রিটার্ন করে। এটি JSONB অবজেক্টের কীগুলি এবং তাদের মান বের করতে ব্যবহৃত হয়।

  • JSONB অবজেক্টের প্রতিটি কী-মান পেয়ার বের করা:

    SELECT * FROM jsonb_each(data);
    

c. jsonb_extract_path()

এই ফাংশনটি JSONB ডেটার একটি নির্দিষ্ট পথ থেকে মান বের করে। এটি নেস্টেড JSON ডেটা থেকে মান বের করার জন্য ব্যবহৃত হয়।

  • নেস্টেড JSONB থেকে মান বের করা:

    SELECT jsonb_extract_path(data, 'address', 'city') FROM users;
    

d. jsonb_set()

এই ফাংশনটি JSONB ডেটার একটি নির্দিষ্ট কী এর মান আপডেট করতে ব্যবহৃত হয়।

  • JSONB এর মান আপডেট করা:

    SELECT jsonb_set(data, '{address, city}', '"San Francisco"') FROM users;
    

e. jsonb_to_record()

এই ফাংশনটি JSONB ডেটা থেকে একটি রেকর্ড তৈরি করতে ব্যবহৃত হয়, যা ডেটা রূপান্তর করতে সহায়তা করে।

  • JSONB থেকে রেকর্ড তৈরি করা:

    SELECT * FROM jsonb_to_record(data) AS x(name text, age int);
    

4. JSON Query Examples

a. JSON Data থেকে Filter করা

ধরা যাক, আপনার users টেবিলে JSON ডেটা রয়েছে এবং আপনি সেই ডেটার নির্দিষ্ট মান অনুসারে রেকর্ড বের করতে চান:

SELECT * FROM users WHERE data->>'name' = 'John';

এটি name কলামের মান "John" এর সাথে মেলানো রেকর্ড ফিরিয়ে আনবে।

b. JSONB Data Filtering

যদি JSONB ডেটা থাকে এবং আপনি JSONB কন্টেইনমেন্ট অপারেটর ব্যবহার করতে চান, তাহলে আপনি এমন কুয়েরি করতে পারেন:

SELECT * FROM users WHERE data @> '{"address": {"city": "New York"}}';

এটি data কলামে address অবজেক্টের মধ্যে city "New York" থাকা রেকর্ড ফিরিয়ে আনবে।

c. JSONB Field Update

JSONB ডেটায় একটি নির্দিষ্ট মান আপডেট করতে:

UPDATE users SET data = jsonb_set(data, '{address, city}', '"Chicago"') WHERE id = 1;

এটি id 1 এর ব্যবহারকারীর address.city মান পরিবর্তন করবে "Chicago" তে।


5. Performance Considerations

  1. Indexing: JSONB ডেটাতে দ্রুত অনুসন্ধান করতে GIN (Generalized Inverted Index) ইনডেক্স ব্যবহার করা যেতে পারে। এটি JSONB ডেটার সঠিক ফিল্টারিং এবং অনুসন্ধান দ্রুত করতে সহায়ক।

    CREATE INDEX idx_gin_data ON users USING gin (data);
    
  2. Use JSONB for Performance: JSONB দ্রুত পার্সিং এবং ইনডেক্সিং সাপোর্ট করে, তাই যদি পারফরম্যান্স গুরুত্বপূর্ণ হয়, তবে JSONB ব্যবহার করা ভালো।

Conclusion

PostgreSQL এর JSON এবং JSONB ফিচারগুলি ডেটাবেসে JSON ডেটার সাথে কাজ করার জন্য অনেক শক্তিশালী অপারেটর এবং ফাংশন সরবরাহ করে। Operators যেমন ->, ->>, @>, এবং Functions যেমন jsonb_array_elements(), jsonb_each() ইত্যাদি ডেটার গভীরে প্রবেশ এবং তার উপর কার্যকরভাবে কাজ করার জন্য ব্যবহৃত হয়। JSON ডেটার ব্যবহার PostgreSQL তে ব্যাপক এবং সহজে সাপোর্ট করা হয়, বিশেষত যখন আপনাকে ওয়েব অ্যাপ্লিকেশন বা API

এর সাথে ইন্টিগ্রেশন করতে হয়।

Content added By

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...