SQL基础操作
#2020云栖大会#阿里云海量offer来啦!投简历、赢阿里云限量礼品及阿里云ACA认证免费考试资格!>>>
什么是SQL
SQL常用数据类型
SQL功能分类
DDL
DML
DQL
什么是SQL
SQL是Structured Quevy Language(结构化查询语言)的缩写。
SQL是专为数据库而建立的操作命令集,是一种功能齐全的数据库语言。
在使用它时,只需要发出“做什么”的命令,“怎么做”是不用使用者考虑的。
SQL常用数据类型
int:整型
double:浮点型,例如double(5,2)表示最多5位,其中必须有2位小数,即最大值为999.99;
char:固定长度字符串类型;char(10) 'abc '
varchar:可变长度字符串类型;varchar(10) 'abc'
text:字符串类型;
blob:二进制类型;
date:日期类型,格式为:yyyy-MM-dd;
time:时间类型,格式为:hh:mm:ss
datetime:日期时间类型 yyyy-MM-dd hh:mm:ss
在mysql中,字符串类型和日期类型都要用单引号括起来。
SQL功能分类
DDL:数据定义语言
用来定义数据库对象:创建库,表,列等。
DML:数据操作语言
用来操作数据库表中的记录
DQL:数据查询语言
用来查询数据
DCL:数据控制语言
用来定义访问权限和安全级别
DDL
创建数据库
create database 数据库名 (character set utf8);
修改数据库
alter database 数据库名 (charactor set utf8);
创建表
CREATE TABLE student(sno VARCHAR(10),sname VARCHAR(10),sex varchar(2) CHECK(sex='男' or sex='女'));
添加一列
ALTER TABLE 表名 ADD 列名 数据类型;
修改一个表的字段类型
ALTER TABLE 表名 MODIFY 字段名 数据类型;
修改表名
RENAME TABLE 原始表名 TO 要修改的表名;
修改表的字符集为gbk
ALTER TABLE 表名 CHARACTER SET 字符集名称;
修改表的列名
ALTER TABLE 表名 CHANGE 原始列名 新列名 数据类型;
查看表的字段信息
DESC 表名;
查看表的创建细节
SHOW CREATE TABLE 表名;
删除一列
ALTER TABLE 表名 DROP 字段名;
删除表
DROP TABLE 表名;
DML
查询表中的所有数据
SELECT * FROM 表名;
插入操作
INSERT INTO 表名(列名1,列名2 ...)VALUE (列值1,列值2...);
批量插入
INSERT INTO 表名(列名1,列名2 ...)VALUES (列值1,列值2...),(列值1,列值2...);
更新操作
UPDATE 表名 SET 列名1=列值1,列名2=列值2 ... WHERE 列名=值
删除操作
DELETE FROM 表名 (WHERE 列名=值);TRUNCATE TABLE 表名 (WHERE 列名=值);
DELETED 与TRUNCATE的区别
DELETE 删除表中的数据,表结构还在;
TRUNCATE 删除是把表直接DROP掉,然后再创建一个同样的新表。执行速度比DELETE快。
DQL
查询所有列
SELECT * FROM 表名;
结果集
数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端。
通过查询语句查询出来的数据以表的形式展示我们称这个表为虚拟结果集。存放在内存中。
查询返回的结果集是一张虚拟表。
查询指定列的数据
SELECT 列名1,列表2... FROM 表名;
条件查询
select * from 表名 where 字段 运行符用法;where name = "张三";where age < 20 ;where age between 18 and 30;where name in("张三","李四","王五");
条件查询运行符及关键字
=(等于)、!=(不等于)、<>(不等于)、<(小于)、<=(小于等于)、>(大于)、>=(大于等于);
BETWEEN…AND;值在什么范围
IN(set);固定的离散范围
IS NULL(为空)、IS NOT NULL(不为空)
AND与、OR或、NOT非
模糊查询
使用like关键字
通配符
_ :任意一个字符
%:任意0~n个字符
where name like "带有通配符";where name like "张%"; //"张"开头的where name like "张__"; // "张"开头的并且三个字where name like "%张%"; // 含有"张"的where name like "___张%";// 第四位是"张"的
字段控制查询
去除重复记录
SELECT DISTINCT name FROM students;
把查询字段的结果进行运算,必须都要是数据型
SELECT *,字段1+字段2 FROM 表名;/*列有很多记录的值为NULL,因为任何东西与NULL相加结果还是NULL,所以结算结果可能会出现NULL。下面使用了把NULL转换成数值0的函数IFNULL*/SELECT *,age+IFNULL(score,0) FROM students;
对查询结果起别名
/*在上面查询中出现列名为sx+IFNULL(yw,0),这很不美观,现在我们给这一列给出一个别名,为totalAS可以省略*/SELECT *, yw+IFNULL(sx,0) AS total FROM score;SELECT *, yw+IFNULL(sx,0) total FROM score;
排序
对查询的结果进行排序
/*使用关键字ORDER BY排序类型升序ASC从小到大 默认降序DESC从大到小*/select * from student order by age desc;
聚合函数
对查询的结果进行统计计算
/*常用聚合函数COUNT():统计指定列不为NULL的记录行数;MAX():计算指定列的最大值,如果指定列是字符串类型,那么使用字符串排序运算;MIN():计算指定列的最小值,如果指定列是字符串类型,那么使用字符串排序运算;SUM():计算指定列的数值和,如果指定列类型不是数值类型,那么计算结果为0;AVG():计算指定列的平均值,如果指定列类型不是数值类型,那么计算结果为0;*/SELECT COUNT(*) AS studentNumber FROM student;// 查询有几条student记录SELECT COUNT(grade) FROM stduent;// 有成绩的学生多少条SELECT COUNT(*) FROM student WHERE grade > 60;// 成绩大于60的学生有多少SELECT COUNT(*) FROM student WHERE grade-IFNULL(penalty,0) > 60;// 成绩减去罚分超过60的SELECT SUM(grade) FROM student;// 全体学生总分SELECT AVG(grade) FROM student;// 平均分SELECT MAX(grade), MIN(grade) FROM student;// 两列最高和最低分
勤学如春起之苗,不见其增,只有所长。辍学如磨刀之石,不见其增,日有所亏
本文分享自微信公众号 - IT那个小笔记(qq1839646816)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

浙公网安备 33010602011771号