DB2 - बाधाओं
यह अध्याय डेटाबेस में विभिन्न बाधाओं का वर्णन करता है।
परिचय
डेटाबेस अखंडता को लागू करने के लिए, नियमों का एक सेट परिभाषित किया गया है, जिसे बाधा कहा जाता है। बाधाएं या तो कॉलम में मानों को अनुमति देती हैं या प्रतिबंधित करती हैं।
एक वास्तविक समय डेटाबेस गतिविधियों में, डेटा को कुछ प्रतिबंधों के साथ जोड़ा जाना चाहिए। उदाहरण के लिए, बिक्री डेटाबेस में, बिक्री-आईडी या लेनदेन-आईडी अद्वितीय होनी चाहिए। बाधा प्रकार हैं:
- शून्य नहीं
- Unique
- प्राथमिक कुंजी
- विदेशी कुंजी
- Check
- Informational
बाधाएं केवल तालिकाओं से जुड़ी हैं। वे केवल विशेष तालिकाओं पर लागू होते हैं। उन्हें टेबल निर्माण के समय तालिका में परिभाषित और लागू किया जाता है।
प्रत्येक बाधा की व्याख्या:
शून्य नहीं
यह तालिका के भीतर एक या अधिक स्तंभों से शून्य मानों को प्रतिबंधित करने का नियम है।
Syntax:
db2 create table <table_name>(col_name col_type not null,..)
Example: [बिक्री तालिका बनाने के लिए, चार कॉलम (आईडी, आइटम नाम, मात्रा, मूल्य) के साथ, इसमें सभी स्तंभों में "शून्य नहीं" बाधा डालते हुए तालिका में किसी भी अशक्त सेल के गठन से बचने के लिए।]
db2 create table shopper.sales(id bigint not null, itemname
varchar(40) not null, qty int not null,price double not null)
तालिका में पूर्ण मान शामिल नहीं है
आप नीचे दिखाए अनुसार तालिका में मान सम्मिलित कर सकते हैं:
Example: [त्रुटिपूर्ण प्रश्न]
db2 insert into shopper.sales(id,itemname,qty)
values(1,'raagi',12)
Output: [सही क्वेरी]
DB21034E The command was processed as an SQL statement because
it was not a
valid Command Line Processor command. During SQL processing
it returned:
SQL0407N Assignment of a NULL value to a NOT NULL column
"TBSPACEID=5,
TABLEID=4, COLNO=3" is not allowed. SQLSTATE=23502
Example: [सही क्वेरी]
db2 insert into shopper.sales(id,itemname,qty,price)
values(1,'raagi',12, 120.00)
db2 insert into shopper.sales(id,itemname,qty,price)
values(1,'raagi',12, 120.00)
Output:
DB20000I The SQL command completed successfully.
अनोखी अड़चनें
इन बाधाओं का उपयोग करके, आप विशिष्ट रूप से स्तंभों के मान सेट कर सकते हैं। इसके लिए, सारणी बनाते समय अद्वितीय अवरोधों को "शून्य नहीं" बाधा के साथ घोषित किया जाता है।
Syntax:
db2 create table <tab_name>(<col> <col_type> not null unique, ...)
Example:
db2 create table shopper.sales1(id bigint not null unique,
itemname varchar(40) not null, qty int not null,price
double not null)
मानों को तालिका में सम्मिलित करना
Example: अद्वितीय आईडी के साथ चार अलग-अलग पंक्तियों को सम्मिलित करने के लिए 1, 2, 3 और 4 के रूप में।
db2 insert into shopper.sales1(id, itemname, qty, price)
values(1, 'sweet', 100, 89)
db2 insert into shopper.sales1(id, itemname, qty, price)
values(2, 'choco', 50, 60)
db2 insert into shopper.sales1(id, itemname, qty, price)
values(3, 'butter', 30, 40)
db2 insert into shopper.sales1(id, itemname, qty, price)
values(4, 'milk', 1000, 12)
Example: "आईडी" मान 3 के साथ एक नई पंक्ति सम्मिलित करने के लिए
db2 insert into shopper.sales1(id, itemname, qty, price)
values(3, 'cheese', 60, 80)
Output: जब आप मौजूद आईडी मान के साथ एक नई पंक्ति सम्मिलित करने का प्रयास करते हैं तो यह इस परिणाम को दिखाएगा:
DB21034E The command was processed as an SQL statement
because it was not a
valid Command Line Processor command. During
SQL processing it returned:
SQL0803N One or more values in the INSERT statement,
UPDATE statement, or foreign key update caused by a
DELETE statement are not valid because the primary key,
unique constraint or unique index identified by "1" constrains
table "SHOPPER.SALES1" from having duplicate values for the
index key. SQLSTATE=23505
प्राथमिक कुंजी
अद्वितीय बाधाओं के समान, आप एक "प्राथमिक कुंजी" और कई तालिकाओं के बीच संबंधों को घोषित करने के लिए एक "विदेशी कुंजी" बाधा का उपयोग कर सकते हैं।
Syntax:
db2 create table <tab_name>(
,.., primary key ())
Example: एक प्राथमिक कुंजी के रूप में "साइड" के साथ 'सेल्सबॉय' टेबल बनाने के लिए
db2 create table shopper.salesboys(sid int not null, name
varchar(40) not null, salary double not null, constraint
pk_boy_id primary key (sid))
विदेशी कुंजी
एक विदेशी कुंजी एक तालिका में स्तंभों का एक सेट है जो किसी अन्य तालिका में पंक्ति की कम से कम एक प्राथमिक कुंजी से मेल खाने के लिए आवश्यक है। यह एक संदर्भित बाधा या संदर्भात्मक अखंडता बाधा है। यह एक या एक से अधिक तालिकाओं में कई स्तंभों में मानों के बारे में एक तार्किक नियम है। यह तालिकाओं के बीच आवश्यक संबंध को सक्षम बनाता है।
इससे पहले, आपने "shopper.salesboys" नाम की एक तालिका बनाई थी। इस तालिका के लिए, प्राथमिक कुंजी "साइड" है। अब आप एक नई तालिका बना रहे हैं जिसमें "स्कीम" और "सेल्सबॉय" नाम की तालिका के साथ अलग-अलग स्कीमा के साथ बिक्री लड़के के व्यक्तिगत विवरण हैं। इस मामले में, "साइड" विदेशी कुंजी है।
Syntax:
db2 create table <tab_name>(<col> <col_type>,constraint
<const_name> foreign key (<col_name>)
reference <ref_table> (<ref_col>)
Example: [विदेशी कुंजी स्तंभ 'साइड' के साथ 'सेल्सबॉय' नाम की एक तालिका बनाने के लिए]
db2 create table employee.salesboys(
sid int,
name varchar(30) not null,
phone int not null,
constraint fk_boy_id
foreign key (sid)
references shopper.salesboys (sid)
on delete restrict
)
Example[प्राथमिक कुंजी तालिका "shopper.salesboys" में मान सम्मिलित करना]
db2 insert into shopper.salesboys values(100,'raju',20000.00),
(101,'kiran',15000.00),
(102,'radha',10000.00),
(103,'wali',20000.00),
(104,'rayan',15000.00)
Example: [विदेशी कुंजी टेबल में मानों को सम्मिलित करें "कर्मचारी.स्लेबॉयस" [बिना त्रुटि के]]
db2 insert into employee.salesboys values(100,'raju',98998976),
(101,'kiran',98911176),
(102,'radha',943245176),
(103,'wali',89857330),
(104,'rayan',89851130)
यदि आपने एक अज्ञात संख्या दर्ज की है, जो "shopper.salesboys" तालिका में संग्रहीत नहीं है, तो यह आपको SQL त्रुटि दिखाएगा।
Example: [त्रुटि निष्पादन]
db2 insert into employee.salesboys values(105,'rayan',89851130)
Output:
DB21034E The command was processed as an SQL statement because it
was not a valid Command Line Processor command. During SQL
processing it returned: SQL0530N The insert or update value of
the FOREIGN KEY "EMPLOYEE.SALESBOYS.FK_BOY_ID" is not equal to any
value of the parent key of the parent table. SQLSTATE=23503
अड़चन की जाँच करना
आपको किसी तालिका में किसी विशिष्ट स्तंभ के लिए सशर्त प्रतिबंध जोड़ने के लिए इस बाधा का उपयोग करने की आवश्यकता है।
Syntax:
db2 create table
(
primary key (
), constraint
check (condition or condition) )
Example: [To create emp1 table with constraints values]
db2 create table empl
(id smallint not null,
name varchar(9),
dept smallint check (dept between 10 and 100),
job char(5) check (job in ('sales', 'mgr', 'clerk')),
hiredate date,
salary decimal(7,2),
comm decimal(7,2),
primary key (id),
constraint yearsal check (year(hiredate) > 1986 or salary > 40500)
)
Inserting values
You can insert values into a table as shown below:
db2 insert into empl values (1,'lee', 15, 'mgr', '1985-01-01' ,
40000.00, 1000.00)
Dropping the constraint
Let us see the syntaxes for dropping various constraints.
Dropping UNIQUE constraint
Syntax:
db2 alter table <tab_name> drop unique <const_name>
Dropping primary key
Syntax:
db2 alter table <tab_name> drop primary key
Dropping check constraint
Syntax:
db2 alter table <tab_name> drop check <check_const_name>
Dropping foreign key
Syntax:
db2 alter table <tab_name> drop foreigh key <foreign_key_name>