MySQL CASE EnumInt WHEN Varchar ELSE Int 返回为 BLOB - 如何转换为 Varchar?
以下返回一个 BLOB,如何将此 else 值转换为 VARCHAR 来解决我的问题?
SELECT
CASE EnumID
WHEN 1 THEN 'Red'
WHEN 2 THEN 'Green'
WHEN 3 THEN 'Blue'
ELSE EnumID
END AS EnumValue
FROM Table
在 MSSQL/TSQL 中,我使用 ELSE CAST([EnumID] AS VARCHAR(100)) ,但 MySQL 抱怨。
我想要的只是一个故障转移,如果这个存储过程不知道新的枚举值来管理代码、主数据库和数据仓库数据持久性。
肯定是一个明显的答案...
显然问题似乎出在使用 VARCHAR?刚刚发现 CAST(EnumID AS CHAR(20))
在大小写开关中工作正常。
叹息...为什么我要费心发帖,我所需要的只是一个可以与之交谈的橡皮鸭...
The following returns a BLOB, how can I convert this else value to a VARCHAR to fix my problem?
SELECT
CASE EnumID
WHEN 1 THEN 'Red'
WHEN 2 THEN 'Green'
WHEN 3 THEN 'Blue'
ELSE EnumID
END AS EnumValue
FROM Table
In MSSQL/TSQL I use ELSE CAST([EnumID] AS VARCHAR(100))
but MySQL complains.
All I want is a failover should this stored procedure not know a new enum value to manage code vs. main database vs. data warehouse data persistence.
Bound to be an obvious answer...
Apparently the problem seems to be using VARCHAR? Just found that CAST(EnumID AS CHAR(20))
works fine in the case switch.
Sigh... why do I bother posting all I need is a Rubber Duck to talk to...
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
使用
cast
请参阅:http:// dev.mysql.com/doc/refman/5.0/en/cast-functions.html
Use
cast
See: http://dev.mysql.com/doc/refman/5.0/en/cast-functions.html