postgres if ,when及判斷表是否存在的sql編寫


判斷表是否存在方法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一樣

1
2
3
4
5
6
7
8
9
10
11
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")


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM