## MySQL之自增
我們發現,當我們的mysql表插入一些數據然后刪除這些數據后,我們下一次插入數據時,表的id仍然是接著數據刪除之前id后面增長的,這是MySQL默認的,但是我們能不能修改呢,當然是可以的。當我們輸入語句show create table 表名\\G;時,可以查看表的創建語句,我們插入一些數據后,比如五條數據,我們查看表的創建語句會發現多了一個AUTO\_INCREMENT=6,再次插入一條數據會發現這個值變成了7,我們會發現這個值,和下一條數據的id值是一樣的,經過驗證,果然可以通過修改這個值來修改id,修改語句如下:
~~~
alter table 表名 AUTO_INCREMENT=數字;
~~~
經過查閱資料發現,MySQL可以修改自增字段的自增步長,并且有基于會話級別和全局級別兩種,會話級別就是當前會話登錄,重新登錄一下失效了,全局級別就是只要修改了,那么每一次修改的自增步長都是修改的值,一般不建議修改全局級別的自增步長。
~~~
注意:1、對于自增列,必須是索引(含主鍵)
2、對于自增可以設置步長和起始值
show session variables like 'auto_inc%'; #查看當前會話的步長和起始值
set session auto_increment_increment=2; #設置當前會話的步長
set session auto_increment_offset=10; #設置當前會話的起始值
show global variables like 'auto_inc%'; #查看全局的步長和起始值
set global auto_increment_increment=2; #設置全局的步長
set global auto_increment_offset=10; #設置全局的起始值
~~~
## 唯一索引
~~~
create table t1(
id int primary key auto_increment,
num int,
cid int,
unique 唯一索引名稱 (列名), #()里面可以寫多列,作為聯合唯一索引
)
PS:唯一索引作用:1、約束不能重復
2、加速查找
~~~
## 外鍵的變種
一對多(MySQL默認創建的外鍵就是一對多)
```
create table userinfo1(
id int primary key auto_increment,
name char(32),
age int,
gender enum('男','女')
)engine=innodb default charset=utf8;
create table admin(
id int primary key auto_increment,
username char(32),
password char(32),
user_id int,
constraint fk5 foreign key (user_id) references userinfo1(id)
)engine=innodb default charset=utf8;
一對多
```
一對一(一對一就是在一對多的基礎上加入了唯一索引的約束)
```
create table userinfo1(
id int primary key auto_increment,
name char(32),
age int,
gender enum('男','女')
)engine=innodb default charset=utf8;
create table admin(
id int primary key auto_increment,
username char(32),
password char(32),
user_id int,
unique uq1(user_id),
constraint fk5 foreign key (user_id) references userinfo1(id)
)engine=innodb default charset=utf8;
一對一
```
多對多(多對多需要創建第三張表來維護表的關系)
```
create table userinfo2(
id int primary key auto_increment,
name char(32),
age int,
gender enum('男','女')
)engine=innodb default charset=utf8;
create table host(
id int primary key auto_increment,
hostname char(32)
)engine=innodb default charset=utf8;
create table userhost(
id int primary key auto_increment,
user_id int,
host_id int,
unique uq2(user_id,host_id),
constraint fk6 foreign key (user_id) references userinfo2(id),
constraint fk7 foreign key (host_id) references host(id)
)engine=innodb default charset=utf8;
多對多
```
## MySQL語句的補充
增
~~~
insert into tb11(name,age) values('wusir',12); #插入單條數據
insert into tb11(name,age) values('wusir',12),('root',18); #插入多條數據
insert into tb12(name,age) select name,age from tb11; #從另一張表中查出數據插入這張表
~~~
刪
~~~
delete from tb12; #清空整個表
delete from tb12 where id !=2; #清空id不為2的數據
delete from tb12 where id =2; #清空id為2的數據
delete from tb12 where id > 2; #清空id大于2的數據
delete from tb12 where id >=2; #清空id大于等于2的數據
delete from tb12 where id >=2 or name='wusir'; #清空id大于等于2或者name為wusir的數據
delete from tb12 where id >=2 and name='wusir'; #清空id大于等于2并且name為wusir的數據
~~~
改
~~~
update tb12 set name='wusir' where id>12 and name='xx'
update tb12 set name='wusir',age=19 where id>12 and name='xx'
~~~
查
~~~
a、條件
select * from 表 where id > 1 and name != 'wusir' and num = 12;
select * from 表 where id between 5 and 16;
select * from 表 where id in (11,22,33)
select * from 表 where id not in (11,22,33)
select * from 表 where id in (select nid from 表)
b、通配符
select * from 表 where name like 'ale%' #ale開頭的所有(多個字符串)
select * from 表 where name like 'ale_' #ale開頭的所有(一個字符)
c、限制
select * from 表 limit 5; - 前5行
select * from 表 limit 4,5; - 從第4行開始的5行
select * from 表 limit 5 offset 4 - 從第4行開始的5行
d、排序
select * from 表 order by 列 asc - 根據 “列” 從小到大排列
select * from 表 order by 列 desc - 根據 “列” 從大到小排列
select * from 表 order by 列1 desc,列2 asc - 根據 “列1” 從大到小排列,如果相同則按列2從小到大排序
e、分組
select num from 表 group by numselect num from 表 where id > 10 group by num order by nid desc
select num,min(score) from 表 group by num
group分組經常配合下面的聚合函數使用:
count()
max()
min()
sum()
avg()
select num from 表 group by num having max(id) > 10
特別的:group by 必須在where之后(where中不能有聚合函數),order by之前,如果二次篩選用到了聚合函數,就不能使用where,要使用having,且having要放在group by之后。
~~~
## ?連表查詢
~~~
select * from userinfo5,department5 where userinfo5.part_id = department5.id; #一般不推薦使用這種連表查詢的方式
select * from userinfo5 left join department5 on userinfo5.part_id = department5.id; #左連接(調換兩個表的順序相當于右連接)
#左邊的表全部顯示,如果對應右邊的表有空數據的話顯示null
select * from userinfo5 right join department5 on userinfo5.part_id = department5.id; #右連接(調換兩個表的順序相當于左連接)
#右邊的表全部顯示,如果對應左邊的表右空數據的話顯示null
select * from userinfo5 innder join department5 on userinfo5.part_id = department5.id #內連接
將出現null時的一行隱藏
PS:一般連表查詢不用*,需要查哪個字段就寫哪個字段,字段前最好加上表名,避免不同的表中出現相同的字段,連表后還可以接著連表。
~~~
## ?數據庫的導入導出
~~~
作用:作數據備份
導出現有數據庫數據:
mysqldump -u用戶名 -p密碼 數據庫名稱 > 導出文件路徑 # 導出結構+數據
mysqldump -u用戶名 -p密碼 -d 數據庫名稱 > 導出文件路徑 # 只導出結構
導入現有數據庫數據:
mysqldump -uroot -p密碼 數據庫名稱 < 文件路徑 #導入之前先要保證要導入的數據庫存在
~~~
## ?MySQL之臨時表
~~~
select num from (select * from t1 where id > 5) as B;
~~~

## ?MySQL補充用法
~~~
select course_id,avg(num),sum(case when num <60 THEN 0 ELSE 1 END)/sum(1) as jgl from score GROUP BY course_id;
~~~

~~~
select avg(if(isnull(score.num),0,score.num)),teacher.tname from course left join score on course.cid = score.course_id
left join teacher on course.teacher_id = teacher.tid group by score.course_id
~~~

- Python學習
- Python基礎
- Python初識
- 列表生成式,生成器,可迭代對象,迭代器詳解
- Python面向對象
- Python中的單例模式
- Python變量作用域、LEGB、閉包
- Python異常處理
- Python操作正則
- Python中的賦值與深淺拷貝
- Python自定義CLI三方庫
- Python并發編程
- Python之進程
- Python之線程
- Python之協程
- Python并發編程與IO模型
- Python網絡編程
- Python之socket網絡編程
- Django學習
- 反向解析
- Cookie和Session操作
- 文件上傳
- 緩存的配置和使用
- 信號
- FBV&&CBV&&中間件
- Django補充
- 用戶認證
- 分頁
- 自定義搜索組件
- Celery
- 搭建sentry平臺監控
- DRF學習
- drf概述
- Flask學習
- 項目拆分
- 三方模塊使用
- 爬蟲學習
- Http和Https區別
- 請求相關庫
- 解析相關庫
- 常見面試題
- 面試題
- 面試題解析
- 網絡原理
- 計算機網絡知識簡單介紹
- 詳解TCP三次握手、四次揮手及11種狀態
- 消息隊列和數據庫
- 消息隊列之RabbitMQ
- 數據庫之Redis
- 數據庫之初識MySQL
- 數據庫之MySQL進階
- 數據庫之MySQL補充
- 數據庫之Python操作MySQL
- Kafka常用命令
- Linux學習
- Linux基礎命令
- Git
- Git介紹
- Git基本配置及理論
- Git常用命令
- Docker
- Docker基本使用
- Docker常用命令
- Docker容器數據卷
- Dockerfile
- Docker網絡原理
- docker-compose
- Docker Swarm
- HTML
- CSS
- JS
- VUE