Ⅰ 在軟體項目建設中,如何保證資料庫完整性
1 伺服器端利用sql Server 7.0資料庫實現數據的完整性
在用INSERT、DELETE、UPDATE語句修改資料庫內容時,數據的完整性可能遭到破壞,為了保證存放數據的正確性和一致性,SQL Server對數據施加了一個或多個數據完整性約束。這些約束限制了對資料庫的數據值,或者限制了資料庫修改所產生的數據值,或限制了對資料庫中某些值的修改。
在SQL Server關系資料庫中,主要有以下3類數據完整性:實體完整性(保證表中所有行唯一);參照完整性(主健和外健關系維護,它涉及兩個或兩個以上的表的數據的一致性維護);域完整性(某列有效性的集合,是對業務管理或是對資料庫數據的限制)。在報務器端有兩種方法實現數據完整性:定義reat Table 完整性約束及定義規則、預設、索引和觸發器。
1.1 定義 reatetable 完整性約束
此方法是在創建資料庫表的命令語句中,加入表級約束或列級來實現數據完整性。如在建表語句中加入非空(nt null)約束、預設(default)約束、唯一碼(unique)約束、主鍵碼(priary key)約束、外鍵碼(frEign key)約束、校驗(hek)約束等。它的主要特點是:定義簡單、安全可靠、維護方便。
1.1.1 非空約束、預設約束和校驗約束
非空約束限定了列值不能為空值;預設約束指定當向資料庫插入數據時,若用戶沒有明確給出某列的值時,SQL Server 自動輸入預定值;校驗約束則用來限定列的值域范圍。
例如,在創建圖書登記表中,限定登記日期、圖書類別編碼、登記號、中文名等列值不允許為空值;頁數的預設值為1;單價的預設值為0;圖書狀態只能為:「在館」、「借出」、「丟失」之一。
1.1.2 主鍵約束和唯一約束
主鍵約束和唯一約束,均為指定的列建立唯一性索引,即不允許唯一索引的列上有相同的值。主鍵約束更嚴格,不但不允許有重復值,而且也不允許有空值。
例如,在科室編碼表,對列ksb創建主鍵約束,對ks創建唯一約束。
1.1.3 外鍵約束
外鍵約束又稱參照完整性約束,用來限定本表外鍵碼列值與相關表主鍵碼欄位列值的匹配,即保證相關數據的一致性。
例如,在創建醫師編碼表中,醫生所屬科室 ssks 為外鍵碼,限定它與科室編碼表中的科室編碼 ksb 列值一致。
1.2 定義規則、預設、索引和觸發器
在資料庫表的創建命令語句中定義約束的方法,雖然具有簡單、方便、安全等特點,但它只對特定的表有效,不能應用到其他表,並且只能使用 alter table 命令修改或刪除約束,缺乏一定的靈活性。與此相反,在資料庫中創建與表相對獨立的規則、索引和觸發器對象,也能實現數據完整性,而且能實施更復雜、更完善的數據完整性約束。它的主要特點是功能強、效率高、維護方便。
1.2.1 定義規則
規則類似於表定義中的校驗約束,用來限定列的值域范圍。但它不限定於特定表,可以綁定到其他表的列或用戶自定義的數據類型中使用。
例如,在定義葯品的編碼規則Rul-ypb,可綁定到其他表中。
Ⅱ SQL語言如何實現數據的完整性
1.首先要明白數據的完整性有哪些:域完整性/列完整性,實體完整性/行完整性,參照完整性/引用完整性;
2.怎樣實現:
域完整性:(1)定義列時,使用check約束;
(2)定義規則;
實體完整性:(3)利用primary key
參照完整性:(4) 利用foreign key references
Ⅲ 簡述SQL Server系統中提供了哪幾大類完整性約束來實現關系資料庫的完整性約束
1、實體完整性:主鍵值必須非空且唯一;
2、參照完整性:外鍵的值必須為空或者其他關系(即主表)的主鍵值;
3、域完整性約束:屬性值應該是域中的值以及一個屬性能否為空(NULL);
4、
Ⅳ SQL數據完整性指的什麼
數據完整性是指數據的精確性
和可靠性。它是應防止資料庫中存在不符合語義規定的數據和防止因錯誤信息的輸入輸出造成無效操作或錯誤信息而提出的。數據完整性分為四類:實體完整性、域完整性、參照完整性、用戶定義的完整性。
Ⅳ 資料庫用SQL語言建表,什麼是完整性約束請問如何寫出各種完整性約束
一、數據的完整性
實體完整性
實體完整性簡單的說,就是將表中的每一行看作一個實體。實體完整性要求表的標示符列或主鍵的完整性。可以通過建立唯一索引、PRIMARY KEY約束、UNIQUE約束,以及列的IDENTITY屬性來實施實體完整性。
域完整性
域完整性是指給定列的輸入有效性。要求表中指定列的數據具有正確的數據類型、格式和有效的數據范圍。強制域有效性的方法有:限制類型(通過數據類型)、格式(通過 CHECK 約束和規則)或可能值的范圍。域完整性通過 FOREIGN KEY 約束、CHECK 約束、DEFAULT 定義、NOT NULL 定義和規則來實現。
引用完整性
引用完整性又稱參照完整性。引用完整性維持被參照表和參照表之間的數據一致性,他通過主鍵(PRIMARY KEY)約束和外鍵(FOREIGN KEY)約束來實現。
用戶定義完整性
二、約束操作
與表相關的約束
在SQL 2008中,常用有6種約束,分別是NOT NULL,UNIQUE,PRIMARY KEY,FOREIGN KEY,DEFAULT和CHECK.
--添加主鍵約束(即primary key約束)
alter table goods add constraint pk_gid primary key(gid)
--1.刪除主鍵約束
alter table goods drop pk_gid
--添加唯一約束(即unique約束)
alter table goods add constraint uq_gname unique(gname)
--刪除唯一約束:仿1.
--添加預設約束(即default約束)
alter table goods add constraint def_gtel default 0000-00000000 for gtel
--刪除預設約束:仿1.
--添加檢查約束(即check約束)
alter table goods add constraint ck_gprice check(gprice>500)
--刪除check約束:仿1.
--創建表2
create table g_p
(
wno int identity(1,1) primary key,
gno int
)
--添加外鍵約束(即foreign key約束)
alter table g_p
add constraint fk_gno
foreign key(gno) references goods(gid)
--刪除外鍵約束:仿1.
--使用newid()
select newid()--生成全球唯一的ID號
create table customer
(
custID uniqueidentifier not null default newid(),
customer char(30) not null
)
insert customer values(newid(),\''\''accp\''\'')--向customer中插入信息
-----------------------------------慢慢研究----
Ⅵ sql server 的數據完整性指的是的什麼
主要是第二段:
數據完整性(Data
Integrity)是指數據的精確性(Accuracy)
和可靠性(Reliability)。它是應防止資料庫中存在不符合語義規定的數據和防止因錯誤信息的輸入輸出造成無效操作或錯誤信息而提出的。數據完整性分為四類:實體完整性(Entity
Integrity)、域完整性(Domain
Integrity)、參照完整性(Referential
Integrity)、用戶定義的完整性(User-definedIntegrity)。
資料庫採用多種方法來保證數據完整性,包括外鍵、約束、規則和觸發器。系統很好地處理了這四者的關系,並針對不同的具體情況用不同的方法進行,相互交叉使用,相補缺點。
Ⅶ 資料庫完整性的定義一般由SQL的()語句來實現。 是DDL還是DML
此題答案為DDL。
資料庫模式定義語言DDL(Data
Definition
Language),是用於描述資料庫中要存儲的現實世界實體的語言。一個資料庫模式包含該資料庫中所有實體的描述定義。這些定義包括結構定義、操作方法定義等。
DML
=
Data
Manipulation
Language,數據操縱語言,命令使用戶能夠查詢資料庫以及操作已有資料庫中的數據的計算機語言。具體是指是UPDATE更新、INSERT插入、DELETE刪除。
DML(Data
Manipulation
Language)數據操縱語言,SQL的分類之一,此外還有DDL(Data
Definition
Language)數據定義語言和DCL(Data
Control
Language)數據控制語言。DML包括:INSERT、UPDATE、DELETE。注意,select語句屬於DQL(Data
Query
Language)。1