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','计算机一班','[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;

猜你喜欢

转载自blog.csdn.net/2301_79355407/article/details/135995965