【百日精通JAVA | SQL篇 | 第三篇】 MYSQL增删改查

SQL得最核心就是增删改查

一个后端开发,在工作中,最常见的场景就是CRUD。

插入数据

sql 复制代码
insert into student values (1,'zhangsan');

指定列插入数据

同时多个列明之间使用逗号,来分割

sql 复制代码
insert into student (name) values ('zhaoliu');

这个黑框是客户端,通过SQL语句对服务器中的数据进行改变,服务器再返回效果。

为什么说select * 是一个非常危险的操作?

如果该表中的数据特别多,select * 一瞬间服务器访问,疯狂的访问硬盘,导致一瞬间服务器,硬盘的带宽和网卡的带宽都吃满了。如果服务器还在给其他

这一种访问方式,其实查看的是临时数据;同时临时表中的数据和原始表中的数据,不一定完全一致。

SQL字段查询的时候,可以对其进行起别名,列明、表明 都可起名别,使用as关键字,但是查询到的结果也是临时。

按照列名升序排序

编程当中,= 为复制,但是在SQL语言中 表示比较相等。

MYSQL在查询语句中,查询的列名起别名后,在where子句当中不可使用,否则报错。

看似在MYSQL设计中,完全可以让where子句,能够识别出别名,但是现在mysql一直没有支持。

站在sql的执行顺序上,也能一定程度的解释上述现象。

select语句执行顺序:

1.遍历到某个指定的行

2.带入条件筛选

3.条件为true,被筛选成功之后,再计算select列明这里的表达式。

模糊查询

sql 复制代码
select * from exam_result where name like '%孙%';

空值查询

如果直接查询 xxx = NULL ,这种结果值为false,无法筛选出

我们使用 xxx <=> NULL 或者 xxx is NULL 的方法来查询结果

limit限制显示信息

这句代码的意思,一次查询最多显示4条记录。

sql 复制代码
select  * from exam_result limit 4;

SQL中的delete删除语句,是按照行数据来删除的, 无法来按照列删除

键值设置

not null 不允许空值

unique 唯一不允许存在两行数据,在这个指定列上重复

相关推荐
weixin_457885821 小时前
智能多媒体处理流水线——基于虎跃办公API的自动化解决方案
运维·数据库·人工智能·ai·自动化
一切皆有迹可循1 小时前
IntelliJ IDEA中Spring Boot项目整合MyBatis:从零实现高效数据持久化
java·spring boot·intellij-idea·mybatis
雾月553 小时前
LeetCode 941 有效的山脉数组
java·开发语言·数据结构·算法·leetcode·职场和发展
狮歌~资深攻城狮4 小时前
ClickHouse进阶技巧:解锁数据处理的高级潜能
大数据·数据库
小诸葛的博客5 小时前
Apache BookKeeper Ledger 的底层存储机制解析
java
极限实验室5 小时前
Easysearch VS Opensearch 数据写入与存储性能对比
数据库
半旧5185 小时前
重构谷粒商城11:node快速入门
java·前端·重构
嘤国大力士5 小时前
C++11&QT复习 (十六)
java·开发语言·c++
菜鸟起航ing6 小时前
【Java面试系列】Spring Boot中自动配置原理与自定义Starter开发实践详解 - 3-5年Java开发必备知识
java·spring boot·面试·自动配置·自定义starter
李白的粉6 小时前
基于springboot+vue的课程管理系统
java·毕业设计·课程设计·源代码·课程管理系统