MySQL表的增删改查(基础)

一、新增(Create)

1、单行数据,全列插入

语法

insert into 表名 values(值,值......);

值与列相匹配

2、指定列插入

insert into 表名(列名,列名...) values(值,值...);

只插入其中的几列,其余被填充为默认值

3、一次插入多行

insert into 表名 values(值,值...),(值,值...);

插入datetime 类型,有固定字符串如:

'2000-01-01 12:00:00'

插入当前时间:now()

二、删除(Delete)(危险操作)

delete from 表名 where 条件(order by/limit);

若where后面不指定条件,则是删除整个表

注:drop table 是删除整个表,表里的记录也删除了

delete 是删除表里的记录,表还在(但是空表)

三、修改(Update)(危险操作)

update 表名 set 列名 = 值 where 条件 (order by/limit);

此时的运算符"="代表的是赋值

若update后面不指定条件,则是对所有行进行修改

四、查询(Retrieve)

1、全列查询(危险操作)

select*from 表名 ;(该行为是一个危险操作,若表中的数据过于庞大,很可能导致占用内存过大而使数据库挂掉)

* 表示 "通配符" ,代表所有列

2、指定列查询

select 列名,列名...from 表名;

3、查询字段为表达式(一边查询,一边计算)

select 列名,列名+操作... from 表名;(该查询是列与列中的运算)

不会修改数据库中的数据,只是在临时结果中做了运算(null参与运算的结果还是null)

4、别名查询

select 表达式 as 别名 from 表名;

为查询结果中的列指定别名,表示返回的结果集中,以别名作为该列的名称

5、去重查询

select distinct 列名 from 表名;

distinct放于select之后

6、查询时排序(把行进行排序,仅针对临时数据)

select 列名 from 表名 order by 列名 asc(升序)/desc(降序) ;

若未标明,则默认为升序

不加order by 的数据顺序是不可靠的

7、条件查询(制定具体条件,根据条件对数据进行筛选)

select 列名 from 表名 where 条件;

比较运算符

逻辑运算符

注:

1、where条件可以使用表达式,但不能使用别名

2、and的优先级高于or,在同时使用时,需要使用小括号()包裹优先执行的部分

3、对null进行判定的时候,<=> 可以对两个列进行修饰,is null只能修饰一个列

8、分页查询(限制查询数量)

select 列名 from 表名 limit N offset M;

limit写在句子最后

select执行的顺序

1、遍历表中的每一个记录

2、将当前的纪录代入条件

3、如条件成立则保留,进行上述的表达式计算

4、有order by ,会在所有行被获取了以后(表达式已算完)再排序

相关推荐
韩立学长3 分钟前
基于Springboot琴行学生课程信息管理系统2gt392wb(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
Mr.H01275 分钟前
Linux常见压缩命令
linux·服务器·数据库
咕噜企业分发小米7 分钟前
阿里云与华为云基因测序数据同步的日志内容中,哪些字段对于故障排查最为关键?
数据库·阿里云·华为云
阿杰 AJie7 分钟前
MyBatis-Plus 比较运算符
java·数据库·mybatis
码农幻想梦8 分钟前
实验六 AOP,JdbcTemplate及声明式事务
java·开发语言·数据库
砚边数影9 分钟前
金仓数据库KDMS助力某能源集团完成20TB时序数据智能迁移,效率提升显著、年省运维成本超千万元
运维·数据库·能源·时序数据库·数据库平替用金仓·金仓数据库·kdms
齐 飞10 分钟前
springboot整合shardingsphere-jdbc5.1.1-按月分表
数据库·spring boot
勇气要爆发34 分钟前
向量数据库 Milvus 极速入门:从 Docker 部署到 Python 增删改查实战
数据库·docker·milvus
xuefuhe35 分钟前
如何连接到postgresql数据库
数据库
好好学操作系统37 分钟前
notion+excel自动创建表格| 了解了notion api
数据库·python·oracle·excel·notion