当前位置: 首页 > backend >正文

SQL通用增删改查

零、文章目录

SQL通用增删改查

1、DML基础概念

(1)定义与作用
  • DML(Data Manipulation Language)用于操作数据库中的数据,核心功能包括数据的插入、更新、删除。
  • 与 DQL(查询)不同,DML 直接修改数据存储。
(2)主要操作类型
  • INSERT:向表中插入新数据
  • UPDATE:修改已有数据
  • DELETE:删除指定数据

2、数据增删改

(1)插入数据(INSERT)
-- 指定列插入 
INSERT INTO 表名 (1,2) 
VALUES (1,2);-- 全列插入(需按表结构顺序)
INSERT INTO 表名 
VALUES (1,2,3);-- 批量插入 
INSERT INTO 表名 (1,2)
VALUES (值A1, 值A2),(值B1, 值B2);
  • 注意事项:
    • 未指定列时默认插入所有字段,需确保值顺序与表结构一致
    • 批量插入可提升性能,但需注意单次操作的数据量限制
(2)更新数据(UPDATE)
UPDATE 表名 
SET1=新值1,2=新值2 
WHERE 条件;  -- 无WHERE则更新全表 -- 示例:带计算表达式 
UPDATE products 
SET price = price * 0.9 
WHERE category = '清仓区';
  • 关键点:
    • WHERE子句必须谨慎使用,避免误改全表数据
    • 支持通过子查询更新多表关联数据(如 UPDATE ... FROM ... 语法)
(3)删除数据(DELETE)
DELETE FROM 表名 
WHERE 条件;  -- 无WHERE则清空表 -- 清空表(DDL操作,不可回滚)
TRUNCATE TABLE 表名;
  • 区别对比:
操作可回滚性性能触发器触发
DELETE较慢
TRUNCATE极快
(4)事务控制(TRANSACTION)
  • DML 操作需配合事务语句保证原子性:
BEGIN TRANSACTION;
UPDATE accounts SET balance = balance - 100 WHERE id = 1;
UPDATE accounts SET balance = balance + 100 WHERE id = 2;
COMMIT;  -- 或 ROLLBACK 回滚
(5)注意事项
  • 更新/删除前通过 SELECT 验证条件准确性
  • 生产环境禁止无 WHERE 的 UPDATE/DELETE 操作
  • 重要数据操作前备份表(如 CREATE TABLE backup AS SELECT * FROM target

3、DQL 基础概念

(1)定义与作用
  • DQL(Data Query Language)用于从数据库中检索数据,核心语句是 SELECT
  • 它是 SQL 四大子语言之一(与 DDL、DML、DCL 并列),不修改数据,仅提供查询结果。
(2)通用语法结构
SELECT [DISTINCT]1,2, 聚合函数(...)  
FROM 表名 
[WHERE 条件] 
[GROUP BY 分组列] 
[HAVING 分组后条件] 
[ORDER BY 排序列 [ASC|DESC]] 
[OFFSET 分页参数];
(3)执行顺序
  • 非编写顺序:FROMWHEREGROUP BYHAVINGSELECTORDER BYOFFSET

4、数据查询

(1)基础查询(SELECT)
  • 查询指定列:SELECT name, age FROM employees;
  • 查询所有列:SELECT * FROM employees;(谨慎使用,可能影响性能)
  • 别名设置:SELECT salary AS 月薪 FROM employees;
  • 去重:SELECT DISTINCT department FROM employees;
(2)条件筛选(WHERE)
  • 运算符:=, >, <, BETWEEN, IN, LIKE, IS NULL
    示例:
SELECT * FROM employees 
WHERE age > 30 AND department = 'Sales';
  • 模糊查询:
    • LIKE '张%':以“张”开头的字符串
    • LIKE '%X':以“X”结尾的字符串(如身份证号)
(3)聚合函数与分组(GROUP BY)
聚合函数作用示例
COUNT()统计行数SELECT COUNT(*) FROM employees;
SUM()计算数值列总和SELECT SUM(salary) FROM employees;
AVG()计算平均值SELECT AVG(age) FROM employees;
MAX()/MIN()获取最大/最小值SELECT MAX(salary) FROM employees;
  • 分组统计:
SELECT department, AVG(salary) AS avg_salary 
FROM employees
GROUP BY department 
HAVING AVG(salary) > 10000;  -- HAVING 筛选分组结果 
  • WHERE vs HAVING:
    • WHERE:在分组前过滤,不可用聚合函数
    • HAVING:在分组后过滤,可用聚合函数
(4)排序与分页(ORDER BY)
  • 排序(ORDER BY):
SELECT * FROM employees 
ORDER BY salary DESC, name ASC; -- 先按薪资降序,再按姓名升序
  • 分页标准 SQL:OFFSET 起始行 FETCH NEXT 条数 ROWS ONLY
(5)多表连接查询(JOIN)
连接类型语法示例作用
内连接(INNER JOIN)SELECT * FROM A INNER JOIN B ON A.id=B.id返回两表匹配的行
左连接(LEFT JOIN)SELECT * FROM A LEFT JOIN B ON A.id=B.id返回左表全部 + 右表匹配行
右连接(RIGHT JOIN)SELECT * FROM A RIGHT JOIN B ON A.id=B.id返回右表全部 + 左表匹配行
全连接(FULL JOIN)SELECT * FROM A FULL JOIN B ON A.id=B.id返回两表所有行(MySQL 需用 UNION 模拟)
(6)子查询
  • 嵌套在 WHERE/FROM/SELECT 中的查询
SELECT name 
FROM employees 
WHERE salary > (SELECT AVG(salary) FROM employees); 
(7)联合查询(UNION)
  • UNION:合并多个查询结果(自动去重)
  • UNION ALL:保留重复结果
SELECT city FROM table1 
UNION 
SELECT city FROM table2;
http://www.xdnf.cn/news/15969.html

相关文章:

  • 如何使用电脑连接小米耳机(红米 redmi耳机)
  • 学习秒杀系统-异步下单(包含RabbitMQ基础知识)
  • RS485和Modbus
  • 全新开发范式:uni-app X助力全平台原生应用
  • 前端,demo操作,增删改查,to do list小项目
  • 网络编程及原理(八)网络层 IP 协议
  • 企业开发转型 | 前端AI化数字化自动化现状
  • C语言字符串相关函数
  • 若依开源框架相关
  • Telink BLE 低功耗学习
  • 板凳-------Mysql cookbook学习 (十二--------3_2)
  • STM32小实验四--按键控制LED灯
  • Android Navigation 组件:简化应用导航的利器
  • Nacos中feign.FeignException$BadGateway: [502 Bad Gateway]
  • Node.js- node管理工具nvm
  • ansible批量部署zabbix客户端
  • 过往记录系列 篇七:大A突破3500点历史梳理
  • 【MySQL】Linux配置MySQL Windows远程连接
  • day27 力扣332.重新安排行程 力扣51. N皇后 力扣37. 解数独 力扣455.分发饼干 力扣376. 摆动序列 力扣53. 最大子序和
  • 【爬虫】06 - 自动化爬虫selenium
  • 二分查找-35.搜索插入位置-力扣(LeetCode)
  • HTML前端颜色渐变动画完整指南
  • IFN影视官网入口 - 4K影视在线看网站|网页|打不开|下载
  • 数据结构-哈希表(一)哈希函数、哈希表介绍、优缺点
  • 解决 Ant Design v5.26.5 与 React 19.0.0 的兼容性问题
  • vue3实现可视化大屏布局
  • Redis入门教程(一):基本数据类型
  • k8s知识点
  • 3x3矩阵教程
  • 第十八节:第七部分:java高级:注解的应用场景:模拟junit框架