如果表中不存在,MySQL将字段选择为NULL

前端之家收集整理的这篇文章主要介绍了如果表中不存在,MySQL将字段选择为NULL前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我喜欢在可能包含某些字段的表上使用SELECT,但可能不是.如果不是,则该值可以返回为NULL,就像JOIN LEFT对不存在的行一样.

例如.像这样的伪sql

SELECT id,email IF EXISTS,name,address FROM users;

应该在没有’email’字段的表’users’上运行而没有错误,但是返回email = NULL.

最佳答案
你想要什么不能在纯sql中完成.

实质上,您希望sql可以有条件地选择可能不存在的列.无法解析此类sql – 所有选定的列必须存在或查询无效.

但是,您可以通过查询目录表来检查您连接到的数据库的模式,并基于此动态构建sql,从而实现此应用程序代码.

查询可能有助于您的应用代码构建您的查询

select COLUMN_NAME
from INFORMATION_SCHEMA.COLUMNS
where TABLE_NAME = 'users'
and TABLE_SCHEMA = 'YOUR-DB-NAME';

猜你在找的MySQL相关文章