本文實例講述了Mysql數(shù)據(jù)庫中數(shù)據(jù)表的優(yōu)化、外鍵與三范式用法。分享給大家供大家參考,具體如下:
數(shù)據(jù)表優(yōu)化
將商品信息表進行優(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.將商品種類寫入商品種類表中:
注意:插入另一個表的查詢結果不需要加values
insert into goods_cates(name)
(select cate_name from goods group by cate_name);
3.將商品種類表更新到商品表中:
將商品表與種類表連接,用種類表id代替商品表種類內容
update (goods_cates inner join goods on goods_cates.name=goods.cate_name)
set goods.cate_name=goods_cates.id;
4.修改表結構:
將商品表商品種類名字段名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ù)據(jù)的錄入)
foreign key(字段名1) references 表名2(字段名2);
(也可在創(chuàng)建表時直接設置外鍵,前提是要連接的表存在)
2.外鍵的缺點:
雖然外鍵可以有效防止非法數(shù)據(jù)的錄入,但是會極大降低表的更新效率,所以實際開發(fā)中,一般不適用外鍵約束,可以再事務層面去判斷數(shù)據(jù)的合法性。
3.外鍵的刪除:
顯示創(chuàng)建表的語句
獲取外鍵名稱后刪除外鍵:
alter table goods drop foreign key goods_ibfk_1;
三范式
1.第一范式(1NF):強調列的原子性,即列不能再分成其他列。
2.第二范式(2NF):基于1NF,表必須有一個主鍵,非主鍵字段必須完全依賴與主鍵,而不是只依賴于主鍵的一部分。
3.第三范式(3NF):基于2NF,非主鍵列必須直接依賴于主鍵,不能存在傳遞依賴。
符合第三范式的數(shù)據(jù)庫,是比較合理的數(shù)據(jù)庫。
更多關于MySQL相關內容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL常用函數(shù)大匯總》、《MySQL日志操作技巧大全》、《MySQL事務操作技巧匯總》、《MySQL存儲過程技巧大全》及《MySQL數(shù)據(jù)庫鎖相關技巧匯總》
希望本文所述對大家MySQL數(shù)據(jù)庫計有所幫助。
您可能感興趣的文章:- MySQL索引知識的一些小妙招總結
- MySQL創(chuàng)建高性能索引的全步驟
- MySQL創(chuàng)建索引需要了解的
- MySQL 普通索引和唯一索引的區(qū)別詳解
- 淺談Mysql哪些字段適合建立索引
- Mysql刪除數(shù)據(jù)以及數(shù)據(jù)表的方法實例
- MySQL創(chuàng)建數(shù)據(jù)表時設定引擎MyISAM/InnoDB操作
- 刪除mysql數(shù)據(jù)表如何操作
- 關于MYSQL 你需要知道的數(shù)據(jù)類型和操作數(shù)據(jù)表
- MySQL創(chuàng)建數(shù)據(jù)表并建立主外鍵關系詳解
- MySQL數(shù)據(jù)表合并去重的簡單實現(xiàn)方法
- MySQL 索引和數(shù)據(jù)表該如何維護