前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL将查询的结果作为update更新的数据,且在原字段数据后 CONCAT拼接(lej)

MySQL将查询的结果作为update更新的数据,且在原字段数据后 CONCAT拼接(lej)

作者头像
全栈程序员站长
发布2022-07-19 12:25:26
7.1K0
发布2022-07-19 12:25:26
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是全栈君。

代码语言:javascript
复制
update user INNER JOIN 
(SELECT GROUP_CONCAT('',id)AS app_id_str  FROM `app` WHERE `admin_id` = '用户B的id' AND `status` > '0' AND `is_deleted` = '0' LIMIT 0,1000 ) app_id_strs 
set app_id= CONCAT(app_id,',',app_id_str) WHERE uid=用户A的id;

释义:

1.查询app表中状态大于0,未删除,且admin_id=用户Bid 用户的所有主键id,并用(,)逗号 拼接成字符串别名 app_id_strs ;

代码语言:javascript
复制
(SELECT GROUP_CONCAT('',id)AS app_id_str  FROM `app` WHERE `admin_id` = '用户B的id' AND `status` > '0' AND `is_deleted` = '0' LIMIT 0,1000 ) app_id_strs 

2.更新用户A 的app_id, 在A用户原有的app_id 后,用CONCAT,拼接上查询出来的app_id_strs,并在两者之间用(,)逗号连接

扩展:

二、mysql中update和select结合使用

在遇到需要update设置的参数来自从其他表select出的结果时,需要把update和select结合使用,不同数据库支持的形式不一样,在mysql中如下:

代码语言:javascript
复制
update A inner join(select id,name from B) c on A.id = c.id set A.name = c.name;

根据AB两个表的id相同为条件,把A表的name修改为B的sql语句就如上所示

三、update 和 select 结合使用进行数据更新,案例

现有两张表 inspect_dangercompany 表,根据 company 表的 IDinspect_danger 表的COMPANY_ID 匹配,把 company 表内的 INDUSTRY 更新到 inspect_danger表中。

代码语言:javascript
复制
UPDATE inspect_danger ins
LEFT JOIN (
    SELECT 
    com.ID,com.INDUSTRY,ip.ID insId
    FROM company com
    INNER JOIN  inspect_danger ip
    ON ip.COMPANY_ID = com.ID
    GROUP BY com.ID
) c 
ON ins.ID = c.insId
SET ins.COMPANY_INDUSTRY = c.INDUSTRY

四、做SQL查询时会经常需要,把查询的结果拼接成一个字符串。

解决方法: 通过 group_concat 函数

1.正常查询 如下:

代码语言:javascript
复制
select id result from ctp_enum_item limit 100;
MySQL将查询的结果作为update更新的数据,且在原字段数据后 CONCAT拼接(lej)
MySQL将查询的结果作为update更新的数据,且在原字段数据后 CONCAT拼接(lej)

2.拼接结果 如下

代码语言:javascript
复制
  select group_concat("'",id,"'") result from ctp_enum_item limit 100; 
MySQL将查询的结果作为update更新的数据,且在原字段数据后 CONCAT拼接(lej)
MySQL将查询的结果作为update更新的数据,且在原字段数据后 CONCAT拼接(lej)

3.因为拼接的结果很长,导致拼接结果显示不全,可以通过以下方法解决。 在每次查询前执行,使得查询结果值变大。

代码语言:javascript
复制
SET SESSION group_concat_max_len = 10240;
或者
SET GLOBAL group_concat_max_len = 10240; 

4.补充:SQL server 的 拼接SQL如下:

代码语言:javascript
复制
select stuff((
select ','+ requestid
from nccombinedpayment for xml path('')),1,1,'') as requestid ;

五、mysql 对查询出来的字段拼接字符串 concat

代码语言:javascript
复制
SELECT item_starttime,item_username,CONCAT('外出',item_wcaddress) as item_wcaddress,author from tlk_KQ_goout_app;

拼接之前

MySQL将查询的结果作为update更新的数据,且在原字段数据后 CONCAT拼接(lej)
MySQL将查询的结果作为update更新的数据,且在原字段数据后 CONCAT拼接(lej)

拼接之后

MySQL将查询的结果作为update更新的数据,且在原字段数据后 CONCAT拼接(lej)
MySQL将查询的结果作为update更新的数据,且在原字段数据后 CONCAT拼接(lej)

六、浅析MySQL中concat以及group_concat的使用

七、mysql 往表中某个字段的字符串后追加字符串

update 表名 set 字段名=CONCAT(字段名,”需添加的值”)WHERE 条件;

例如:

代码语言:javascript
复制
update np_order set customer_remark=CONCAT(customer_remark,"需添加的值")WHERE order_id='1'

np_order :表名

customer_remark 字段名称

where 后指定条件

八、mysql 把select结果update更新到表中,从查询结果中更新数据

逻辑:两张表连接获取finishin的重量插入到sale.

代码语言:javascript
复制
UPDATE sale
INNER JOIN (
	SELECT
		sale.FNo,
		sale.FEntryID,
		(finishin.FQty) AS qty
	FROM
		sale,
		finishin
	WHERE
		sale.FNo = finishin.FNo
	AND sale.FEntryID = finishin.FEntryID
	ORDER BY
		sale.FNo
) sale2 ON sale2.FNo = sale.FNo
AND sale2.FEntryID = sale.FEntryID
SET sale.FqtyIn = sale2.qty

逻辑:timefinishin表中有多个相同的FBillNo,FEntryID一样的数据,通过分组来求和qty总重量,成为一张新的表和salesorderinfo进行连表

代码语言:javascript
复制
UPDATE salesorderinfo
INNER JOIN (
	SELECT
		salesorderinfo.FBillNo,
		salesorderinfo.FEntryID,
		(timein.FqtyIn) AS qty
	FROM
		salesorderinfo,
		(
			SELECT
				*, SUM(timefinishin.FQty) AS FqtyIn
			FROM
				timefinishin
			GROUP BY
				FBillNo,
				FEntryID
		) timein
	WHERE
		salesorderinfo.FBillNo = timein.FBillNo
	AND salesorderinfo.FEntryID = timein.FEntryID
) sale2 ON sale2.FBillNo = salesorderinfo.FBillNo
AND sale2.FEntryID = salesorderinfo.FEntryID
SET salesorderinfo.FqtyIn = sale2.qty

发现好东西,https://httpbin.org/ 这个网站可以用来测试 http 请求 参考:

https://blog.csdn.net/qq_36823916/article/details/79403696

https://blog.csdn.net/qq5621/article/details/108098826

https://blog.csdn.net/cydbetter/article/details/82117841

https://blog.csdn.net/mary19920410/article/details/76545053

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/111441.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年2月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 二、mysql中update和select结合使用
    • 三、update 和 select 结合使用进行数据更新,案例
    相关产品与服务
    数据库
    云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档