【小技巧】mysql 判断表字段是否存在 删除字段 sql脚本

MySQL 判断表字段是否存在 删除字段 sql脚本

下面是一个包含插入和更新操作的流程:

-- 先尝试插入数据
INSERT IGNORE INTO user_info (last_name, first_name)
VALUES ('x', 'y');

-- 如果插入成功,ROW_COUNT() 返回 1,否则返回 0
IF ROW_COUNT() = 0 THEN
    -- 数据已存在,执行更新操作
    UPDATE user_info 
    SET last_name = 'new_last_name', first_name = 'new_first_name'
    WHERE last_name = 'x' AND first_name = 'y';
END IF;

ROW_COUNT使用

ROW_COUNT() 是 MySQL 中的一个函数,它返回上一个 SQL 语句所影响的行数。它是根据执行的操作类型返回相应的行数。具体情况如下:

  • 对于 INSERTUPDATEDELETE 操作,ROW_COUNT() 返回受影响的行数。
  • 对于 SELECT 语句,它返回结果集中的行数(不过在某些情况下可能不适用,因为 ROW_COUNT() 更常用于数据更改语句)。
  • 如果上一个语句没有影响任何行(如 INSERT IGNORE 遇到重复数据没有插入),ROW_COUNT() 返回 0。

常见返回值

  1. INSERT 操作

    • 如果成功插入数据,ROW_COUNT() 返回插入的行数。
    • 如果使用 INSERT IGNORE,当遇到唯一约束冲突而没有插入数据时,ROW_COUNT() 返回 0。
  2. UPDATE 操作

    • 如果成功更新数据,ROW_COUNT() 返回更新的行数。
    • 如果没有匹配的行或者更新后的数据和原来相同,ROW_COUNT() 返回 0。
  3. DELETE 操作

    • 如果成功删除数据,ROW_COUNT() 返回删除的行数。
    • 如果没有找到需要删除的行,ROW_COUNT() 返回 0。

举例说明

1. INSERT IGNORE 示例
INSERT IGNORE INTO user_info (last_name, first_name) VALUES ('x', 'y');

-- 假设 ('x', 'y') 已经存在,此时不会插入数据,ROW_COUNT() 返回 0
SELECT ROW_COUNT();  -- 返回 0
2. UPDATE 示例
UPDATE user_info SET last_name = 'z' WHERE last_name = 'x';

-- 假设匹配到了 2 条记录并进行了更新,ROW_COUNT() 返回 2
SELECT ROW_COUNT();  -- 返回 2
3. DELETE 示例
DELETE FROM user_info WHERE last_name = 'nonexistent';

-- 假设没有找到匹配的记录,ROW_COUNT() 返回 0
SELECT ROW_COUNT();  -- 返回 0

总结来说,ROW_COUNT() 用于检查前一个数据操作(INSERT、UPDATE、DELETE)是否实际影响了数据库中的行,返回值为受影响的行数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

界王拳十倍

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值