ব্যাসিকস
এক্টো হলো এলিক্সিরের অফিশিয়াল ডাটাবেস র্যাপার এবং ইন্টিগ্রেটেড কুয়েরী ল্যাংগুয়েজ। এক্টো এর সাহায্যে আমরা মাইগ্রেশান তৈরি করা, স্কিমা তৈরি করা, রেকর্ড ইনসার্ট এবং আপডেট, এবং কুয়েরী করতে পারি।
এডাপ্টারস
এক্টো এডাপ্টারস এর সাহায্যে বিভিন্ন ডাটাবেস সাপোর্ট করে থাকে। নিম্নে কিছু এডাপ্টার উদাহরণস্বরূপ দেয়া হলোঃ
- পোস্টগ্রেএসকিউএল
- মাইএসকিউএল
- এসকিউলাইট
এই অধ্যায়ে আমরা,পোস্টগ্রেএসকিউএল এডাপ্টার ব্যবহারের জন্যে এক্টো কনফিগার করবো।
শুরু করা যাক
এই অধ্যায়ে, আমরা এক্টো এর তিনটি অংশ আলোচনা করবোঃ
- রিপোজিটোরী — ডাটাবেস এর কানেকশান ও ইন্টারফেস।
- মাইগ্রেশান — ডাটাবেস এর টেবিল এবং ইনডেক্স তৈরি, পরিবর্তন ও ধ্বংসের উপায়।
- স্কিমা — ডাটাবেস এর এন্ট্রিগুলোকে প্রকাশ করার স্পেশালাইজড স্ট্রাক্ট
শুরুতেই, আমরা একটা সুপারভিশন ট্রিসহ এপ্লিকেশান তৈরি করবো।
mix new friends --sup
cd friends
এবার, mix.exs ফাইলে এক্টো এবং পোস্টগ্রেক্স প্যাকেজ ডিপেন্ডেসীগুলো যোগ করবোঃ
defp deps do
[
{:ecto_sql, "~> 3.2"},
{:postgrex, "~> 0.15"}
]
end
ডিপেন্ডেন্সীগুলো ইন্সটল করবোঃ
mix deps.get
রিপোজিটরী তৈরি
এক্টো এর রিপোজটিরী বিভিন্ন ডাটাবেস এর সাথেই ম্যাপ করে থাকে, যেমন আমাদের পোস্টগ্রেস ডাটাবেস। রিপোজিটরী এর সাহায্যে সব ধরণের ডাটাবেস কমিউনিকেশান করা হবে।
রিপোজিটরী সেটআপ করতে রান করিঃ
mix ecto.gen.repo -r Friends.Repo
এই কমান্ডের মাধ্যমে, config/config.exs এ ডাটাবেস কানেক্ট করা ও কোন এডাপ্টার ব্যবহার করা হবে তা উল্লেখ করার কনফিগারেশান জেনারেট হবে।
Friends এপ্লিকেশান এর কনফিগারেশান ফাইলটি নিম্নরূপঃ
config :friends, Friends.Repo,
database: "friends_repo",
username: "postgres",
password: "",
hostname: "localhost"
লক্ষ্যণীয়, এক্টো কিভাবে ডাটাবেস এর সাথে কানেক্ট হবে তা এই কনফিগারেশানে উল্লেখ করা থাকে, তাই আপনাকে হয়তো আপনার ডাটাবেস এর ম্যাচিং ক্রিডেনশাল ব্যবহার করতে হতে পারে।
এটা Friends.Repo মডিউলও তৈরি করে lib/friends/repo.ex এর ভিতরে।
defmodule Friends.Repo do
use Ecto.Repo,
otp_app: :friends,
adapter: Ecto.Adapters.Postgres
end
আমরা Friends.Repo মডিউল ব্যবহার করে, ডাটাবেস এ কুয়েরী করবো। আমরা এই মডিউলকে কিভাবে :friends এলিক্সির এপ্লিকেশানে ডাটাবেস কনফিগারেশান ইনফোরমেশান পেতে হবে তাও উল্লেখ করে দিয়েছি এবং এ ছাড়াও আমরা Ecto.Adapters.Postgres এডাপ্টারটি পছন্দ করেছি।
পরবর্তীতে, আমরা Friends.Repo কে আমাদের এপ্লিকেশানের সুপারভিশান ট্রি lib/friends/application.ex তে সুপারভিসর হিসেবে সেটআপ করবো।
এর ফলে, যখন আমাদের এপ্লিকশান রান হবে তখন এটি এক্টো প্রসেসটিকেও চালু করবে।
def start(_type, _args) do
# List all child processes to be supervised
children = [
Friends.Repo,
]
...
এর পরে, আমাদেরকে config/config.exs ফাইলে নিচের লাইনটি যোগ করতে হবেঃ
config :friends, ecto_repos: [Friends.Repo]
এর ফলে, আমাদের এপ্লিকেশানটি এক্টো এর মিক্স কমান্ডগুলো কমান্ডলাইন থেকে রান করতে সক্ষম হবে।
এরই মাধ্যমে, আমাদের রিপজিটরী কনফিগারেশান শেষ হলো! এবার আমরা, পোস্টগ্রেসে আমাদের ডাটাবেসটি তৈরি করতে পারি নিচের কমান্ডের সাহায্যেঃ
mix ecto.create
এক্টো config/config.exs ফাইলের ইনফোরমেশান ব্যবহার করে জানতে পারবে কিভাবে পোস্টগ্রেস এর সাথে কানেক্ট হতে হবে, এবং ডাটাবেসকে কি নামে ডাকা হবে।
যদি আপনি কোনো এরর এর সম্মুখীন হন, তবে কনফিগারেশানের ইনফোরমেশান গুলো সঠিক কি না তা আরেকবার চেক করে দেখুন এবং আপনার পোস্টগ্রেস ইন্সট্যান্স রানিং আছে কি না তা ও দেখুন।
মাইগ্রেশান
পোস্টগ্রেস ডাটাবেসে টেবিল তৈরি ও পরিবর্তন করতে এক্টোর আছে মাইগ্রেশান। প্রতিটা মাইগ্রেশানে কিছু একশান উল্লেখ করা থাকে, যা আমাদের ডাটাবেসে সংঘটিত হবে, যেমন কোন টেবিল তৈরি বা আপডেট করা হবে।
যেহেতু, এখনো আমাদের ডাটাবেসে কোন টেবিল নাই, তাই আমাদের টেবিল তৈরি করতে কিছু মাইগ্রেশান লিখতে হবে।
এক্টোর রীতি হলো টেবিল নাম বহুবচনে লেখা, তাই আমাদের এপ্লিকেশানে আমাদের একটি people টেবিল তৈরি করা লাগবে, চলুন তবে এর মাধ্যমে মাইগ্রেশান তৈরি করা শুরু করা যাক।
মাইগ্রেশান তৈরির উত্তম পন্থা হলো মিক্সের ecto.gen.migration <name> টাস্ক ব্যবহার করা, আমাদের এ ক্ষেত্রে ব্যবহার করতে হবেঃ
mix ecto.gen.migration create_people
এর ফলে, priv/repo/migrations ফোল্ডারে টাইমস্ট্যাম্প আছে এমন নামের একটা নতুন ফাইল তৈরি হবে।
ঐ ফোল্ডারে গিয়ে আমরা যদি ফাইলটি ওপেন করি, তবে নিচের মতো কিছু দেখতে পাবোঃ
defmodule Friends.Repo.Migrations.CreatePeople do
use Ecto.Migration
def change do
end
end
শুরুতে, change/0 ফাংশনটি পরিবর্তন করে, আমরা name এবং age সম্বলিত একটা নতুন টেবিল people তৈরি করবোঃ
defmodule Friends.Repo.Migrations.CreatePeople do
use Ecto.Migration
def change do
create table(:people) do
add :name, :string, null: false
add :age, :integer, default: 0
end
end
end
উপরে দেখতে পাবেন, আমরা কলামগুলোর ডাটা টাইপও উল্লেখ করেছি।
এবং এছাড়াও আমরা null: false এবং default: 0 অপশন হিসেবে যুক্ত করেছি।
চলুন তবে, শেলে গিয়ে মাইগ্রেশান রান করা যাকঃ
mix ecto.migrate
স্কিমা
টেবিলতো তৈরি হলো এবার আমাদের এক্টোকে এর সম্পর্কে বিস্তারিত জানাতে হবে, স্কিমার মাধ্যমে আমরা এর কিছু অংশ করতে পারি। স্কিমা একটি মডিউল যেটা অন্তর্নিহিত ডাটাবেস টেবিলের ফিল্ডগুলোর ম্যাপিং বর্ণনা করে।
যদিও ডাটাবেস টেবিলের নামের জন্যে এক্টো বহুবচন পছন্দ করে, তবে স্কিমা সাধারণত একবচনের হয়ে থাকে, তাই আমরা আমাদের টেবিলের জন্যে যে স্কিমা তৈরি করবো তার নাম দিবো Person।
চলুন, lib/friends/person.ex এখানে, নতুন স্কিমাটি তৈরি করা যাকঃ
defmodule Friends.Person do
use Ecto.Schema
schema "people" do
field :name, :string
field :age, :integer, default: 0
end
end
আমরা দেখতে পাচ্ছি, Friends.Person মডিউল এক্টোকে বলে দিচ্ছে এই স্কিমাটি people টেবিল সম্পর্কিত এবং আমাদের দুটি কলাম আছেঃ name যেটা একটা স্ট্রিং এবং age, একটা ইন্টেজার যার ডিফল্ট ভ্যালু 0
চলুন তবে, নতুন একটা পার্সন তৈরি করে স্কিমা দেখা যাক, এর জন্যে iex -S mix ওপেন করিঃ
iex> %Friends.Person{}
%Friends.Person{age: 0, name: nil}
অনুমিত ভাবেই, একটি নতুন Person পেলাম যার age এ ডিফল্ট ভ্যালু এপ্লাই করা আছে।
এবার, “সত্যিকার” মানুষ তৈরি করা যাকঃ
iex> person = %Friends.Person{name: "Tom", age: 11}
%Friends.Person{age: 11, name: "Tom"}
যেহেতু, স্কিমাগুলো হলো স্ট্রাক্ট, তাই আমরা সাধারণত যেভাবে করি ঠিক একই উপায়ে ডাটাগুলোর সাথে ইন্টারেক্ট করতে পারিঃ
iex> person.name
"Tom"
iex> Map.get(person, :name)
"Tom"
iex> %{name: name} = person
%Friends.Person{age: 11, name: "Tom"}
iex> name
"Tom"
একই ভাবে, আমরা স্কিমাগুলোকে আপডেট ও করতে পারি, ঠিক যেভাবে আমরা এলিক্সিরে অন্যান্য ম্যাপ অথবা স্ট্রাক্ট এর ক্ষেত্রে করে থাকিঃ
iex> %{person | age: 18}
%Friends.Person{age: 18, name: "Tom"}
iex> Map.put(person, :name, "Jerry")
%Friends.Person{age: 18, name: "Jerry"}
পরবর্তী অধ্যায় চেইঞ্জসেট আলোচনা করা হবে, আমরা দেখবো কিভাবে আমরা ডাটা চেইঞ্জ গুলো নিরীক্ষা করতে পারি, এবং সবশেষে কিভাবে ডাটাবেসে সেগুলো রাখতে পারি।
Caught a mistake or want to contribute to the lesson? Edit this lesson on GitHub!