Mysql中如何实现两列的值互换

 更新时间:2024年11月11日 11:34:29   作者:无敌小肥007  
这篇文章主要来和大家探讨一下Mysql中如何实现两列的值互换,文中为大家提供了一些常用的方法,希望对大家有一定的帮助

Mysql中如何实现两列的值互换

如图,因业务要求,需要把某两列的值互换。

1、第一感觉此sql应该能处理问题了

UPDATE students
SET name = other_name,
    other_name = name;

结果是这样。。。没搞定

2、需要一个地方存要替换的值,不然两列搞不定

2.1 加第三列?(能解决,但是看起来呆呆)

-- 新增列
ALTER TABLE students
ADD COLUMN swap_col VARCHAR(255);

-- 赋值
UPDATE students
SET swap_col = other_name;

UPDATE students
SET other_name = name;

UPDATE students
SET name = swap_col;

-- 删除列
ALTER TABLE students
DROP COLUMN swap_col;
-- 

2.2 上临时表(搞点弯路走走)

-- 创建临时表
CREATE TEMPORARY TABLE `students_temp`
(
    `id`         int,
    `name`       varchar(255),
    `other_name` varchar(255),
    INDEX `idx_id` (`id`),
    INDEX `idx_name` (`name`),
    INDEX `idx_other_name` (`other_name`)
);

-- 给临时表赋值
INSERT INTO students_temp
SELECT id, name, other_name
FROM students;

-- 联表更新
UPDATE students AS target
    INNER JOIN students_temp AS source
    ON target.id = source.id
SET target.name       = source.other_name,
    target.other_name = source.name;

-- 删除临时表
DROP TABLE students_temp;

示例sql

DROP table if exists `students`;

CREATE TABLE `students` (
  `id` int NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  `other_name` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE
);

INSERT INTO `students` VALUES (1, '张三', '张三1');
INSERT INTO `students` VALUES (2, '李四', '李四1');
INSERT INTO `students` VALUES (3, '王五', '王五1');
INSERT INTO `students` VALUES (4, '赵六', '赵六');
INSERT INTO `students` VALUES (5, '孙七', '孙七');
INSERT INTO `students` VALUES (6, '张三', '张三2');
INSERT INTO `students` VALUES (7, '李四', '李四2');
INSERT INTO `students` VALUES (8, '张三', '张三3');

到此这篇关于Mysql中如何实现两列的值互换的文章就介绍到这了,更多相关Mysql两列值互换内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL用户权限验证与管理方法详解

    MySQL用户权限验证与管理方法详解

    这篇文章主要介绍了MySQL用户权限验证与管理方法,结合实例形式详细分析了mysql针对用户权限的验证、查看、收回、修改等各种常用操作技巧,需要的朋友可以参考下
    2018-04-04
  • mysql 5.7.10 winx64安装配置方法图文教程(win10)

    mysql 5.7.10 winx64安装配置方法图文教程(win10)

    这篇文章主要为大家分享了mysql 5.7.10 winx64安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • MySQL使用MD5加密算法进行数据加密功能

    MySQL使用MD5加密算法进行数据加密功能

    在现代的数据库应用中,数据的安全性和隐私性变得尤为重要,MySQL作为最流行的关系型数据库之一,提供了多种加密功能,允许用户对数据进行加密和解密操作,在这篇文章中,我们将深入探讨MySQL的加密功能,并重点介绍如何使用MD5加密算法进行加密,需要的朋友可以参考下
    2024-12-12
  • insert和select结合实现

    insert和select结合实现"插入某字段在数据库中的最大值+1"的方法

    今天小编就为大家分享一篇关于insert和select结合实现"插入某字段在数据库中的最大值+1"的方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • mysql与mysqli的区别与用法说明

    mysql与mysqli的区别与用法说明

    mysql是非持继连接函数而mysqli是永远连接函数。
    2010-07-07
  • Mysql exists用法小结

    Mysql exists用法小结

    这篇文章主要介绍了Mysql exists用法的的相关资料,帮助大家更好的理解和使用MySQL,感兴趣的朋友可以了解下
    2020-12-12
  • MySQL主从复制搭建流程分步实现

    MySQL主从复制搭建流程分步实现

    这篇文章主要介绍了MySQL的主从复制原理详细分析,读写分离是基于主从复制来实现的。文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-11-11
  • Mysql忘记密码怎么重置密码的几种实现方法

    Mysql忘记密码怎么重置密码的几种实现方法

    本文主要介绍了Mysql忘记密码怎么重置密码的几种实现方法,每种方法都有其适用的情况,根据具体情况选择合适的方法,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • MySQL REVOKE实现删除用户权限

    MySQL REVOKE实现删除用户权限

    在 MySQL 中,可以使用 REVOKE 语句删除某个用户的某些权限,本文就详细的来介绍一下REVOKE 的具体使用方法,感兴趣的可以了解一下
    2021-06-06
  • MySQL中查询当前时间间隔前1天的数据

    MySQL中查询当前时间间隔前1天的数据

    实际项目中我们都会遇到分布式定时任务执行的情况,今天通过本文给大家分享MySQL中查询当前时间间隔前1天的数据,查询sql语句给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧<BR>
    2021-12-12

最新评论