一、MySQL鍵值(限制如何給字段賦值)
1)
索引:相似與「書的目錄」樹型目錄
缺點:減慢寫的速度(insert update delete)
佔用物理存儲空間
優勢:加快查詢速度
2)
使用索引
使用規則
一個表中能夠由多個index字段
字段的值容許由重複,切能夠賦NULL
常常把作查詢條件的字段設置爲index字段
index字段的key標誌是MULmysql
查看索引
desc 表名;sql
show index for 表名;
#查看索引詳細信息數據庫
建立索引
create table 表名(
字段 類型,
index(索引名);
#建表時建立索引
#默認和字段名同名緩存
-> create table t21(
-> name char(10),
-> age int,
-> sex enum('boy','girl'),
-> index(name),
-> index(sex));ide
#####################################################################
create index 索引名 on 表名(字段);
#已有表建立索引
#索引名能夠和字段名相同
#默認使用的索引類型:BRREE(二叉樹)工具
create index name on t3(name)優化
drop index 索引名 on 表名;
#刪除索引 日誌
###################################################################
主鍵 parimary key索引
使用規則
一個表中只能有一個 parimary key 字段
對應的字段值不容許有重複,且不容許賦值
若是有多個字段都做爲 parimary key ,稱爲複合主鍵,必須一個建立。
主健字段的KEY標誌死PRI
一般與 auto_increment 連用
常常把表中可以惟一標識記錄的字段位主鍵
1)
-> create table t22( -> create table t22(
-> name char(10), -> name char(10)primary key ,
-> age int, -> age int,
-> likes set('a','b','c'), -> likes set('a','b','c')0;
-> primary key(name));
#建立表時添加主鍵接口
2)
alter table 表名 add primary key(字段);
#已有表添加主鍵
3)
alter table 表名 drop primary key;
#刪除主鍵
##########################################################################
複合主鍵
多個字段一塊兒作主鍵,字段值沒法同時重複。
1)
-> create table 表名(
-> cip char(15),
-> port smallint,
-> status enum('allow','deny') default 'deny',
-> primary key(cip,port));
#建立複合主鍵,必須一塊兒建立
2)
alter table 表名 drop primary key;
#刪除複合主鍵,必須同時刪除
3)
alter table t23 add primary key(cip,port);
#已有表建立複合主鍵
#############################################################################
主鍵與 auto_increment 連用,讓字段的最大值自動增加 +1 ,而且位數值類型
1)
-> create table t24(
-> id int(2) zerofill primary key auto_increment,
-> name char(10),
-> class char(4),
-> index(name));
#建立表
insert into t24(name,class) values('tom','1709');
#添加信息 name class ,此時表中 id 字段自動 +1 。
2)
alter table t24 modify id int(2) unsigned zerofill not null;
alter table t24 drop primary key;
#刪除主鍵要先把 aotu_increment
############################################################################
unique惟一索引
一個表中能夠有多個unique字段
對應的字段值不容許有重複
unique字段的key標誌是uni
unique字段的值容許爲null,當將其修改成不容許爲null,則此字段限制與主鍵相同
############################################################################
外鍵:foreign key
做用:
限制給字段賦值的。
值必須在指定表中指定字段值的範圍內選擇。
條件:
表的存儲引擎必須是innodb
字段類型要一致
被參照字段必需要是索引類型的一種(primary key)
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1)
foreign key(字段) references 被參考表(字段)
on update cascade on delete cascade
#使用方法,同步更新同步刪除
練習:
參考表
mysql> create table jfb(
-> id int(2) primary key auto_increment,
-> name char(10),
-> pay float(7,2)
-> )engine=innodb;
insert into jfb(name,pay) values('bob',20000),('lucy',15000);
+-------+----------+-----------------+
| id | name | pay |
+-------+----------+-----------------+
| 1 | bob | 20000.00 |
| 2 | lucy | 15000.00 |
+-------+----------+-----------------+
外鍵表
mysql> create table xsb(
-> num int(2),
-> name char(10),
-> class char(9),
-> foreign key(num) references jfb(id)
-> on update cascade
-> on delete cascade
-> )engine=innodb;
#num字段參考jfb(id)
insert into xsb values(1,'bob','nsd1709'),(2,'lucy','nsd1709');
#將xsb寫入數據
+----------+----------+----------------+
| num | name | class |
+----------+-----------+---------------+
| 1 | bob | nsd1709 |
| 2 | lucy | nsd1709 |
+----------+----------+----------------+
insert into xsb values(3,'tom','nsd1709');
#由於參考表jfb(id)沒有3,因此沒法建立
insert into xsb values(2,'jerry','nsd1709');
+----------+------------+----------------+
| num | name | class |
+----------+------------+----------------+
| 1 | bob | nsd1709 |
| 2 | lucy | nsd1709 |
| 2 | jerry | nsd1709 |
+----------+------------+----------------+
參考表jfb(id)只有兩條數據,可是仍是添加成功由於
參數 2 存在因此添加成功,可是參考表只有兩條數據
爲了不這種狀況咱們要讓 xsb(num) 也具備惟一性
在上面添加主鍵
delete from xsb where name='jerry';
#刪除重複數據
alter table xsb add primary key(num);
#爲 xsb(num) 設置主鍵
jfb xfb
+-------+----------+-----------------+ +----------+----------+----------------+
| id | name | pay | | num | name | class |
+-------+----------+-----------------+ +----------+-----------+---------------+
| 1 | bob | 20000.00 | | 1 | bob | nsd1709 |
| 2 | lucy | 15000.00 | | 2 | lucy | nsd1709 |
+-------+----------+-----------------+ +----------+----------+----------------+
update jfb set id=8 where id=2;
#修改 jfb id=2 改成 id=8
jfb xfb
+-------+----------+-----------------+ +----------+----------+----------------+
| id | name | pay | | num | name | class |
+-------+----------+-----------------+ +----------+-----------+---------------+
| 1 | bob | 20000.00 | | 1 | bob | nsd1709 |
| 8 | lucy | 15000.00 | | 8 | lucy | nsd1709 |
+-------+----------+-----------------+ +----------+----------+----------------+
delete from jfb where id=1;
#刪除 jfb id 爲1的數據
jfb xfb
+-------+----------+-----------------+ +----------+----------+----------------+
| id | name | pay | | num | name | class |
+-------+----------+-----------------+ +----------+-----------+---------------+
| 8 | lucy | 15000.00 | | 8 | lucy | nsd1709 |
+-------+----------+-----------------+ +----------+----------+----------------+
delete from jfb;
error:被參考的表不能隨便被刪除的
刪除外鍵
show create table 表名
#外鍵名稱自動生成。
alter table 表名 drop foreign key 外鍵名
#刪除外鍵名字
###########################################################################
存儲引擎
MySQL 數據庫服務軟件自帶的程序。
不一樣的存儲引擎有不一樣的功能和數據存儲方式
是處理表的處理器
表名.frm 存放數據庫結構
1)
show engines;
#查看數據庫服務支持的存儲引擎
2)
存儲引擎的特色
MyISAM:
表名.MYI 索引信息
表名.MYI 數據
表名.frm 表結構
功能:
支持表級鎖:鎖一張表
不支持事務 事務回滾
InnoDB
表名.MYI 表結構
表名.idb 數據+索引信息
功能:
支持行級鎖:只給當前被訪問的行加鎖
支持事務 事務回滾
鎖類型:讀鎖、 寫鎖
select insert delete update
接收寫操做的表適合使用 InnoDB 存儲引擎
接收讀操做的表適合使用 MyISAM 存儲引擎
鎖粒度:表級鎖 行級鎖
事務:一次數據訪問從開始訪問到訪問結束的過程
事務回滾:一次數據訪問過程當中任意一步操做錯誤,都會恢復全部操做
事務特性:一致性 原子性 隔離性
事務日誌文件:記錄InnoDB存儲引擎的表執行過的操做。
3)
在配置文件中寫入 /etc/my.cnf
default_storage_engine=存儲引擎名
#修改默認引擎
alter table 表名 engine=存儲引擎名
#修改表引擎
create table 表名(。。。。)engine=innodb;
#設置表的存儲引擎
因當在表中沒有存儲數據時設置。
###########################################################################################MySQL 服務體系結構:(8個功能模塊)鏈接池sql接口分析器:分析命令語法優化器:以最小消耗執行命令查詢緩存:存放曾經查找過的數據存儲引擎文件系統:硬盤管理工具:裝包後提供的命令