01.DDL
常用數(shù)據(jù)類(lèi)型
- 創(chuàng)建表
create table user(username varchar(30),
password char(32));
- 查看表結(jié)構(gòu)
desc user; - 查看表創(chuàng)建語(yǔ)句
show create table user; - 刪除表
drop table user; - 創(chuàng)建表指定字符集和引擎
create table user(username varchar(30), password char(32)) engine=innodb default charset=utf8; - 修改字段類(lèi)型
alter table user modify username varchar(20); - 添加字段
alter table user add email varchar(30)
alter table user add email varchar(30) after username;
增刪改查 curd操作
首先通過(guò)mysql -uroot -p 進(jìn)入數(shù)據(jù)庫(kù)系統(tǒng)士飒,創(chuàng)建數(shù)據(jù)庫(kù)dudu嘉蕾,進(jìn)入數(shù)據(jù)庫(kù)dudu use dudu,然后才是創(chuàng)建表的過(guò)程
所有的符號(hào)都是英文诽嘉。
- 創(chuàng)建表開(kāi)始學(xué)習(xí)增刪改
mysql> create table user(
-> id int auto_increment,
-> name varchar(30) not null,
-> money int not null,
-> province varchar(20) default null,
-> age tinyint unsigned not null,
-> sex enum('女', '男') not null,
-> primary key(id)
-> )engine=innodb default charset=utf8;
【注】單選在插入值的時(shí)候下愈,可以直接使用1 2汹碱,那么1代表女尖啡,2代表男,enum類(lèi)型如不不給值摧玫,默認(rèn)是第一個(gè)
- set類(lèi)型如何插入耳奕?
set('吃', '喝', '嫖', '賭', '抽')
1 2 4 8 16
4|8|16 如果是后三個(gè),可以這么寫(xiě)
28 也可以加起來(lái),這么寫(xiě)
02.可視化工具
當(dāng)你去操作數(shù)據(jù)庫(kù)的時(shí)候屋群,其實(shí)有3中方式
(1)使用mysql自帶的客戶(hù)端進(jìn)行操作
(2)使用一些第三方的可視化工具管理數(shù)據(jù)庫(kù) 比如navicate闸婴、sqlyog
(3)使用代碼去操作數(shù)據(jù)庫(kù),比如python芍躏、java邪乍、php
04.DQL
query : 查詢(xún)
模糊查詢(xún):like '%德%' 只要有 德 字的都符合要求
% 代表任意多的字符
like '柳_' 叫 柳某 的都符合要求
_ 代表一個(gè)任意字符
limit:
limit 2 : 在結(jié)果集中只要前兩個(gè)
limit offset, number : offset代表偏移量,number代表數(shù)量
LIMIT number1 OFFSET number2 : number1 是數(shù)量 number2 是偏移量
上網(wǎng)的時(shí)候对竣,經(jīng)常會(huì)有分頁(yè)庇楞,每頁(yè)顯示10條,
第一頁(yè):select * from table limit 0, 10
第二頁(yè):select * from table limit 10, 10
第三頁(yè):select * from table limit 20, 10
第n頁(yè):select * from table limit (n-1)*10, 10
分組:
字段只能出現(xiàn)分組字段和統(tǒng)計(jì)信息否纬,其它的字段出現(xiàn)沒(méi)有意義
select province, count() from user group by province;
select province, count() as c from user group by province having c>=2;
【注】having經(jīng)常跟在group by的后面姐刁,where是跟在表的后面
- select使用順序
SELECT xxx FROM xxx WHERE xxx GROUP BY xxx HAVING xxx ORDER BY xxx LIMIT xxx;
多表聯(lián)合
mysql> create table user(
-> id int auto_increment,
-> name varchar(30) not null,
-> gid varchar(10) default 0,
-> primary key(id)
-> )engine=innodb default charset=utf8;
mysql> create table goods(
-> gid int auto_increment,
-> name varchar(30) not null,
-> price int not null,
-> category varchar(20) not null,
-> primary key(gid)
-> )engine=innodb default charset=utf8;
mysql> insert into user(name, gid) values('郭德綱', 1),
-> ('岳云鵬', 2),
-> ('曹云金', 0),
-> ('于謙', 3),
-> ('牛群', 1),
-> ('馮鞏', 1),
-> ('大兵', 4),
-> ('馬三立', 0),
-> ('賈玲', 2);
- 隱式內(nèi)連接
select user.name as uname, goods.name as gname from user, goods where user.gid=goods.gid; - 顯示內(nèi)連接
select * from user as u join goods as g on u.gid=g.gid;
select u.name as uname, g.name as gname from user as u join goods as g on u.gid=g.gid; - 三表鏈接格式
select * from user as u join goods as g on u.gid=g.gid join price as p on g.pid=p.pid