开发者

Check if a table exist in where

This query generates an error because table2 does开发者_开发百科n't exist:

Select * FROM table WHERE table2.id IS NOT NULL

Is there anything like this for check the table2 before apply the check on the id?

Select * FROM table WHERE (EXIST(table2) AND table2.id IS NOT NULL) or not EXIST(table2)


You need to query this system table:

SELECT table_name
FROM information_schema.tables
WHERE table_schema = 'yourdatabasename'
AND table_name = 'table2';

If a row is returned, then your table exists.


I do not believe there is any command or function in standard SQL to do this. You could query the data dictionary to check if the table exists before issuing your SQL query as follows:

SELECT table_name FROM INFORMATION_SCHEMA.tables WHERE table_name = 'xxx';

I do not think it could be done in a single SQL statement though.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜