用于数据的查询:
SELECT子句(选择)、FROM子句WHERE子句
对数据库中的数据进行增加、修改和删除。
1)INSERT:增加数据
2)UPDATE:修改数据
3)DELETE:删除数据
针对数据库对象进行创建、修改和删除操作。
1)CREATE:创建数据库对象(create)
2)ALTER:修改数据库对象(alter)
3)DROP:删除数据库对象(drop)
授予或回收访问数据库的权限
1)GRANT:授予用户权限(grant)
2)REVOKE:回收授予的权限(revoke)
用于数据库的事务管理。
1)START TRANSACTION:开启事务(start transaction)
2)COMMIT:提交事务(commit)
3)ROLLBACK:回滚事务(rollback)
4)SET TRANSACTION:设置事务的属性(set transaction)
一、创建数据库表
以创建student表为例:表中包括学生的学号,姓名,年龄,入学日期,班级,email
create table t_student(
sno int(5),
sname varchar(10),
sex char(1),
age int(3),
enterdate date,
classname varchar(15),
email varchar(15)
);
desc t_student; -- 查看表的结构
select * from t_student; -- 查看表中数据
二、数据表中添加数据
insert into t_student values(1,'张三','男',18,’2022-5-8','计算机一班','[email protected]');
-- 输入一个人的全部数据
insert into t_student(sname,age) values('李四',18);
-- 输入一个人的部分数据
-- 注意:
-- 输入字符串时,用''或""
-- 输入的每个数据用逗号隔开,最后一个数据没有逗号
三、数据表中修改和删除数据
-- 修改数据
-- 修改所有性别为男
update t_student set sex = '男'
-- 修改指定的行,性别改为男
update t_student set sex = '男' where sno = 1;
-- 删除一行数据
delete from t_student where sno = 1;
-- 注意:
-- 内容不区分大小写。
-- 删除数据时:注意加from
-- 修改数据时,注意加where 限制条件
四、修改和删除数据库表
--修改表的结构
-- 增加一列并填写数据:
alter table t_student add score int(5);
update t_student set score = 99 where sno = 1;
-- 指定增加的一列所在位置
-- 放在最前面
alter table t_student add score int(5) first;
-- 放在sname后面
alter table t_student add score int(5) after sname;
-- 删除一列:
alter table t_student drop score;
-- 修改列的结构
alter table t_student modify score float(4.1);
-- 修改列的名字和结构
alter table t_student change score score1 float(4.1);
五、快速添加表
-- 添加一个表,结构和数据与t_student一致
create table t_student1
as
select * from t_student;
-- 添加一个表,结构和t_student一致,没有数据
create table t_student1
as
select * from t_student where 1 = 2;
-- 添加一个表,只要部分数据,部分列
create table t_student1
as
select sno.sname,age from t_student where sno = 1;
-- 清空数据
delete from t_student;
六、单表查询
1.基本SQL查询命令
-- 对emp表进行查询
select * from emp;
-- 显示部分列的数据
select ename,empno from emp;
-- 显示部分行的数据
select * from emp where sal > 2000;
-- 显示部分行、部分列的数据
select ename,empno from emp where sal > 2000;
-- 起别名
select ename as '名字',sal as "工资" from emp;
-- 注意:
-- as可省略,''或""可省略
-- 别名有特殊字符时不可省略
select ename 名字,sal 工资 from emp;
-- 算术运算符
select sal,sal+1000 from emp;
-- 去重操作:distinct
select distinct sal from emp;
-- 排序:order by
-- asc:升序,默认不写
-- desc:降序
select * from emp order by sal;
select * from emp order by sal desc;
2.where子句
作用:筛选条件
select * from emp where deptno = 10;
select * from emp where deptno > 10;
select * from emp where deptno >= 10;
select * from emp where deptno < 10;
select * from emp where deptno <= 10;
select * from emp where deptno != 10;-- 不等于
select * from emp where deptno <> 10;-- 不等于
select * from emp where sname = 'gong';
select * from emp where deptno = 'GONG';
-- 默认情况,字符不区分大小写,加binary 区分大小写
select * from emp where binary sname = 'gong';
select * from emp where hiredate > '2024-2-2';
-- where子句和and
select * from emp where sal > 1500 and sal < 2000;
select * from emp where sal > 1500 && sal < 2000;
select * from emp where sal > 1500 and sal < 2000 order by sal;-- 按工资排序
select * from emp where sal between 1500 and 2000;
-- where子句和or
select * from emp where deptno = 10 or deptno = 20;
select * from emp where deptno = 10 || deptno = 20;
select * from emp where deptno in (10,20);
-- where子句和like:模糊查询
-- %代表任意多个字符
-- _代表任意一个字符
select * from emp where ename like '%A%';
select * from emp where ename like '_A_';
-- 判断null
select * from emp where ename is null;
select * from emp where ename is not null;
-- ()优先级的考虑
select *from emp where (ename = 'jock' or ename = 'gong') or sal = 1500;
3.单行函数和多行函数
1)单行函数:
改变每一条结果,每一条数据对应一条结果
常用的单行函数主要包括字符串函数、数值函数、日期与时间函数、流程函数以及其他函数。
2)多行函数:
多行函数是指对一组数据进行运算,针对这一组数据(多行记录)只返回一个结果,也称为分组函数。
需要时直接调用即可。
4.分组group by
-- 统计各个部门的平均值
select deptno,avg(sal) from emp group by deptno;
5.having分组后筛选
等效于where
where先筛选再分组
having先分组再筛选
-- 统计各个岗位的平均工资,除了MANAGER
-- 方法1:
select job,avg(sal) from emp group by job having job != 'MANAGER';
--方法2:
select job,avg(sal) from emp where job != 'MANAGER' group by job;