欢迎各位兄弟 发布技术文章

这里的技术是共享的

You are here

mysql 字符串相加 有大用

shiping1 的头像
 
列参与相加不能直接用加号(+),需要引用函数concat,
 
 concat(列名,'字符串') 最好用它
 
 
例: concat('字符串',concat(列名,'字符串'))
 
 上面的例子是包含了两次相加
 
 
 
普通字符串直接相加即可 '字符串'+'字符串'
 
 
 
MySQL的日期类型可以当作MySQL字符串处理
 
 
 
CONCAT(',', 列名, ',')
结果就是    ,列名,   它是三个字符串的相加
 
例:  select concat(money_year,'万元') from dede_addon17;
 
 
 
 
 
 

mysql CONCAT()函数用于将多个字符串连接成一个字符串,是最重要的mysql函数之一,下面就将为您详细介绍mysql CONCAT()函数,供您参考

mysql CONCAT(str1,str2,…)                        
返回结果为连接参数产生的字符串。如有任何一个参数为NULL ,则返回值为 NULL。或许有一个或多个参数。 如果所有参数均为非二进制字符串,则结果为非二进制字符串。 如果自变量中含有任一二进制字符串,则结果为一个二进制字符串。一个数字参数被转化为与之相等的二进制字符串格式;若要避免这种情况,可使用显式类型 cast, 例如: SELECT CONCAT(CAST(int_col AS CHAR), char_col)

mysql> SELECT CONCAT(’My’, ‘S’, ‘QL’);

-> ‘MySQL’

mysql> SELECT CONCAT(’My’, NULL, ‘QL’);

-> NULL

mysql> SELECT CONCAT(14.3);

-> ‘14.3′

mysql CONCAT_WS(separator,str1,str2,…) 
CONCAT_WS() 代表 CONCAT With Separator ,是CONCAT()的特殊形式。   第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是其它参数。如果分隔符为 NULL,则结果为 NULL。函数会忽略任何分隔符参数后的 NULL 值。

mysql> SELECT CONCAT_WS(’,',’First name’,'Second name’,'Last Name’);

-> ‘First name,Second name,Last Name’

mysql> SELECT CONCAT_WS(’,',’First name’,NULL,’Last Name’);

-> ‘First name,Last Name’

mysql CONCAT_WS()不会忽略任何空字符串。 (然而会忽略所有的 NULL)。

 

 

dedecms 相加的例子 

update dede_addonarticle addon inner join dede_archives arc on addon.aid=arc.id  set addon.body=concat('<p style="text-align: center">
<a href="',arc.litpic,'" target="_blank" title="',arc.title,'"><img src="',arc.litpic,'" style="border-bottom: #ffffff 0px solid; border-left: #ffffff 0px solid;  border-top: #ffffff 0px solid; border-right: #ffffff 0px solid" alt="',arc.litpic,'"/></a></p>')  where addon.typeid=16


     update 更新 联合更新
update dede_archives arc inner join   dede_addonimages addon  on addon.aid=arc.id set arc.litpic=substring(imgurls,locate('ddimg',imgurls)+7,locate('.jpg',imgurls)-locate('ddimg',imgurls)-3)
 
 

 

普通分类: