sql增删改查怎么写?有时会不会有联表查询的增删查改

SQL 的增删改查(CRUD)是数据库操作的核心。针对你的问题,我先为你梳理基础单表的写法,再重点解答"联表查询的增删改查"该怎么实现。

📝 SQL 基础单表增删改查

假设我们有一张用户表 user,包含 id, username, age, phone 等字段:

  • 增 (INSERT) :向表中添加新记录。

    sql 复制代码
    -- 插入单条数据
    INSERT INTO user (username, age, phone) VALUES ('张三', 25, '13800000000');
    -- 批量插入多条数据
    INSERT INTO user (username, age, phone) VALUES ('李四', 22, '13900000000'), ('王五', 30, '13700000000');
  • 删 (DELETE) :删除表中的记录。切记带上 WHERE 条件!

    sql 复制代码
    DELETE FROM user WHERE id = 1;
  • 改 (UPDATE) :修改表中已有的数据。同样必须带 WHERE 条件!

    sql 复制代码
    UPDATE user SET age = 26, phone = '13811111111' WHERE username = '张三';
  • 查 (SELECT) :从表中检索数据。

    sql 复制代码
    SELECT id, username, age FROM user WHERE age > 20 ORDER BY age DESC;

🔗 联表查询的增删改查

是的,SQL 完全支持联表进行增、删、改、查。 这在处理多张关联表(比如订单表和商品表、用户表和部门表)的业务时非常常见。

1. 联表查询 (JOIN SELECT)

这是最常用的一种。当你需要从两张或多张表中获取数据时使用,核心关键字是 JOIN

sql 复制代码
-- 查询订单信息,并带出下单用户的名字
SELECT o.order_no, u.username, o.amount
FROM orders o
JOIN user u ON o.user_id = u.id  -- 通过 user_id 将订单表和用户表关联起来
WHERE o.status = 1;
2. 联表更新 (JOIN UPDATE)

当你需要根据另一张表的数据来更新当前表,或者同时更新多张表时使用。

sql 复制代码
-- 场景:当支付表(payments)中有记录时,把订单表(orders)的状态改为已支付('paid')
UPDATE orders o
JOIN payments p ON o.id = p.order_id
SET o.status = 'paid'
WHERE p.payment_time IS NOT NULL;

(注:不同数据库的联表更新语法略有差异,上述为 MySQL 常见写法)

3. 联表删除 (JOIN DELETE)

可以根据关联表的条件来删除主表的数据,甚至可以一次性删除多张表的数据。

sql 复制代码
-- 场景:删除用户表(user)中,在日志表(user_logs)里超过一年没有活跃记录的用户
DELETE u 
FROM user u
JOIN user_logs ul ON u.id = ul.user_id
WHERE ul.last_active_time < '2025-01-01';

⚠️ 高危提醒 :联表删除和更新一样,破坏力极强。在生产环境中执行前,务必先用同样的 JOIN 条件写一条 SELECT 语句,确认筛选出的数据确实是你想要删除的,再进行操作!

4. 联表新增 (INSERT ... SELECT)

虽然不能像查询那样随意"JOIN着插入",但你可以把一个联表查询的结果集,整体插入到另一张表中。

sql 复制代码
-- 场景:年底了,把高薪员工的信息连同计算好的奖金,插入到奖金表(bonuses)中
INSERT INTO bonuses (employee_id, bonus_amount, reason)
SELECT e.id, e.salary * 0.2, '年度优秀员工奖金'
FROM employees e
JOIN departments d ON e.dept_id = d.id
WHERE d.dept_name = '技术部' AND e.salary > 20000;

在实际的 Java + MyBatis-Plus 开发中,简单的联表查询可以通过手写 XML 或注解 SQL 来实现;如果是复杂的联表更新或删除,很多开发者也会选择先在代码中查出 ID,再通过循环或批量操作来完成,这样逻辑会更清晰且安全。

相关推荐
Elastic 中国社区官方博客1 小时前
13.7万人,零人工决策:使用 Elasticsearch 实现智能体驱动的灾害响应系统
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
jingyu飞鸟2 小时前
openEuler 22.03 LTS SP4安装华为opengauss 22.03 LTS版本数据库,一键复制安装使用,保姆级教程
数据库·华为
IvorySQL2 小时前
【HOW 2026 分论坛演讲】PG/IvorySQL私有云中实践
数据库·人工智能·sql·postgresql
SAP庖丁解码2 小时前
【采购申请的校验——成本中心范围】
数据库
雪的季节2 小时前
HTTP 和 HTTPS 五大核心区别
数据库·http·https
GottdesKrieges2 小时前
OceanBase迁移用户及其权限配置
数据库·oceanbase
OceanBase数据库官方博客3 小时前
新版本 OceanBase seekdb 1.3.0:22倍性能增益,P99抖动小于1.1倍
数据库·oceanbase
倒流时光三十年3 小时前
PostgreSQL ON CONFLICT DO UPDATE 增加 WHERE 条件优化性能
数据库·postgresql
暴力求解3 小时前
MySQL---表的操作
数据库·mysql