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

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

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

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 ;

(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中如下:

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_danger 和 company 表,根据 company 表的 ID 和 inspect_danger 表的COMPANY_ID 匹配,把 company 表内的 INDUSTRY 更新到 inspect_danger表中。

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.正常查询 如下: 

select id result from ctp_enum_item limit 100;

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

2.拼接结果 如下

  select group_concat("'",id,"'") result from ctp_enum_item limit 100; 

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

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

SET SESSION group_concat_max_len = 10240;
或者
SET GLOBAL group_concat_max_len = 10240; 

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

select stuff((
select ','+ requestid
from nccombinedpayment for xml path('')),1,1,'') as requestid ;

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

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中concat以及group_concat的使用

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

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

例如:

update np_order set customer_remark=CONCAT(customer_remark,"需添加的值")WHERE order_id='1'

np_order :表名

customer_remark  字段名称

where  后指定条件

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

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

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进行连表

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • sdio接口是什么_如何理解api接口

    sdio接口是什么_如何理解api接口运用SD卡第一步,认识SDIO接口做毕业设计需要用到大量的音频文件,一般的存储器满足不了存储要求,故选择SD卡作为存储器件。在这里记录一下自己的学习经历,学习一个新的IC,无非是要么根据时序图写出Read和Write函数,要么是根据通信总线和IC相关操作指令去完成Read和Write函数。只有能与对应IC“说话”,我们才能去开发它更多地可能性。这里以原子探索者为例,为大家介绍一下SD卡相关知识。…

  • 死锁原因总结

    死锁原因总结

  • jq正则表达式_JAVA 正则表达式

    jq正则表达式_JAVA 正则表达式一、JavaScript正则表达式正则表达式(英语:RegularExpression,在代码中常简写为regex、regexp或RE)使用单个字符串来描述、匹配一系列符合某个句法规则的字符串搜索模式。搜索模式可用于文本搜索和文本替换。什么是正则表达式?正则表达式是由一个字符序列形成的搜索模式。当你在文本中搜索数据时,你可以用搜索模式来描述你要查询的内容。正则表达式可以是一个简单的字符,或一个更…

  • executescalar mysql_DbCommand.ExecuteScalar 方法的返回值[通俗易懂]

    executescalar mysql_DbCommand.ExecuteScalar 方法的返回值[通俗易懂]DbCommand.ExecuteScalar方法执行查询,并返回查询所返回的结果集中第一行的第一列。所有其他的列和行将被忽略。语法:publicabstractObjectExecuteScalar()返回值:类型:System.Object,结果集中第一行的第一列。备注:使用ExecuteScalar方法从数据库中检索单个值(例如一个聚合值)。与使用ExecuteRe…

  • 浮雕建模软件_自建房设计软件

    浮雕建模软件_自建房设计软件vectricaspire10是一款非常专业的3d浮雕模型设计软件,为CNC铣床上创建和切割零件提供了强大直观的解决方案,凭借其独特的3D组件建模、完善的2D设计、编辑工具集让你可以轻松使用现有2D数据或导入的3D模型,甚至能够从头开始创建自己的2D和3D零件。而且可以将几何体捕捉到不作为几何体存在的直线,延伸和交叉点,从而减少对大多数构造矢量的需求,还具有一整套完善的绘图工具,允许你通过在创建几何体时允许键入值来更轻松地为形状创建和编辑过程添加更多精度,让你能够更准确地切割这些形状。与此同时,全新的v

  • c语言 无锁编程,无锁编程与有锁编程的效率总结、无锁队列的实现(c语言)「建议收藏」

    c语言 无锁编程,无锁编程与有锁编程的效率总结、无锁队列的实现(c语言)「建议收藏」1.无锁编程与有锁编程的效率无锁编程,即通过CAS原子操作去控制线程的同步。如果你还不知道什么使CAS原子操作,建议先去查看相关资料,这一方面的资料网络上有很多。CAS实现的是硬件级的互斥,在线程低并发的情况下,其性能比普通互斥锁高效,但是当线程高并发的时候,硬件级互斥引入的代价与应用层的锁竞争产生的代价同样都是很大的。这时普通锁编程其实是优于无锁编程的。硬件级原子操作使应用层的操作变慢,而且无法…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号