bt365软件下载

MySQL的学习总结:创建修改删除数据、数据表和单表查询

MySQL的学习总结:创建修改删除数据、数据表和单表查询

用于数据的查询:

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','计算机一班','123@126.com');

-- 输入一个人的全部数据

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;

相关推荐