MySQL同表不同字段互相替换

日常项目中常见表中两个字段有一些数据存值相反导致业务错误,这个时候需要脚本执行把数据替换。

小编下面的sql语句是把test表中员工编号和员工编码存在错误的数据替换,错误数据的条件是员工编码存的员工姓名,员工姓名存的员工编码。这时候用到了regexp这个函数,判断字段里是否是汉字还是数值,是数字返回0汉字返回1,下面是脚本

sql 复制代码
UPDATE test a,
 test b
SET a.USER_NO = b.USER_NO_NAME,
 a.USER_NO_NAME = b.USER_NO
WHERE
	a.id = b.id
AND a.id IN (
	SELECT
		id
	FROM
		(
			SELECT
				id,
				(
					USER_NO_NAME REGEXP '[^0-9.]'
				) AS data_flag,
				USER_NO_NAME
			FROM
				test
		) a
	WHERE
		data_flag = 0
)
相关推荐
R.lin8 小时前
windows MySQL解压版安装教程
windows·mysql·adb
前端小臻8 小时前
MySQL 错误 1005 (errno: 150) 深度解析与解决方案
数据库·mysql
Dev7z8 小时前
在MySQL里创建数据库
android·数据库·mysql
WZgold1418 小时前
黄金波动实战:如何利用三大交易时段捕捉每日行情
经验分享
invicinble9 小时前
mysql建立存数据的表(一)
android·数据库·mysql
spencer_tseng9 小时前
MySQL backup.bat
mysql
程序员水自流10 小时前
MySQL InnoDB存储引擎详细介绍之事务
java·数据库·mysql·oracle
Knight_AL10 小时前
MySQL STORED 生成列(Generated Column)详解:让 SQL 变快的秘密武器
数据库·sql·mysql
光羽隹衡11 小时前
MySQL的安装
数据库·mysql
脸大是真的好~11 小时前
尚硅谷-mysql专项训练-数据库服务的优化-慢查询-EXPLAIN字段
数据库·mysql·性能优化