mysql实战之 批量update
mysql实战之批量update
现阶段我们的业务量很小,要对admin_user表中的relationship字段进行更新,指定id是409。已知409是公司内的一服务中心,需要把该服务中心放到区代下面, 区代id是3486,相关字段是paren_id(父子级别关系),需要把409已经409旗下所有商家以及客户都转移到3486下面,这个对应字段是relationship ,业务介绍完毕,下面来实战操作:
查看各个id现在的relationship情况
mysql> SELECT relationship FROM admin_user WHERE parent_id=409;
+-------------------------+
| relationship |
+-------------------------+
| ,1,30,304,405,409,437, |
| ,1,30,304,405,409,450, |
| ,1,30,304,405,409,464, |
| ,1,30,304,405,409,465, |
| ,1,30,304,405,409,471, |
| ,1,30,304,405,409,505, |
| ,1,30,304,405,409,540, |
| ,1,30,304,405,409,793, |
| ,1,30,304,405,409,794, |
| ,1,30,304,405,409,1801, |
| ,1,30,304,405,409,1802, |
| ,1,30,304,405,409,1949, |
| ,1,30,304,405,409,2015, |
+-------------------------+
13 rows in set (0.02 sec)
mysql> SELECT relationship FROM admin_user WHERE parent_id=3486;
+---------------------+
| relationship |
+---------------------+
| ,1,30,304,3486,409, |
+---------------------+
1 row in set (0.02 sec)
现在就是要把parent_id=409 的relationship中’,1,30,304,405,409,437,’所有的409换成3486,
笨方法:一条一条的update,但是业务量小,这样可以实现,假如是几万条数据的话这样操作是不可取的,还有手动更改某一个数很难保证正确性。
UPDATE admin_user SET relationship=',1,30,304,405,3486,437,' WHERE id=437;
UPDATE admin_user SET relationship=',1,30,304,405,3486,450,' WHERE id=450;
UPDATE admin_user SET relationship=',1,30,304,405,3486,464,' WHERE id=464;
。。。。。。。。。。。
其实我就是用这样的方法去更新的,后来经过领导指点采取新的方法实现一条语句更新来实现业务,
使用到的是连接函数concat,查看语法
mysql> help concat
Name: 'CONCAT'
Description:
Syntax:
CONCAT(str1,str2,...)
Returns the string that results from concatenating the arguments. May
have one or more arguments. If all arguments are nonbinary strings, the
result is a nonbinary string. If the arguments include any binary
strings, the result is a binary string. A numeric argument is converted
to its equivalent nonbinary string form.
CONCAT() returns NULL if any argument is NULL.
URL: http://dev.mysql.com/doc/refman/5.6/en/string-functions.html
Examples:
mysql> SELECT CONCAT('My', 'S', 'QL');
-> 'MySQL'
mysql> SELECT CONCAT('My', NULL, 'QL');
-> NULL
mysql> SELECT CONCAT(14.3);
-> '14.3'
我需要替换掉最左边之前的字符,都是固定的,先写下查询的sql语句试试,
mysql> SELECT CONCAT(',1,30,304,3486,409,',RIGHT(relationship,LENGTH(relationship)-LENGTH(',1,30,304,405,409,'))) AS r1,relationship FROM admin_user WHERE relationship LIKE ',1,30,304,405,409,%';
+--------------------------+-------------------------+
| r1 | relationship |
+--------------------------+-------------------------+
| ,1,30,304,3486,409,437, | ,1,30,304,405,409,437, |
| ,1,30,304,3486,409,450, | ,1,30,304,405,409,450, |
| ,1,30,304,3486,409,464, | ,1,30,304,405,409,464, |
| ,1,30,304,3486,409,465, | ,1,30,304,405,409,465, |
| ,1,30,304,3486,409,471, | ,1,30,304,405,409,471, |
| ,1,30,304,3486,409,505, | ,1,30,304,405,409,505, |
| ,1,30,304,3486,409,540, | ,1,30,304,405,409,540, |
| ,1,30,304,3486,409,793, | ,1,30,304,405,409,793, |
| ,1,30,304,3486,409,794, | ,1,30,304,405,409,794, |
| ,1,30,304,3486,409,1801, | ,1,30,304,405,409,1801, |
| ,1,30,304,3486,409,1802, | ,1,30,304,405,409,1802, |
| ,1,30,304,3486,409,1949, | ,1,30,304,405,409,1949, |
| ,1,30,304,3486,409,2015, | ,1,30,304,405,409,2015, |
+--------------------------+-------------------------+
13 rows in set (0.01 sec)
很显然,r1就是我想要的结果,下面可以更改成一个更新语句了,
mysql> update admin_user set relationship=concat(',1,30,304,3486,409,',RIGHT(relationship,LENGTH(relationship)-LENGTH(',1,30,304,405,409,'))) where relationship LIKE ',1,30,304,405,409,%';
Query OK, 13 rows affected (0.05 sec)
Rows matched: 13 Changed: 13 Warnings: 0
mysql> select relationship from admin_user where parent_id=409;
+--------------------------+
| relationship |
+--------------------------+
| ,1,30,304,3486,409,437, |
| ,1,30,304,3486,409,450, |
| ,1,30,304,3486,409,464, |
| ,1,30,304,3486,409,465, |
| ,1,30,304,3486,409,471, |
| ,1,30,304,3486,409,505, |
| ,1,30,304,3486,409,540, |
| ,1,30,304,3486,409,793, |
| ,1,30,304,3486,409,794, |
| ,1,30,304,3486,409,1801, |
| ,1,30,304,3486,409,1802, |
| ,1,30,304,3486,409,1949, |
| ,1,30,304,3486,409,2015, |
+--------------------------+
13 rows in set (0.02 sec)
搞定,期间我尝试过用when case来实现这个业务,跟单个update一样繁琐,就这13条数据也看不出来有多效率,所以还是这个拼接替换好用,菜鸟级水平奉上。
mysql实战之 批量update的更多相关文章
- mysql语句:批量更新多条记录的不同值[转]
mysql语句:批量更新多条记录的不同值 mysql更新语句很简单,更新一条数据的某个字段,一般这样写: 帮助 1 UPDATE mytable SET myfield = 'value' WHERE ...
- MyBatis魔法堂:各数据库的批量Update操作
一.前言 MyBatis的update元素的用法与insert元素基本相同,因此本篇不打算重复了.本篇仅记录批量update操作的sql语句,懂得SQL语句,那么MyBatis部分的操作就简单了. ...
- centos mysql 实战 第一节课 安全加固 mysql安装
centos mysql 实战 第一节课 安全加固 mysql安装 percona名字的由来=consultation 顾问+performance 性能=per con a mysql ...
- mysql 如何提高批量导入的速度
mysql 如何提高批量导入的速度 最近一个项目测试,有几个mysql数据库的表数据记录达到了几十万条,在搭建测试环境 导入 测试数据时,十分慢.在网上搜索了一下,有下面一些方法可以加快mysql数据 ...
- MySQL实战 | 03 - 谁动了我的数据:浅析MySQL的事务隔离级别
原文链接:这一次,带你搞清楚MySQL的事务隔离级别! 使用过关系型数据库的,应该都事务的概念有所了解,知道事务有 ACID 四个基本属性:原子性(Atomicity).一致性(Consistency ...
- mybatis批量update操作的写法,及批量update报错的问题解决方法
mybatis的批量update操作写法很简单,如下: public interface YourMapper extends BaseMapper<YourExt> { void upd ...
- 极客时间 Mysql实战45讲 07讲行锁功过:怎么减少行锁对性能的影响笔记 极客时间
极客时间 Mysql实战45讲 07讲行锁功过:怎么减少行锁对性能的影响笔记 极客时间极客时间 Mysql实战45讲 07讲行锁功过:怎么减少行锁对性能的影响笔记 极客时间 笔记体会: 方案一,事务相 ...
- MySQL实战45讲学习笔记:第十五讲
一.引子 在今天这篇答疑文章更新前,MySQL 实战这个专栏已经更新了 14 篇.在这些文章中,大家在评论区留下了很多高质量的留言.现在,每篇文章的评论区都有热心的同学帮忙总结文章知识点,也有不少同学 ...
- MySQL实战45讲学习笔记:第三十九讲
一.本节概况 MySQL实战45讲学习笔记:自增主键为什么不是连续的?(第39讲) 在第 4 篇文章中,我们提到过自增主键,由于自增主键可以让主键索引尽量地保持递增顺序插入,避免了页分裂,因此索引更紧 ...
随机推荐
- golang DynamoDB sdk AccessDeniedException
golang调用aws sdk时候提示: AccessDeniedException: User: arn:aws:sts::818539432014:assumed-role/bj-develop/ ...
- OC----面向对象
创建一个类 comm+n 实例变量的可见度 @public,@protect@private @public // 共有的,在类的内部和外部都可以进行访问 @protected // 受保护的, ...
- Magento后台简单更换favicon.ico
刚才需要更换网站的favicon.ico,就是浏览器url前面的那个小图标. 网上稍微搜搜一下,然后就震惊了,号多方法是替换文件的方法,而且文件散步在网站的各个角落. 其实,后台是有直接上传更换的方法 ...
- iOS真机运行 Xcode报错(libpng error: CgBI: unhandled critical chunk)问题已解决;
Cocos2d-x加载图片资源出现libpng error: CgBI: unhandled critical chunk Xcode7.3 设置Remove Text Metadata From P ...
- html页面定位
对于css中的position:relative;我始终搞不明白它是什么意思,有什么作用? 对于position的其它几个属性,我都搞懂了 引用 static : 无特殊定位,对象遵循HTML定位规则 ...
- redhat note
1,iptables -I INPUT 5 -m state --state NEW -p tcp --dport 80 -j ACCEPT
- LinQ 组合查询与分页
1.以开头查 public List<Car> Select1(string a){ return con.Car.Where(r => r.Name.StartsWith(a)). ...
- Activityn 生命周期
前言 Activity 生命周期,虽然开发android 程序有几年了,但是很多基本东西还是经常遗忘模糊,在此笔记白纸黑字记录,下次记忆模糊的时候温故知新.网上一搜索一大把,但是多是一大堆各种日志搅来 ...
- HDU-1257 导弹拦截系统 http://acm.hdu.edu.cn/showproblem.php?pid=1257
Problem Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高 ...
- Windows Phone 十二、设计器同步
在设计阶段为页面添加数据源 Blend或者VS的可视化设计器会跑我们的代码,然后来显示出来,当我们Build之后,设计器会进入页面的构造函数,调用InitializeComponent();方法来将U ...