數據庫SQL實戰(牛客網):將id=5以及emp_no=10001的行數據替換成id=5以及emp_no=10005

將id=5以及emp_no=10001的行數據替換成id=5以及emp_no=10005,其他數據保持不變,使用replace實現。
CREATE TABLE IF NOT EXISTS titles_test (
id int(11) not null primary key,
emp_no int(11) NOT NULL,
title varchar(50) NOT NULL,
from_date date NOT NULL,
to_date date DEFAULT NULL);

insert into titles_test values (‘1’, ‘10001’, ‘Senior Engineer’, ‘1986-06-26’, ‘9999-01-01’),
(‘2’, ‘10002’, ‘Staff’, ‘1996-08-03’, ‘9999-01-01’),
(‘3’, ‘10003’, ‘Senior Engineer’, ‘1995-12-03’, ‘9999-01-01’),
(‘4’, ‘10004’, ‘Senior Engineer’, ‘1995-12-03’, ‘9999-01-01’),
(‘5’, ‘10001’, ‘Senior Engineer’, ‘1986-06-26’, ‘9999-01-01’),
(‘6’, ‘10002’, ‘Staff’, ‘1996-08-03’, ‘9999-01-01’),
(‘7’, ‘10003’, ‘Senior Engineer’, ‘1995-12-03’, ‘9999-01-01’);

replace(x,y,z)作用是將字段x爲y的行替換成z

update titles_test set emp_no = replace(emp_no,10001,10005) where id=5;

參考牛客網的解法:

鏈接:https://www.nowcoder.com/questionTerminal/2bec4d94f525458ca3d0ebf3bc8cd240?f=discussion
來源:牛客網

本題運用 REPLACE 有兩種解法
方法一:全字段更新替換。由於 REPLACE 的新記錄中 id=5,與表中的主鍵 id=5 衝突,故會替換掉表中 id=5 的記錄,否則會插入一條新記錄(例如新插入的記錄 id = 10)。並且要將所有字段的值寫出,否則將置爲空。可參考:
http://blog.csdn.net/zhangjg_blog/article/details/23267761

1
REPLACE INTO titles_test VALUES (5, 10005, 'Senior Engineer', '1986-06-26', '9999-01-01')
方法二:運用REPLACE(X,Y,Z)函數。其中X是要處理的字符串,Y是X中將要被替換的字符串,Z是用來替換Y的字符串,最終返回替換後的字符串。以下語句用 UPDATEREPLACE 配合完成,用REPLACE函數替換後的新值複製給 id=5 的 emp_no。REPLACE的參數爲整型時也可通過。可參考:
http://www.cnblogs.com/huangtailang/p/5cfbd242cae2bcc929c81c266d0c875b.html
http://sqlite.org/lang_corefunc.html#replace

1
UPDATE titles_test SET emp_no = REPLACE(emp_no,10001,10005) WHERE id = 5
/** 另外可以利用OJ系統的漏洞,不用 REPLACE 實現  **/
1
UPDATE titles_test SET emp_no = 10005 WHERE id = 5
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章