這篇文章主要介紹了MySQL數(shù)據(jù)庫中數(shù)據(jù)約束的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
公司專注于為企業(yè)提供成都網(wǎng)站建設、網(wǎng)站設計、微信公眾號開發(fā)、成都做商城網(wǎng)站,小程序制作,軟件按需網(wǎng)站策劃等一站式互聯(lián)網(wǎng)企業(yè)服務。憑借多年豐富的經(jīng)驗,我們會仔細了解各客戶的需求而做出多方面的分析、設計、整合,為客戶設計出具風格及創(chuàng)意性的商業(yè)解決方案,創(chuàng)新互聯(lián)更提供一系列網(wǎng)站制作和網(wǎng)站推廣的服務。為了防止不符合規(guī)范的數(shù)據(jù)進入數(shù)據(jù)庫,在用戶對數(shù)據(jù)進行插入、修改、刪除等操作時,DBMS自動按照一定的約束條件對數(shù)據(jù)進行監(jiān)測,使不符合規(guī)范的數(shù)據(jù)不能進入數(shù)據(jù)庫,以確保數(shù)據(jù)庫中存儲的數(shù)據(jù)正確、有效、相容。
#數(shù)據(jù)約束
#五種完整性約束: #NOT NULL :非空約束,指定某列不能為空; #UNIQUE : 唯一約束,指定某列或者幾列組合不能重復 #PRIMARY KEY :主鍵,指定該列的值可以唯一地標識該列記錄 #FOREIGN KEY :外鍵,指定該行記錄從屬于主表中的一條記錄,主要用于參照完整性 #CHECK :檢查,指定一個布爾表達式,用于指定對應的值必須滿足該表達式(mysql不支持check約束) #--------------------------------NOT NULL 非空約束 --------------------------- create table test4 ( #建立非空約束 id int not null, name varchar(55) default 'ABCD' not null, #默認值就是null age int null ); #取消非空約束 alter table test4 modify name varchar(55) default 'ABCD' not null, #增加非空約束 alter table test4 modify age int not null; #--------------------------------UNIQUE : 唯一約束-------------------------------- #列級約束語法建立約束 create table test_unique ( #建立行級唯一約束 id int not null unique, age int ); #表級約束語法格式 create table unique_test3 ( test6_id int not null, test6_name varchar(255), test6_pass varchar(255), #使用表級約束語法建立唯一約束,指定test6_id和test6_name兩列組合不能重復 constraint test6_unique unique(test6_id,test6_name), #使用表級約束語法建立唯一約束,約束名為test6_unique_2,test6_pass不能重復 constraint test6_unique_2 unique(test6_pass) ); #add關鍵字增加唯一約束 alter table test4 add unique(id,name,age); #modify關鍵字刪除或者增加唯一約束 alter table test4 modify age varchar(255) not null; alter table test4 modify age varchar(255) not null unique; #對大部分數(shù)據(jù)庫而言,刪除約束使用: alter table 表名 drop constraint 約束名 #但是Mysql不采取此方式,而是: alter table 表名 drop index 約束名 #--------------------------------PRIMARY KEY : 主鍵約束-------------------------------- #主鍵約束相當于非空約束和唯一約束。 #每個表只允許擁有一個主鍵,但是這個主鍵可以由多個數(shù)據(jù)列組成,這些列組合不能重復 #標準SQL允許給主鍵自行命名,但是對于Mysql來說自己的名字沒有任何作用,總是默認名為PRIMARY create table primary_test ( #使用列級語法建立主鍵約束 test_id int primary key, test_name varchar(255) ); #使用表級語法建立主鍵約束 create table primary_test2 ( test_id int not null, test_name varchar(255), test_pass varchar(255), #指定主鍵約束名為test2_pk,對大部分數(shù)據(jù)庫有效,但是對mysql無效,此主鍵約束名仍為PRIMARY constraint test2_pk primary key (test_id) ); #以多列組合創(chuàng)立主鍵 create table primary_test3 ( test_id int, test_name varchar(255), primary key(test_id,test_name) ); #使用列級約束語法 alter table primary_test3 modify test_id int primary key(); #使用表級約束語法 alter table primary_test3 add primary key(test_id,test_name); #刪除主鍵約束:alter table 表名 drop primary key; #主鍵列自增長特性:如果某個數(shù)據(jù)列的類型是整型,而且該列作為主鍵列,則可指定該列具有自增長功能 #mysql使用auto_increment來設置自增長,向該表插入記錄時可不為該列指定值,由系統(tǒng)生成 create table primary_test3 ( //建立主鍵約束、設置自增長 test_id int auto_increment primary key, test_name varchar(255) ); #外鍵約束 FOREIGN KEY #Mysql中只有表級語法建立的外鍵約束才可以生效 #為保證參照主表的存在,先建立主表 create table teacher_tb ( t_id int auto_increment, t_name varchar(255), primary key(t_id) ); create table student_tb ( s_id int auto_increment primary key, s_name varchar(255) not null, t_java int, foreign key(t_java) references teacher_tb(t_id) ); #如果使用表級約束語法,則需要使用foreign key指定本表的外鍵列,如果創(chuàng)建外鍵約束時沒有指定約束名, #則mysql會為該外鍵約束命名為table_name_ibfk_n,其中table_name是從表的表名,n是從1開始的整數(shù) create table teacher_tb2 ( t_id int auto_increment, t_name varchar(255), primary key(t_id) ); create table student_tb2 ( s_id int auto_increment primary key, s_name varchar(255) not null, t_java int, constraint student_teacher_fk foreign key(t_java) references teacher_tb2(t_id) ); #建立多列組合外鍵約束 create table teacher_tb5 ( t_name varchar(255), t_pass varchar(255), primary key(t_name,t_pass) ); create table student_tb5 ( s_id int auto_increment primary key, s_name varchar(255) not null, t_java_pass varchar(255), t_java_name varchar(255), foreign key(t_java_name,t_java_pass) references teacher_tb5(t_name,t_pass) ); #刪除外鍵約束 alter table student_tb2 drop foreign key student_teacher_fk; #增加外鍵約束 alter table student_tb2 add foreign key(t_java) references teacher_tb2(t_id); #外鍵約束參照自身,自約束 create table foreign_test9 ( foreign_id int auto_increment primary key, foreign_name varchar(255), refer_id int, foreign key(refer_id) references foreign_test9(foreign_id) ); #定義當刪除主表記錄時,從表記錄也隨之刪除 #on delete cascade 把參照該主表記錄的從表記錄全部級聯(lián)刪除 #on delete set null 把參照該主表記錄的從表記錄從表設為null e create table teacher_tb8 ( t_id int auto_increment, t_name varchar(255), primary key(t_id) ); create table student_tb8 ( s_id int auto_increment primary key, s_name varchar(255) not null, t_java int, constraint student_teacher_fk foreign key(t_java) references teacher_tb8(t_id) on delete cascade );
感謝你能夠認真閱讀完這篇文章,希望小編分享的“MySQL數(shù)據(jù)庫中數(shù)據(jù)約束的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關知識等著你來學習!
當前標題:MySQL數(shù)據(jù)庫中數(shù)據(jù)約束的示例分析-創(chuàng)新互聯(lián)
新聞來源:http://bm7419.com/article44/ijphe.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供自適應網(wǎng)站、全網(wǎng)營銷推廣、品牌網(wǎng)站設計、關鍵詞優(yōu)化、外貿(mào)建站、營銷型網(wǎng)站建設
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容