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

【小技巧】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)是否实际影响了数据库中的行,返回值为受影响的行数。


http://www.kler.cn/news/338991.html

相关文章:

  • python爬虫 - 进阶requests模块
  • 【机器学习-无监督学习】降维与主成分分析
  • 命名管道Linux
  • Stable Diffusion绘画 | 如何做到不同动作表情,人物角色保持一致性(下篇)
  • 深度学习中的迁移学习:预训练模型微调与实践
  • 2024年liunx安装openvino非源码编译版(比源码编译简单!)
  • APP自动化搭建与应用
  • Linux 学习
  • 推荐!专业Substance 3D Painter v10.解锁版下载及安装 (3D绘画软件)
  • 最大异或对(每周一类)
  • 常用动词敬语形式大揭秘,柯桥零基础日语培训
  • 【C#生态园】提升C#图像处理与压缩效率:六款库全面比较
  • jQuery EasyUI 扩展
  • cmakelist加载Qt模块
  • 定时器定时中断定时器外部中断
  • Qt 图片显示 动态选择图片显示
  • 基于springboot的家政服务管理系统(含源码+sql+视频导入教程+文档+PPT)
  • ctfshow-web入门(信息收集,持续更新中。。)
  • JavaSE - 基础语法
  • 【Qt】控件概述(2)—— 按钮类控件