postgres if ,when及判断表是否存在的sql编写

哈哈 阅读:1122 2020-06-13 18:34:30 评论:0

判断表是否存在方法1:

SELECT  case  WHEN   a.cc =1 THEN 2 else 0 END 
FROM 
( 
select  count(*) as cc from pg_class where relname = 'wo'    --wo is table name,pg_class是pg自带的关键字 
) as a  

方法2:

用if判断,但有以下条件

The IF statement is part of the default procedural language PL/pgSQL. You need to create a function or execute an ad-hoc statement with the DO command.、

exist使用要求和if一样

DO 
$do$ 
BEGIN 
IF (select  count(*) cc from pg_class where relname = 'wo') = 0 --一定要加括号 
THEN 
   INSERT INTO wo VALUES (2); 
ELSE  
   INSERT INTO wo VALUES (1); 
END IF; 
END 
$do$ 

 联合使用select 和insert的方法如下

create table language_ko(Key text,XML text); 
insert into Language_ko(key,xml) (select "Key " as key,'<'||"Key"||'>'||"Korean"||'</'||"Key"||'>' as xml  from "centralClient1")

 

标签:数据库
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

关注我们

一个IT知识分享的公众号