Sql server® 2012 t-sql fundamentals



Download 10,93 Mb.
Pdf ko'rish
bet66/443
Sana26.01.2022
Hajmi10,93 Mb.
#411755
1   ...   62   63   64   65   66   67   68   69   ...   443
Bog'liq
BookSQL

 

CHAPTER 1

 

Background to T-SQL Querying and Programming



 

 23

The following code defines a unique constraint on the ssn column in the Employees table.

ALTER TABLE dbo.Employees 

  ADD CONSTRAINT UNQ_Employees_ssn 

  UNIQUE(ssn);

As with a primary key constraint, SQL Server will create a unique index behind the scenes as the 

physical mechanism to enforce the logical unique constraint.

Foreign Key Constraints

A foreign key enforces referential integrity. This constraint is defined on one or more attributes in 

what’s called the referencing table and points to candidate key (primary key or unique constraint) 

attributes in what’s called the referenced table. Note that the referencing and referenced tables can 

be one and the same. The foreign key’s purpose is to restrict the values allowed in the foreign key 

columns to those that exist in the referenced columns.

The following code creates a table called Orders with a primary key defined on the orderid column.

IF OBJECT_ID('dbo.Orders', 'U') IS NOT NULL 

  DROP TABLE dbo.Orders; 

 

CREATE TABLE dbo.Orders 



  orderid   INT         NOT NULL, 

  empid     INT         NOT NULL, 

  custid    VARCHAR(10) NOT NULL, 

  orderts   DATETIME2   NOT NULL, 

  qty       INT         NOT NULL

  CONSTRAINT PK_Orders 

    PRIMARY KEY(orderid) 

);

Suppose you want to enforce an integrity rule that restricts the values supported by the empid col-



umn in the Orders table to the values that exist in the empid column in the Employees table. You can 

achieve this by defining a foreign key constraint on the empid column in the Orders table pointing to 

the empid column in the Employees table, like the following.

ALTER TABLE dbo.Orders 

  ADD CONSTRAINT FK_Orders_Employees 

  FOREIGN KEY(empid) 

  REFERENCES dbo.Employees(empid);

Similarly, if you want to restrict the values supported by the mgrid column in the Employees table 

to the values that exist in the empid column of the same table, you can do so by adding the following 

foreign key.

ALTER TABLE dbo.Employees 

  ADD CONSTRAINT FK_Employees_Employees 

  FOREIGN KEY(mgrid) 

  REFERENCES dbo.Employees(empid);

www.it-ebooks.info



24  

Microsoft SQL Server 2012 T-SQL Fundamentals

Note that NULL marks are allowed in the foreign key columns (mgrid in the last example) even if 

there are no NULL marks in the referenced candidate key columns.

The preceding two examples are basic definitions of foreign keys that enforce a referential action 

called no action. No action means that attempts to delete rows from the referenced table or update 

the referenced candidate key attributes will be rejected if related rows exist in the referencing table. 

For example, if you try to delete an employee row from the Employees table when there are related 

orders in the Orders table, the RDBMS will reject such an attempt and produce an error. 

You can define the foreign key with actions that will compensate for such attempts (to delete rows 

from the referenced table or update the referenced candidate key attributes when related rows exist 

in the referencing table). You can define the options ON DELETE and ON UPDATE with actions such 

as CASCADESET DEFAULT, and SET NULL as part of the foreign key definition. CASCADE means that 

the operation (delete or update) will be cascaded to related rows. For example, ON DELETE CASCADE 

means that when you delete a row from the referenced table, the RDBMS will delete the related rows 

from the referencing table. SET DEFAULT and SET NULL mean that the compensating action will set 

the foreign key attributes of the related rows to the column’s default value or NULL, respectively. Note 

that regardless of which action you chose, the referencing table will only have orphaned rows in the 

case of the exception with NULL marks that I mentioned earlier.


Download 10,93 Mb.

Do'stlaringiz bilan baham:
1   ...   62   63   64   65   66   67   68   69   ...   443




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©hozir.org 2025
ma'muriyatiga murojaat qiling

kiriting | ro'yxatdan o'tish
    Bosh sahifa
юртда тантана
Боғда битган
Бугун юртда
Эшитганлар жилманглар
Эшитмадим деманглар
битган бодомлар
Yangiariq tumani
qitish marakazi
Raqamli texnologiyalar
ilishida muhokamadan
tasdiqqa tavsiya
tavsiya etilgan
iqtisodiyot kafedrasi
steiermarkischen landesregierung
asarlaringizni yuboring
o'zingizning asarlaringizni
Iltimos faqat
faqat o'zingizning
steierm rkischen
landesregierung fachabteilung
rkischen landesregierung
hamshira loyihasi
loyihasi mavsum
faolyatining oqibatlari
asosiy adabiyotlar
fakulteti ahborot
ahborot havfsizligi
havfsizligi kafedrasi
fanidan bo’yicha
fakulteti iqtisodiyot
boshqaruv fakulteti
chiqarishda boshqaruv
ishlab chiqarishda
iqtisodiyot fakultet
multiservis tarmoqlari
fanidan asosiy
Uzbek fanidan
mavzulari potok
asosidagi multiservis
'aliyyil a'ziym
billahil 'aliyyil
illaa billahil
quvvata illaa
falah' deganida
Kompyuter savodxonligi
bo’yicha mustaqil
'alal falah'
Hayya 'alal
'alas soloh
Hayya 'alas
mavsum boyicha


yuklab olish