MySQL日常操作
《MySQL日常操作》要点: 安装 MySQL 5.5.27 x64
删除
登陆 >mysql -u root -p 退出 > quit 修改密码
SQL SHOW 1. 查看当前数据库服务器中的所有数据库 DDL:操作数据库、表、列等
操作数据库 CREATE CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] ALTER ALTER DATABASE [IF NOT EXISTS] db_name SELECT 1. 查看当前使用的数据库 DROP
RENAME 找到MySQL 数据库存放位置 data,将数据库改为对应的名称 操作数据表 创建表
查询表信息
修改表 追加 ALTER TABLE table_name 修改 ALTER TABLE table_name 删除列 ALTER TABLE table_name 修改表名 Rename TABLE 表名 to 新表名; 修改表的字符集 ALTER TABLE table_name character set utf8; 删除表 DROP TABLE user;
DML操作(重要)
插入操作:INSERT:
修改操作 UPDATE:
删除操作 DELETE:
RENAME TABLE命令语法:
DQL数据查询语言 (重要)
根据数据字典 创建表 学生表:stu -- 创建学生表 雇员表:emp -- 创建雇员表 部门表:dept -- 创建部门表 基础查询
条件查询(操作stu表)
2.2 查询性别为女,并且年龄大于等于50的记录 SELECT * FROM stu WHERE gender=’female’ AND age>=50; 2.3 查询学号为S_1001,或者姓名为liSi的记录 SELECT * FROM stu WHERE sid=’S_1001’ OR sname=’lisi’; 2.4 查询学号为S_1001,S_1002,S_1003的记录 SELECT * FROM stu WHERE sid=’S_1001’ OR sid=’S_1002’ OR sid=’S_1003’; SELECT * FROM stu WHERE sid IN(‘S_1001’,’S_1002’,’S_1003’); 2.5 查询学号不是S_1001,S_1003的记录 SELECT * FROM stu WHERE sid NOT IN(‘S_1001’,’S_1003’); 2.6 查询年龄为null的记录 SELECT * FROM stu WHERE age IS NULL; SELECT * FROM stu WHERE age IS NOT NULL; 2.7 查询年龄在20到40之间的学生记录 SELECT * FROM stu WHERE age>=20 AND age<=40; SELECT * FROM stu WHERE age BETWEEN 20 AND 40; 2.8 查询性别非男的学生记录 SELECT * FROM stu WHERE gender=’female’; SELECT * FROM stu WHERE gender!=’male’; SELECT * FROM stu WHERE gender<>’male’; 2.9 查询姓名不为null的学生记录 SELECT * FROM stu WHERE sname IS NOT NULL; 模糊查询(操作stu表)
3.1 查询姓名由5个字母构成的学生记录 SELECT * FROM stu WHERE sname LIKE ‘_‘; – 模糊查询必须使用LIKE关键字.其中 “”匹配任意一个字母,5个“”表示5个任意字母. 3.2 查询姓名由5个字母构成,并且第5个字母为“i”的学生记录 SELECT * FROM stu WHERE sname LIKE ‘____i’; 3.3 查询姓名以“z”开头的学生记录 SELECT * FROM stu WHERE sname LIKE ‘z%’; – 其中“%”匹配0~n个任何字母. 3.4 查询姓名中第2个字母为“i”的学生记录 SELECT * FROM stu WHERE sname LIKE ‘_i%’; 3.5 查询姓名中包含“a”字母的学生记录 SELECT * FROM stu WHERE sname LIKE ‘%a%’; 字段控制查询(操作emp表) 4.1 去除重复记录 去除重复记录(两行或两行以上记录中系列的上的数据都相同),例如emp表中sal字段就存在相同的记录.当只查询emp表的sal字段时,那么会出现重复记录,那么想去除重复记录,需要使用DISTINCT: SELECT DISTINCT sal FROM emp; 4.2 查看雇员的月薪与佣金之和 因为sal和comm两列的类型都是数值类型,所以可以做加运算.如果sal或comm中有一个字段不是数值类型,那么会出错. SELECT *,sal+comm FROM emp; comm列有很多记录的值为NULL,因为任何东西与NULL相加结果还是NULL,所以结算结果可能会出现NULL.下面使用了把NULL转换成数值0的函数IFNULL: SELECT *,sal+IFNULL(comm,0) FROM emp; 4.3 给列名添加别名 在上面查询中出现列名为sal+IFNULL(comm,0),这很不美观,现在我们给这一列给出一个别名,为total: SELECT *,0) AS total FROM emp; 给列起别名时,是可以省略AS关键字的: SELECT *,0) total FROM emp; 排序 (操作stu表)
5.1 查询所有学生记录,按年龄升序排序 SELECT * FROM stu ORDER BY sage ASC; 或者(默认) SELECT * FROM stu ORDER BY sage; 5.2 查询所有学生记录,按年龄降序排序 SELECT * FROM stu ORDER BY age DESC; 5.3 查询所有雇员,按月薪降序排序,如果月薪相同时,按编号升序排序 SELECT * FROM emp ORDER BY sal DESC,empno ASC; 聚合函数
COUNT() 当需要纵向统计时可以使用COUNT(). 查询emp表中记录数: SELECT COUNT(*) AS cnt FROM emp; 查询emp表中有佣金的人数: SELECT COUNT(comm) cnt FROM emp; 注意,因为count()函数中给出的是comm列,那么只统计comm列非NULL的行数. 查询emp表中月薪大于2500的人数: SELECT COUNT(*) FROM emp WHERE sal > 2500; 统计月薪与佣金之和大于2500元的人数: SELECT COUNT(*) AS cnt FROM emp WHERE sal+IFNULL(comm,0) > 2500; 查询有佣金的人数,有领导的人数: SELECT COUNT(comm),COUNT(mgr) FROM emp; SUM和AVG 当需要纵向求和时使用sum()函数. 查询所有雇员月薪和: SELECT SUM(sal) FROM emp; 查询所有雇员月薪和,以及所有雇员佣金和: SELECT SUM(sal),SUM(comm) FROM emp; 查询所有雇员月薪+佣金和: SELECT SUM(sal+IFNULL(comm,0)) FROM emp; 或者 SELECT SUM(sal)+SUM(comm) FROM emp; 统计所有员工平均工资: SELECT AVG(sal) FROM emp; MAX和MIN 查询最高工资和最低工资: SELECT MAX(sal),MIN(sal) FROM emp; 分组查询
此处需要去除 gender 为 NULL 的数据 SELECT COUNT(*) FROM stu WHERE gender IS NOT NULL GROUP BY gender; 分组查询 查询每个部门的部门编号和每个部门的工资和: SELECT deptno,SUM(sal) FROM emp GROUP BY deptno; 查询每个部门的部门编号以及每个部门的人数: SELECT deptno,COUNT(*) FROM emp GROUP BY deptno; 查询每个部门的部门编号以及每个部门工资大于1500的人数: SELECT deptno,COUNT(*) FROM emp WHERE sal>1500 GROUP BY deptno; HAVING子句 查询工资总和大于9000的部门编号以及工资和:
查询工资大于1500的,工资总和大于6000的部门编号以及工资和:
注: having与where的区别:
图解: LIMIT LIMIT用来限定查询结果的起始行,以及总行数. 查询5行记录,起始行从0开始 SELECT * FROM emp LIMIT 0,5;
原表: limit 0,5 后 查询10行记录,起始行从3开始 SELECT * FROM emp LIMIT 3,10; 分页查询 如果一页记录为10条,希望查看第3页记录应该怎么查呢? 1. 第一页记录起始行为0,一共查询10行; 2. 第二页记录起始行为10,一共查询10行; 3. 第三页记录起始行为20,一共查询10行; DQL 书写顺序和执行顺序 查询语句书写顺序: select – from- where - group by- having - order by - limit 查询语句执行顺序: from - where - group by - having - select - order by - limit 编程之家PHP培训学院每天发布《MySQL日常操作》等实战技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培养人才。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |