我想知道,在日期列中没有日期时,是否可以显示"-“
因此,一个元组可能是{Dave,2011年7月13日},而另一个元组可能是{John,-}
编辑:感谢下面提出这个建议的人:
SELECT `ID`, COALESCE(CAST(`Graduation Date` AS CHAR), '-') FROM <table>啊,真灵!
发布于 2011-04-27 11:15:25
使用COALESCE
SELECT name, COALESCE(date, '-')
FROM table编辑:不知道它怎么可能不工作。示例:
SELECT COALESCE('2011-01-01', '-') //returns '2011-01-01'
SELECT COALESCE('', '-') //returns ''
SELECT COALESCE(NULL, '-') //returns '-'尝试它们3条语句,您将看到返回的内容。
EDIT2:
SELECT name, IF(COALESCE(date, '-') = '', '-', date)
FROM table发布于 2011-04-27 12:29:51
如果date列包含一些您希望以与NULL相同的方式处理的特殊日期(例如,0000-00-00),则可以尝试以下方法:
SELECT COALESCE(NULLIF(yourdatecolumn, '0000-00-00'), '-')这实际上只是一种较短的写作方式:
SELECT CASE
WHEN yourdatecolumn IS NULL OR yourdatecolumn = '0000-00-00' THEN '-'
ELSE yourdatecolumn
END发布于 2011-04-27 11:16:12
SELECT ID, IF(GRADUATIONDATE IS NULL, '-', GRADUATIONDATE) FROM TABLE
or
SELECT ID, IFNULL(GRADUATIONDATE,'-') FROM TABLEhttps://stackoverflow.com/questions/5803102
复制相似问题