“最难不过坚持”
本人承接扒站仿站,php网站维护,病毒查杀,网站编辑,网站改版,html制作
有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339
- https://jueru.net/
-
- :weixiao:
-
- :shuijiao: :weiqu: :zhenbang: :leng:
-
- :yiwen: :yiwen: :yiwen: :yiwen:
-
- 这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
-
项目中查询用到了concat()拼接函数,在此查询中出现了拼接的字段为null的情况,拼接结果为null在应用层报了空指针异常。
SELECT CONCAT('1,',NULL,'2') result;
SELECT CONCAT('1,','','2') result;
通过实践证明CONCAT()函数拼接时如果拼接的参数中有NULL时,结果为NULL。
使用以下方式来解决
方法一:使用IFNULL函数如果是NULL将其置为''空字符串。
SELECT CONCAT('1,',IFNULL(NULL,''),'2') result;
方法二:使用CONCAT_WS函数。指定有分隔符的字符串连接
SELECT CONCAT_WS(',','1',NULL,'2') result;
指定使用逗号进行分隔
CONCAT_WS(分隔符,参数1,参数2,...参数n)与CONCAT(参数1,参数2,...参数n)
两个函数的区别:
CONCAT_WS():表示concat with separator,即有分隔符的字符串连接
CONCAT():表示将字符串进行连接
两个最重要的区别就是,CONCAT()函数,拼接参数中存在NULL直接返回NULL
而CONCAT_WS()函数在执行的时候,不会因为NULL值而返回NULL
实际应用:mysql中拼接2个字段内容到一个字段内容
数据表中有2个字段remark1,remark2,需要把remark2的内容合并到remark1里面,remark1里面的内容需要保留
方法1:
UPDATE d_bill SET remark1=CONCAT(IFNULL(remark1,''),IFNULL(remark2,''))
判断字段值是否为NULL,如果为NULL则转换为空
方法2:
UPDATE d_bill SET remark1=CONCAT_WS(',',remark1,remark2)
以','拼接2个字段,如果remark1或者remark2有一个值为NULL则不会出现分隔符',',但是会合并成功
注意:如果remark1和remark2的值是空字符,不是NULL,那么会出现分隔符',',显得有点别扭