Mysql數(shù)據(jù)庫中數(shù)據(jù)表的優(yōu)化、外鍵與三范式用法實(shí)例分析
本文實(shí)例講述了Mysql數(shù)據(jù)庫中數(shù)據(jù)表的優(yōu)化、外鍵與三范式用法。分享給大家供大家參考,具體如下:
數(shù)據(jù)表優(yōu)化
將商品信息表進(jìn)行優(yōu)化

1.創(chuàng)建商品種類表:
create table if not exists goods_cates( id int unsigned primary key auto_increment, name varchar(40) not null );
2.將商品種類寫入商品種類表中:
注意:插入另一個(gè)表的查詢結(jié)果不需要加values
insert into goods_cates(name) (select cate_name from goods group by cate_name);

3.將商品種類表更新到商品表中:
將商品表與種類表連接,用種類表id代替商品表種類內(nèi)容
update (goods_cates inner join goods on goods_cates.name=goods.cate_name) set goods.cate_name=goods_cates.id;
4.修改表結(jié)構(gòu):
將商品表商品種類名字段名cate_name重命名為cate_id
alter table goods change cate_name cate_id int unsigned not null;

外鍵
1.外鍵的使用:
添加外鍵約束,插入數(shù)據(jù)線判斷cate_id是否存在于goods_cates中的id,不存在,則插入數(shù)據(jù)失敗
alter table 表名1 add foreign key (字段名1) references 表名2(字段名2);
(設(shè)置外鍵后可以防止非法數(shù)據(jù)的錄入)

foreign key(字段名1) references 表名2(字段名2);
(也可在創(chuàng)建表時(shí)直接設(shè)置外鍵,前提是要連接的表存在)
2.外鍵的缺點(diǎn):
雖然外鍵可以有效防止非法數(shù)據(jù)的錄入,但是會(huì)極大降低表的更新效率,所以實(shí)際開發(fā)中,一般不適用外鍵約束,可以再事務(wù)層面去判斷數(shù)據(jù)的合法性。
3.外鍵的刪除:
顯示創(chuàng)建表的語句
show create table goods;

獲取外鍵名稱后刪除外鍵:
alter table goods drop foreign key goods_ibfk_1;
三范式
1.第一范式(1NF):強(qiáng)調(diào)列的原子性,即列不能再分成其他列。
2.第二范式(2NF):基于1NF,表必須有一個(gè)主鍵,非主鍵字段必須完全依賴與主鍵,而不是只依賴于主鍵的一部分。
3.第三范式(3NF):基于2NF,非主鍵列必須直接依賴于主鍵,不能存在傳遞依賴。
符合第三范式的數(shù)據(jù)庫,是比較合理的數(shù)據(jù)庫。
更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL常用函數(shù)大匯總》、《MySQL日志操作技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲(chǔ)過程技巧大全》及《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總》
希望本文所述對(duì)大家MySQL數(shù)據(jù)庫計(jì)有所幫助。
相關(guān)文章
mysql 5.7.17 安裝教程 附MySQL服務(wù)無法啟動(dòng)的解決方法
這篇文章主要為大家詳細(xì)介紹了mysql 5.7.17安裝教程,并且為大家分享了MySQL服務(wù)無法啟動(dòng)的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
MySQL因大事務(wù)導(dǎo)致的Insert慢實(shí)例分析
這篇文章主要給大家介紹了關(guān)于MySQL因大事務(wù)導(dǎo)致Insert慢的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-10-10
在MySQL中使用通配符時(shí)應(yīng)該注意的問題
這篇文章主要介紹了在MySQL中使用通配符時(shí)應(yīng)該注意的問題,主要是下劃線的使用容易引起的錯(cuò)誤,需要的朋友可以參考下2015-05-05
超越MySQL 對(duì)流行數(shù)據(jù)庫進(jìn)行分支的知識(shí)小結(jié)
盡管MySQL是最受歡迎的程序之一,但是許多開發(fā)人員認(rèn)為有必要將其拆分成其他項(xiàng)目,并且每個(gè)分支項(xiàng)目都有自己的專長。該需求,以及 Oracle 對(duì)核心產(chǎn)品增長緩慢的擔(dān)憂,導(dǎo)致出現(xiàn)了許多開發(fā)人員感興趣的子項(xiàng)目和分支2012-01-01
mysql too many open connections問題解決方法
這篇文章主要介紹了mysql too many open connections問題解決方法,其實(shí)是max_connections配置問題導(dǎo)致,它必須在[mysqld]下面才會(huì)生效,需要的朋友可以參考下2014-05-05
解決MySQL安裝重裝時(shí)出現(xiàn)could not start the service mysql error:0問題的方法
這篇文章主要為大家詳細(xì)介紹了解決MySQL安裝重裝時(shí)出現(xiàn)could not start the service mysql error:0問題的方法,感興趣的小伙伴們可以參考一下2016-06-06

