35个常用的mySQL基本操作

1、创建数据库CREATE DATABASE _databasename

--创建一个mytest的数据库
CREATE DATABASE mytest;
--创建一个mytest的数据库并设置默认字符编码
CREATE DATABASE mytest DEFAULT CHARACTER SET "utf8";

2、查看已创建的所有数据库SHOW DATABASES

SHOW DATABASES;

3、使用数据库USE _databasename

--使用mytest数据库
USE mytest;

4、创建数据表CREATE TABLE _tablename

--创建一个名为user的数据表
CREATE TABLE 'user'(
id SMALLINT,
username VARCHAR(20),
age TINYINT
);

5、查看当前数据库中所有的数据表SHOW TABLES

SHOW TABLES;

6、查看当前数据表中的结构DESC _tablename

--查看hurujiuser表
DESC hurujiuser;

7、查看创建数据库时的描述SHOW CREATE TABLE _tablename

--查看hurujiuser
SHOW CREATE TABLE hurujiuser;

8、插入记录INSERT tablename VALUES

--向user表中插入一条记录
INSERT user VALUES("1","huruji","18");
--向user表中插入一条记录只包含名字
INSERT user(username) VALUES("xie");
--向user表中同时插入多条记录
INSERT user VALUES(2,,"xie",10),
(3,"zhi",12),
(4,"huruwa",20);

9、查看数据表中的所有记录SELECT * FROM _tablename

--查看cms_user
SELECT * FROM cms_user;

10、修改数据表名字 RENAME...

ALTER TABLE hurujiuser RENAME TO xieuser;

ALTER TABLE xieuser RENAME AS hurujiuser;

ALTER TABLE hurujiuser RENAME xieuser;

RENAME TABLE xieuser TO hurujiuser;

11、添加字段ADD

--添加一个字段
ALTER TABLE hurujiuser ADD card CHAR(18);
--一次添加多个字段
ALTER TABLE hurujiuser ADD test CHAR,
ADD test2 INT(11),
ADD test3 VARCHAR(20);

12、删除字段DROP

--删除一个字段
ALTER TABLE hurujiuser DROP test;
--一次删除多个字段
ALTER TABLE hurujiuser DROP test2,
DROP test3;
--同时添加和删除字段
ALTER TABLE hurujiuser ADD email VARCHAR(50),
DROP age;

13、修改字段MODIFY

ALTER TABLE hurujiuser MODIFY eamil VARCHAR(200) NOT NULL DEFAULT "myuser@qq.com";

14、修改字段位置MODIFY

--将email字段移至addr字段之后
ALTER TABLE hurujiuser MODIFY email VARCHAR(200) NOT NULL DEFAULT "myuser@qq.com" AFTER addr;
--将username字段移至第一位
ALTER TABLE hurujiuser MODIFY username CARCHAR(20) NOT NULL UNIQUE FIRST;

15、添加主键ADD PRIMARY KEY

ALTER TABLE hurujiuser ADD PRIMARY KEY(username);

16、添加唯一ADD UNIQUE

ALTER TABLE hurujiuser ADD UNIQUE(email);

17、为两个字段添加唯一索引ADD UNIQUE INDEX

ALTER TABLE hurujiuser ADD UNIQUE INDEX mul_age_num(age,num);

18、删除唯一索引DROP

ALTER TABLE hurujiuser DROP mul_age_num;

19、删除数据表DROP TABLE _tablename

DROP TABLE hurujiuser;

20、将查询结果插入到新的表中

--将testinsert 中的id,username插入表mytest中
INSERT mytest SELECT id,username FROM testinsert;

21、更改数据UPDATE

--将所有记录的age改为15
UPDATE hurujiuser SET age=15;
--将id=1的记录的age改为2,email为id@qq.com
UPDATE hurujiuser SET age=2,email="id@qq.com" WHERE id=1;

22、彻底清空表格TRUNCATE

TRUNCATE TABLE hurujiuser;

23、查询数据SELECT ... FROM ...

--查询所有记录
SELECT * FROM hurujiuser;
--查询记录中的id和username
SELECT id username FROM hurujiuser;
--查询id=1的记录
SELECT * FROM hurujiuser WHERE id=1;
--查询id>=6的所有记录
SELECT * FROM hurujiuser WHERE id>=6; 

24、模糊查询LIKE
%:代表0个、1个或者多个任意字符
_:代表1个任意字符

--搜索名字中含有张字的用户
SELECT * FROM cms_user WHERE username LIKE "%张%";
--搜索名字中姓张的用户
SELECT * FROM cms_user WHERE username LIKE "张%";
--搜索姓名为4个字的用户
SELECT * FROM cms_user WHERE username LIKE "____";

25、分组查询GROUP BY

SELECT * FROM cms_user GROUP BY proid;

26、显示分组后的详情GROUP_CONCAT

--显示每个组中的姓名
SELECT id,sex,GROUP_CONCAT(username) FROM cms_user GROUP BY sex;

27、二次筛选HAVING

SELECT sex,GROUP_CONCAT(username) AS users,
COUNT(*) AS totalUsers,
MAX(age) AS max_age,
SUM(age) AS total_age
FROM cms_user GROUP BY sex HAVING COUNT(*)>2;

28、排序ORDER BY

--升序默认
SELECT * FROM cms_user ORDER BY id;
SELECT * FROM cms_user ORDER BY id ASC;
--降序
SELECT * FROM cms_user ORDER BY id DESC;

29、随机显示RAND()

SELECT * FROM cms_user RAND();

30、限制记录LIMIT

--显示前3条
SELECT * FROM cms_user LIMIT 3;
SELECT * FROM cms_user LIMIT 0,3;
--显示4,5,6三条
SELECT * FROM cms_user LIMIT 3,3;

31、聚合函数MAX(),MIN(),AVG(),SUM()

SELECT id,sex,age,GROUP_CONCAT(username),
COUNT(*) AS totalusers,
MAX(age) AS max_age,
MIN(age) AS min_age,
AvG(age) AS avg_age,
SUM(age) AS sum_age
FROM cms_user
WHERE id>=1
GROUP BY sex
HAVING COUNT(*)>=2 ORDER BY age DESC LIMIT 2;

32、内连接查询

SELECT u.id,u.username,u.email,u.sex,p.proname
FROM cms_user AS u
INNER JOIN provinces AS p 
ON u.proid=p.id;

SELECT u.id,u.username,p.proName
FROM provinces AS p
CROSS JOIN cms_user AS u
ON p.id=u.proid;

SELECT u.id,u.username,u.sex,p.proName
FROM cms_user AS u JOIN 
provinces AS p
ON u.proid=p.id
WHERE u.sex="男";

33、联合查询UNION

SELECT username FROM employee UNION SELECT username FROM cms_user;

34、子查询

SELECT id username FROM employee WHERE depId IN(SELECT id FROM department);

35、添加外键FOREIGN KEY

CREATE TABLE IF NOT EXISTS employee(
id SMALLINT UNSIGNED AUTO_INCREMENT KEY,
username VARCHAR(20) NOT NULL UNIQUE,
depId TINYINT UNSIGNED,
CONSTRAINT emp_fk_dep FOREIGN KEY(depId) REFERENCES department(id)
)ENGINE=INNODB;

ALTER TABLE employee ADD CONSTRAINT emp_fk_dep FROEIGN KEY(depId) REFERENCES department(id);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,444评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,421评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,363评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,460评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,502评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,511评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,280评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,736评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,014评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,190评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,848评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,531评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,159评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,411评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,067评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,078评论 2 352

推荐阅读更多精彩内容