目录
SQL
sql:结构化查询语言,其实就是定义了操作所有关系型数据库的规则,每一种数据库存在不一样的地方,称为方言。
sql的通用语法:sql语句可以单行或多行书写,以分号结尾。可以使用空格和缩进来增强语句的可读性。
注释方式:单行注释:-- 注释内容 # 注释内容 多行注释: /* 注释 */
sql语言的分类:
1)ddl:数据定义语言,用来定义数据对象,表,关键字。
2)dml:数据操作语言,用来对数据库中的数据进行增删改。
3)dql:数据查询语言,用来擦汗寻数据表中的记录。
4)dcl:数据控制语言,用来定义数据库的访问权限和安全级别,及创建用户。
DDL:操作数据库
1.操作数据库:CRUD
1.C(create):创建
创建数据库:
create database
创建数据库db4数据库,判断是否存在,并指定字符集为gbk
create database if not exists db4 charcter set gbk;
2.R(Retrieve):查询
查询所有数据库的名称
show database;
查询某个数据库的字符集:查询某个数据库的创建语句
show create database 数据库名称
3.U(Update):修改
修改数据库的字符集
alter database 数据库名称 character set 字符集名称;
4.D(Delete):删除
删除数据库
drop database 数据库名称
判断数据库存在,存在再删除
drop database if exists 数据库名称;
5.使用数据库
查询当前正在使用的数据库名称
select database();
2.操作表
1.C(create):创建
1.语法
create table 表名(
列名1 数据类型1,
列名2 数据类型2,
...
列名n 数据类型n
);
注意:最后一列,不需要加逗号
2.数据库类型:
1.int:整数类型
age int,
2.double:小数类型
score double(5,2)
3.date:日期,致函年月日,yyy-MM-dd
4.datatime:日期,包含年月日时分秒 yyy-MM-dd HH:mm:ss
5.timestamp:时间错类型 包含年月日时分秒 yyy-MM-dd
HH:mm:ss
如果将来不给这个字段赋值,或赋值为null,则默认使用当前系统时间,
来自动赋值
6.varchar:字符串
name varchar(20):姓名最大20个字符
zhangsan 8个字符 张三 2个字符
创建表
create table student(
id int,
name varchar(32),
age int,
score double(4,1),
birthday date,
insert_time timestamp
);
复制表:
create table 表名 like 被复制的表名;
2.R(Retrieve):查询
查询某个数据库中所有表的名称
show tables;
查询表结构
desc 表名;
3.U(update):修改
1.修改表名
alter table 表名 rename to 新的表名;
2.修改表的字符集
alter table 表名 charcter set 字符集名称;
3.添加一列
alter table 表名 add 列名 数据类型;
4.修改列名称 类型
alter table 表名 change 列名 新列名 新数据类型;
5.删除列
alter table 表名 drop 列名称;
4.D(Delete):删除
drop table 表名;
drop table if exists 表明
DML:增删改表中数据
1.添加数据
语法
insert into 表名(列名1,列名2,...列名n) values(值1,值2...值n);
注意:
1.列名和值一一对应。
2.如果表改名后,不定义列名,则默认给所有列添加元素
insert into 表名 values(值1,值2,...值n);
3.除了数字类型,其他类型都需要使用引号(单双引号都行)引起来
2.删除数据
delete from 表名 [where 条件]
注意:
1.如果不加条件,则删除表中所有数据
2.如果要删除所有数据
delete from 表名;-- 不推荐使用,有多少条记录就要执行多少次
3.修改数据
语法:
update 表名 set 列名1=值1,列名2=值2,...[where 条件];
如果不加任何条件,则所有记录 全部都会被
DQL:查询表中的记录
select * from 表名;
1.语法
select
字段列表
from
表名列表
group by
分组字段
having
分组之后的条件
order by
排序
limit
分页限定
2.基础查询
1.多个字段的查询
select 字段名1,字段名2,...from 表名;
注意:
如果查询所有字段,则可以使用*来替代字段列表
2.去除重复
distinct
3.计算列
一般可以用四则运算计算一些列的值(一般只会进行数值型的计算)
ifnull(表达式1,表达式2):null参与的运算,计算结果都为null
表达式1:哪个字段需要判断是否为null
表达式2该字段为null后的替换值
4.起别名
as:as也可以省略
3.条件查询
1.where句子后跟条件
2.运算符
>,<,<=,>=,=,<>
BETWEEN...AND
IN(集合)
LIKE:模糊查询
_:单个任意字符
%:多个任意字符
IS NULL
AND 或&&
OR 或||
not 或!
-- 查询年龄大于20岁
SELECT*FROM student WHERE age>20;
SELECT*FROM student WHERE age>=20;
-- 查询英语成绩不为null
SELECT *FROM student WHERE english is not null;