Skip to main content

Command Palette

Search for a command to run...

ক্লাস নং-৮,ক্লাসের বিষয়-ডেটাবেজ রিলেশন,লারাভেল ফ্যাক্টরি,ডেটাবেজ সিডিং।

Updated
5 min read
ক্লাস নং-৮,ক্লাসের বিষয়-ডেটাবেজ রিলেশন,লারাভেল ফ্যাক্টরি,ডেটাবেজ সিডিং।
R

Hi there, I am rakibul islam you can call me rakib, i have completed my graduation from chongqing university of technology,chongqing china department of cse & i really love to write blog & share

অবশ্যই আজকের টপিক টা অনেক গুরুত্বপূর্ন একটা টপিক,এবং সেই সাথে বুঝতেো বেশ সময় লাগতে পারে আজকের ক্লাস টা।কারন আস্তে,ক্লাস গুলো একটু ইন্টারমিডিয়েট লেভেল এর দিকে যাচ্ছে।

\==>ডেটাবেইজ এর ও language আছে ।

\=>sql(Structure Query Language )->আমরা যেটা ব্যাবহার করব।

এটা আবার ৪ ধরনের কুয়েরি হয়।

\=>TCL (Transaction Control Language)

\=>DML (Data Manipulation Language)

\=>DCL (Data Control Language)

\=>DDL (Data Definition Language)

DATABASE এর MIGRATION আমরা DDL এর যে কমান্ড গুলো চালায় সেগুলো হলোঃ

  • CREATE DDL Command

  • ALTER DDL Command

  • DROP DDL Command

  • TRUNCATE DDL Command

  • RENAME DDL Command

DATABASE এর MIGRATION আমরা DML এর যে কমান্ড গুলো চালায় সেগুলো হলোঃ

  • SELECT DML Command

  • INSERT DML Command

  • UPDATE DML Command

  • DELETE DML Command

এবং আর যে দুই টাইপ কুয়েরি আছে সেগুলো একটু কম ই ব্যাবহত হয়ে থাকে।

\=>DCL =>মূলত বিভিন্ন পারমিশন এর ক্ষেত্রে ব্যাবহত হয়।কন্ট্রোল টাইপ।

  • Grant DCL Command

  • Revoke DCL Command

\=>TCL

  • Commit TCL Command

  • Rollback TCL Command

ডেটাবেজ এর ক্ষেত্রে স্কিমা অনেক গুরুত্বপূর্ন ।স্কিমা বলতে সাধারনত বোঝায় কিভাবে ডেটাবেজ এর বিভিন্ন ফিল্ড এবং ডেটাবেজ এর টেবিল গুলো সাজানো আছে।

ডেটাবেজ মাইগ্রেশন এর ডিফল্ট যে ফিল্ড গুলো থাকে।

$table->timestamp();

এটা মূলত ব্যাবহত হয় সময় এর জন্য কোন সময় অপারেশন টা হয়েছে।created_at,updated_at.

এবার আশা যাক বেশ কিছু ডেটাটাইপ এ যেগুলো আমরা ব্যাবহার করে থাকি ডেটাবেজ মাইগ্রেশন এর ক্ষেত্রে।এবং বিভিন্ন programming language এ।

\=>STRING

সাধারনত ছোটখাট কেইস গুলোতে STRING DATATYPE ব্যাবহার করা হয়।যেমন অল্প কিছূ লেটার লেখা লাগবে।

যেমনঃ-"আমার নাম রাকিব"

\=>INTEGER

পুর্ন সংখার ডেটা টাইপ হলো integer.

যেমনঃ-1,2,3,4,5

\=>FLOAT

ভগ্নাংশ সংখা গুলোর ক্ষেত্রে float type

যেমনঃ- ২.৩,৫.৪।

\=>VARCHAR

এই ডেটা টাইপ টাও নামের ক্ষেত্রে বেশ ব্যাবহার করা হয়ে থাকে।

\=>char

\=>text

\=>LONGTEXT

etc

এই প্রত্যেক টা ডেটা টাইপ এর আবার লিমিট আছে যে কত সংখা,কত ক্যারাক্টার ব্যাবহার করবে।

CHAR(২৫৫)

VARCHAR( ২৫৫)

TEXT(65,535 bytes)

LONGTEXT(4,294,967,295 characters)

এখানে একটা প্রশ্ন থাকে যে ,string,char,varchar,text,longtext, সব ই তো string এর মত কাজ করে তাহলে কেন আমরা শুধু string,varchar,char

ব্যাবহার করে থাকি।

উত্তরঃ-আমরা বিভিন্ন ডেটা টাইপ এর সাইজ দেখেই বুঝে গেছি হয়ত।কারন আমরা স্ট্রিং ব্যাবহার করে থাকি অল্প কিছু ক্যারাক্টার আমাদের নামের ক্ষেত্রে ব্যাবহার করা হয়।

এক্ষেত্রে আমাদের মেমোরি অল্প লাগতেছে কিন্তু অন্যান্য ডেটা টাইপ গুলোর সাইজ বেশ বড় ।application এর সাইজ পরবর্তিতে বড় হয়ে যাবে এবং performance কম হবে।যার কারনে

string,char,varchar ব্যাবহার করা হয়।

\==>হারুন ভাই আরেকটা কথা বলেছেন যে indexing করতে গেলে,Text,longtext এ অনেক ঝামেলা পোহাতে হয়।যার কারনে string,char,varchar ব্যাবহার করা হয়।

database migration এ দুইটা ফাংশন কাজ করে ।

১।

public function up(){

//এখানে আমরা আমাদের ডেটাবেজ এর বিভিন্ন কলাম তৈরি করি।

}

২।

public function down(){

//এখানে আমরা আমাদের ডেটাবেজ এর বিভিন্ন কলাম প্রয়োজন অনুসারে ডিলিট করি/ড্রপ করি।

}

down function এ দারুন একটা কেইস আছে সেটা হল আপনি যদি আপনার কোন কলাম ড্রপ করেন পরবর্তিতে ।আবার যদি রান করেন migration তাহলে তখন আপনার up function

run হবে কিন্তু ডাউন ফাংশন রান হবে না। আবার যদি migrate করেন তখন আবার down function run হবে।

এক্ষেত্রে আপনার কমান্ড হবে।

\==>php artisan migrate:rollback

এটাকে ডেটাবেজ এর রোলব্যাক বা ভার্সনিং ও বলে।

DATABASE RELATION:

\==================

অনেক গুরুত্বপূর্ন এবং অনেক কনফিউশন একটা টপিক হলো এই ডেটাবেজ রিলেশন।বেশ কয়েকধরনের রিলেশন রয়েছে ডেটাবেজ এ এর মধ্যে সাধারন অবস্থায় কিছু রিলেশন কমন ভাবে ব্যাবহার হয়ে থাকে।

  • \==>One to One relation

  • \==>One to Many relation

  • \==>Many to one relation

  • \==>Many to many relation

\==>ONE TO ONE RELATION

টাইটেল দেখেই হয়ত বুঝতে পারছি এটা একটা টেবিলের সাথে আরেকটা টেবিলের one to one relation হচ্ছে।

রিলেশন এর ক্ষেত্রে বেশ কয়েকটা জিনিষ গুরুত্বপূর্ন।

\==>FOREIGNKEY -->নাম দেখে হয়ত আন্দাজ করতে পারছেন।এটা অন্য টেবিলের ইউনিক একটা কি হতে হবে।(অবশ্যই ইউনিক হতে হবে)

\==>ম্যানুয়ালি করতে গেলে আপনার রেফারেন্স লাগবে ।

\==>ONE TO MANY RELATION

এক্ষেত্রে আমরা বুঝতে পারছি একটা স্যারের সাথে একাধিক ছাত্রের রিলেশন।

database বেশ কয়েকধরনের অপশন আছে one to many relation এর তবে।

আপনি খুব সহজেই foreignkey দিয়ে column_name দিলে constraint এর মাধ্যমে আপনি তৈরি করে ফেলতে পারবেন।অবশ্য এক্ষত্রে Constraint ই রিলেশন তৈরি করে নেই।

public funtion orders(){

return $this->hasmany('orders','user_id');

}

এখানে ইউজার টেবিলের সাথে order table এর একটি one to many relation হচ্ছে।

\==>MANY TO MANY RELATION

বেশ complex একটা টার্ম কারন এখানে দুই সাইড থেকে এক জনের সাথে একাধিক জনের সম্পর্ক হয়ে থাকে।এবং এর মধ্যে একটা পিভট কাজ করে।

relation এর ক্ষেত্রে একটা জিনিষ মনে রাখতে হবে up & down function এর ক্ষেত্রে।

আমরা যখন কোন টেবিল drop করতে যাব সেক্ষেত্রে একটা বিষয় আমাদের মনে রাখতে হবে।আমরা কোন কলাম টি ডিলেট করব এবং কোন কলাম টি কোন টার ওপর ডিপেন্ডেন্ড।

যেটার ওপরে depended সেটা পরে ডিলেট করতে হবে।

যেটা অন্য একটা কলামের ওপরে ডিপেন্ড করে সেটি আগে ডিলেট করতে হবে।

RELATION

\========

many to many relation এর ক্ষেত্রে দুইটাই হবে belongstomany

খুব সহজেই রিলেশন তৈরি করতে পারি মডেল এর নাম ব্যাবহার করে।

//model role

public function users(){

return $this->belongstoMany(User::class);

}

//model users

public function roles(){

return $this->belongstoMany(Role::class);

}

USER এর মধ্যে ROLE && ROLE এর মধ্যে USERS

FACTORY

\=========

নাম দেখে হয়ত বুঝতে পারছেন এটার কাজ। এখানে মূলত আমাদের কর্ম জীবনের ফ্যাক্টরির মতোই পন্য উৎপন্ন হয় তবে সেটা নির্দিষ্ট কিছু ফেইক কলামে ফেইক ডেটা।

।একটি সুন্দর website কাঠামো দেখার জন্য website এ অবশ্যই content এর প্রয়োজন হয় কিন্ত develop করার সময় main content গুলো না দেওয়ার কারনে ।লারাভেল এর

এই factory থেকে ডামি ডেটা আমরা ব্যাবহার করে থাকি খুব অল্প সময়েই আমাদের প্রয়োজন অনুসারে ডেটা ব্যাবহার করতে পারি।

SEEDER

\=========

বীজ বপ্ন।আমরা যখন ফ্যাক্টরি তে ডেটা তৈরি করি সেই ডেটা গুলো প্রয়োজন অনুসারে বিভিন্ন টেবিলে,কলামে দেওয়া লাগে তাই এই সিডারের প্রয়োজন হয়ে থাকে।আমাদের সীডার ফাইলের ফাংশনের মধ্যে

আমরা আমাদের প্রয়োজুন অনুসারে ডেটাবেজ টেবিলের কলাম অনুসারে ডেটা জেনারেট করতে পারি।

public function definition(){

returnp[

'name'=>fake()->name(),

'email'=>fake()->eemail()

];

}

এক্ষত্রে কমান্ড টি হলোঃ

php artisan migrate:fresh --seed

এখানে migration ও করা হল আবার সীডার ও করা হলো;

এটি ক্লাসের ওভারভিউ এর সাথে কিছু বিষয় add করেছি।আশা করি সবাই বুঝতে পারবেন।

আপনারা আরো বেশি ভাল করে জানতে চাইলে প্রত্যেক টা টপিক কপি করে গুগলে সার্চ করবেন এবং সেই নির্দিষ্ট টপিক ভাল ভাবে পড়বেন আশা করি আরো অনেক কিছু জানতে পারবেন।

ধন্যবাদ।

___RAKIBUL ISLAM___

R

its a gd blog for all..thanks..

1
R

thank you

M

Outstanding brother, I am impressed, saw your writing skill or another skill, This blog helps new developments and so we are benefited read this blog

1
R

thank you

More from this blog

We discuss basic routing

বেসিক রাউটিং সফটওয়্যার আর্কিটেকচারে রাউট হচ্ছে মৌলিক উপাদান(Basic Component). রাউট URL(URL = Uniform Resource Locator) থেকে অনুরোধ গ্রহণ করে এবং এপ্লিকেশনকে রিসোর্সের জন্য নির্দেশনা প্রদান করে। লারাভেলের রাউট সমূহ একই সাথে সুবিন্যস্ত করে রাখার জন্য r...

Jun 1, 20233 min read

Visual Studio Code এডিটর কি-বোর্ড শর্টকার্ট

এখন কোডিংয়ের স্পীড হবে রকেটের গতি যদি আপনি ব্লগটি পড়েন এবং শর্টকাট ব্যবহার করেন তাহলে চলুন শুরু করি। Visual Studio Code এডিটর কি-বোর্ড শর্টকার্টঃ MAC ও WINDOWS এর জন্য আলাদা কি-বোর্ড শর্টকাট নিচে দেওয়া হল- Visual Studio Code এর কমান্ড পেলেট কিভাবে ওপ...

Jun 1, 20233 min read
Visual Studio Code এডিটর কি-বোর্ড শর্টকার্ট

WordPress Support Engineer Input Field And Form

আজকে আমরা আলোচনা করব আমাদের WordPress Support Engineer Course এর ক্লাস ২ নিয়ে এবং আমাদের টপিক হলো html input fields. ইনপুট ফিল্ডে বিভিন্ন রকম টাইপ রয়েছে এর মধ্যে default html,html-5,iput type="text" ইত্যাদি। তো চলুন শুরু করি ।প্রথমেই আমরা আলোচনা করব ...

May 7, 20233 min read

Tailwind Css CLI ব্যাক্ষ্যা সহ Install প্রসেস

সবার প্রথমে আমাদের একটা Directory বানাতে হবে। আপনার Project এর নাম দিয়ে একটি Directory বানিয়ে ফেলুন। এরপর যেকোনো একটা Terminal ব্যবহার করে এই Directory তে ঢুকুন। npm install -D tailwindcss autoprefixer vite এই কমান্ড Terminal-এ দিবো। এক্সট্রা হিসেবে...

Apr 3, 20232 min read
Tailwind Css CLI ব্যাক্ষ্যা সহ Install প্রসেস
S

Shikhun Blog

96 posts