时间:2021-05-24
Mysql的查询结果行字段拼接,可以用下面两个函数实现:
如果连接串中存在NULL,则返回结果为NULL:
mysql> select concat('1','2',NULL,'3') from test ;+--------------------------+| concat('1','2',NULL,'3') |+--------------------------+| NULL |+--------------------------+concat(separator,str1,str2,...) 代表 concat with separator ,是concat()的特殊形式。第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是其它参数。
mysql> select concat_ws(':','1','2','3') from test ;+----------------------------+| concat_ws(':','1','2','3') |+----------------------------+| 1:2:3 |+----------------------------+分隔符为NULL,则返回结果为NULL:
mysql> select concat_ws(NULL,'1','2','3') from test; +-----------------------------+| concat_ws(NULL,'1','2','3') |+-----------------------------+| NULL | +-----------------------------+如果参数中存在NULL,则会被忽略:
mysql> select concat_ws(':','1','2',NULL,NULL,NULL,'3') from test ;+-------------------------------------------+| concat_ws(':','1','2',NULL,NULL,NULL,'3') |+-------------------------------------------+| 1:2:3 |+-------------------------------------------+可以对NULL进行判断,并用其它值进行替换:
mysql> select concat_ws(':','1','2',ifNULL(NULL,'0'),'3') from bank limit 1; +---------------------------------------------+| concat_ws(':','1','2',ifNULL(NULL,'0'),'3') |+---------------------------------------------+| 1:2:0:3 | +---------------------------------------------+补充:补充:mysql中分组时将某个字段的值进行拼接
t_dog表
t_vaccine表
t_dog_vaccine表
我需要将dog_vaccine中每个狗相对应的疫苗查询出来,由于狗和疫苗是多对多的关系,一个狗可能对应多个疫苗,但我想把这多个疫苗用字符串拼接成一个,然后去映射到java实体类上。
我用了俩个左连接查询使得 t_dog表,t_vaccine表,t_dog_vaccine表这三个表关联了起来
select dv.id as id, d.dog_name as dogName,v.vaccine_name from t_dog_vaccine dv left join t_dog d on dv.dog_id = d.id left join t_vaccine v on dv.vaccine_id = v.id这样虽然把狗和疫苗都对应上了,但是每条狗有多条记录,而我只想要一个狗的名字和把多个vaccine_name的值合并成一个字符串这样的数据。在经过思考以后,我突然想到了·group by 。
select dv.id as id, d.dog_name as dogName,v.vaccine_name from t_dog_vaccine dv left join t_dog d on dv.dog_id = d.id left join t_vaccine v on dv.vaccine_id = v.id group by dogName用了group by 这明显不是我想到的结果啊,dogName虽然只有一个了,但是它对应的疫苗也只有一个了,我想要多个疫苗名,那怎么办呢? 是不是有个函数可以做字符串拼接呢? emmmmm,有了,group_concat。。。
select dv.id as id, d.dog_name as dogName, group_concat(v.vaccine_name) as dogVaccineName from t_dog_vaccine dv left join t_dog d on dv.dog_id = d.id left join t_vaccine v on dv.vaccine_id = v.id group by d.dog_name这下就达到我想的效果啦。
默认用法
select group_concat(vaccine_name) as dogVaccineName from t_vaccine where id in(select vaccine_id from t_dog_vaccine where dog_id = 1)group_concat拼接时默认的分隔符是',' ,如果我们想改变这个分隔符可以这样做。
REPLACE(group_concat(vaccine_name),',','这里填写你所想换的分隔符')比如我想把默认的,换成;
select REPLACE(group_concat(vaccine_name),',',';') as dogVaccineName from t_vaccine where id in(select vaccine_id from t_dog_vaccine where dog_id = 1)以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
MySQL序列AUTO_INCREMENT详解及实例代码MySQL序列是一组整数:1,2,3,...,由于一张数据表只能有一个字段自增主键,如果你想实现其他字段
mysql根据多个字段查找在mysql中,如果要实现根据某个字段排序的时候,可以使用下面的SQL语句SELECT*FROM'TABLE_NAME'ORDERBY
本文实例讲述了thinkPHP实现多字段模糊匹配查询的方法。分享给大家供大家参考,具体如下:引言:有时候查询要匹配多个字段。比如查询地址,地址是由多个字段组成的
在有些场景下,我们需要对我们的varchar类型的字段做修改,而修改的结果为两个字段的拼接或者一个字段+字符串的拼接。如下所示,我们希望将xx_role表中的n
背景使用mybatis查询(mysql)时,会使用多个double字段做相加,但是呢,其中几个字段有可能是null,会抛空指针。解决方法自动生成的mybatis