mysql数据库,sql语句,concat,如果一个字段值为null,则返回null?能不能返回值
taotaoit Mysql 2025-06-03 33 0
关于本站

“最难不过坚持”

本人承接扒站仿站,php网站维护,病毒查杀,网站编辑,网站改版,html制作

有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339

8166370 2696 39
最新评论
https://jueru.net/
评 留言
:weixiao:
评 留言
:shuijiao: :weiqu: :zhenbang: :leng:
评 留言
:yiwen: :yiwen: :yiwen: :yiwen:
评 EasySass: could not generate CSS file. See Output panel for details.
这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
评 TP6模型事件-查询后onAfterRead不好用
文章标签更多
ThinkPHP (260)
Mysql (59)
DedeCms (33)
jQuery (74)
证件照 (1)
setInc (4)
setDec (4)
onclick (5)
打开边栏(ESC) 关闭边栏(ESC)

mysql数据库,sql语句,concat,如果一个字段值为null,则返回null?能不能返回值

在 MySQL 数据库中,CONCAT 函数默认行为就是:如果任一字段为 NULL,则整个结果返回 NULL。这是 MySQL 特有的行为(与其他数据库不同)。

示例演示:
sql
SELECT 
  CONCAT('Hello', NULL, 'World') AS result1, -- 返回 NULL
  CONCAT('Hello', 'World') AS result2;       -- 返回 'HelloWorld'

如果需要避免 NULL(保留非空部分):
使用 CONCAT_WS() + IFNULL() 组合:

sql
SELECT 
  CONCAT_WS(
    '', -- 空分隔符
    IFNULL(col1, ''),
    IFNULL(col2, '')
  ) AS safe_concat
FROM your_table;

关键总结:
默认行为
CONCAT() 遇到任何 NULL 参数时,必定返回 NULL

特殊需求解决方案

保留非空部分 → 用 CONCAT_WS('', IFNULL(col1,''), ...)

需要明确区分空字符串和 NULL → 保持默认行为

版权声明:本站原创文章,允许自由转载。

相关推荐
MySQL提示“SQLSTATE[HY000] [1045] Access denied for user 'root'@'localhost' (using password: YES)”错误
Mysql | 2019-08-30 28293
在登录用thinkphp框架做的网站后台时,提示: MySQL提示“SQLSTATE[HY000] [1045] Access denied for user 'root'@'localhost' (using password: YES)”错误 怀疑是数据库连接密码错误,仔细检查了config.php文件,发现没有错误,...
Navicat for Mysql 如何备份数据库psc格式
Mysql | 2017-12-27 10961
Navicat for Mysql 如何备份数据库psc格式 navicat 备份数据库放在哪里 1,打开要备份的数据库,在 Navicat 界面的菜单栏中选择“备份”功能按钮。 2,在导航栏中点击“新建备份”按钮。 3,在弹出的新建备份窗口中点击“开始”按钮,执行备份的命令。 ...
评论:0条
评论加载中...
发表评论