日常项目中常见表中两个字段有一些数据存值相反导致业务错误,这个时候需要脚本执行把数据替换。
小编下面的sql语句是把test表中员工编号和员工编码存在错误的数据替换,错误数据的条件是员工编码存的员工姓名,员工姓名存的员工编码。这时候用到了regexp这个函数,判断字段里是否是汉字还是数值,是数字返回0汉字返回1,下面是脚本
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
)