mysql如何交换两列的值

sql 复制代码
    create table test.student(
	id int(11) auto_increment primary key,
	name varchar(255),
	des  varchar(255)
)

insert into test.student(name,des) values
('desc1','name1'),
('desc2','name2'),
('desc3','name3'),
('desc4','name4'),
('desc5','name5'),
('desc6','name6'),
('desc7','name7'),
('desc8','name8'),
('desc9','name9')

select * from test.student;

如上图所示name和des两列数据错位了。如何修复了。

最开始的想法

update test.student set name=des ,des=name

发现结果 好像是先把des赋值给name了,然后再执行set des=name所以数据不对。

如何解决呢?我看到网上有几种方法

1.多加一列 比如add column tmp , set tmp=des,des=name,name=tmp

2.使用一个临时表 具体也没看。

我才用另外一种方法

update test.student t1 inner join test.student t2 on t1.id=t2.id set t1.name=t2.name ,t1.des=t2.des

简单的一个思路,唯一注意的是要注意on的关联条件,使用主键关联

相关推荐
加勒比之杰克7 分钟前
【数据库初阶】数据库基础知识
数据库·adb
林农8 分钟前
C05S16-MySQL高可用
linux·mysql·云计算
后端转全栈_小伵9 分钟前
MySQL外键类型与应用场景总结:优缺点一目了然
数据库·后端·sql·mysql·学习方法
码中小白鼠9 分钟前
Ubuntu系统部署Mysql8.0后设置不区分大小写
linux·mysql·ubuntu·adb
自律的kkk37 分钟前
mysql基础快速入门
java·数据库·mysql·oracle
Andy01_1 小时前
Java八股汇总【MySQL】
java·开发语言·mysql
阿杰同学1 小时前
如何实现 MySQL 的读写分离?
数据库·mysql
weisian1512 小时前
Redis篇--应用篇3--数据统计(排行榜,计数器)
数据库·redis·缓存
羊村懒哥2 小时前
mysql-二进制安装方式
数据库·mysql
言之。2 小时前
Redis单线程快的原因
数据库·redis·缓存