将同一个表中的一个字段的值复制给另一个字段
UPDATE t_user SET signed_time = create_time
将同一个表中两个类型一样的字段的值互换
UPDATE t_user u1, t_user u2 SET u1.signed_time = u2.create_time, u2.create_time = u1.signed_time
-- 同一个表UPDATE table_a SET A=(SELECT B FROM (SELECT * FROM table_a) b WHERE b.id = table_a.id)-- 两个(一样的)表UPDATE table_a SET A = (SELECT B FROM table_b WHERE table_b.id= table_a.id)-- 例子-- UPDATE FY_MEDICINE_DIRECTION SET MEDICINE_NAME=(SELECT COMMON_NAME FROM (SELECT * FROM FY_MEDICINE_DIRECTION) b WHERE b.id = FY_MEDICINE_DIRECTION.id) WHERE SOURCES='参考《国家医保药品手册》(2017版)' AND MED_ISTATUS=1-- UPDATE message SET image=(SELECT istatus FROM (SELECT * FROM message) b WHERE b.id = message.id)
要求:
替换成
测试数据:
CREATE TABLE `test` ( `id` int(10) UNSIGNED NOT NULL AUTO_INCREMENT, `value` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL, PRIMARY KEY (`id`) USING BTREE) ENGINE = InnoDB AUTO_INCREMENT = 8 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;-- ------------------------------ Records of test-- ----------------------------INSERT INTO `test` VALUES (1, 'a');INSERT INTO `test` VALUES (2, 'b');INSERT INTO `test` VALUES (3, 'c');INSERT INTO `test` VALUES (4, 'd');INSERT INTO `test` VALUES (5, 'e');
以前以为set就是:key = value,没想到可以直接将两个字段放上去进行赋值。
UPDATE test SET value = id;-- 若有其他条件往后面添加就行 update table set field1 = field2 where ...
这种方法针对两个表的数据同步
update A inner join(select id,name from B) c on A.id = c.id set A.name = c.name;
用在这里就是创建一个临时表(将test表复制一份),然后使用这种方法。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持一聚教程网。
火柴人忍者3v3M0D版内置功能菜单 v5.5
下载重生细胞腾讯版 安卓版v3.5.2-bilibili-UO
下载拳皇命运体验服 最新免费版v2.31.000
下载地牢杀手无限生命版 内置修改器最新版v0.707.12
下载天天爱烹饪 安卓版1.1.1
天天爱烹饪是由润谦科技游戏厂商出品的美食烹饪餐厅模拟经营休闲
我的世界RLCraft任务汉化版 安卓版v2.9.1
我的世界RLCraft任务汉化版是一个非常有趣的整合包,游戏
光与夜之恋内测版 最新版v1.8.0803
光与夜之恋是一款女性向恋爱养成游戏,精美的画面,丰富的剧情故
光与夜之恋台服 安卓版v1.8.0803
光与夜之恋是一款高品质恋爱互动式养成游戏,超一线画师及豪华编
俄罗斯乡村模拟器3D 手机版v1.8.2
俄罗斯乡村模拟器(Russian Village Simul