亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 3487 | 回復(fù): 2
打印 上一主題 下一主題

postgresql中這種查詢有沒有簡單的方法把結(jié)果返回 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2012-06-25 10:13 |只看該作者 |倒序?yàn)g覽
想把查詢的結(jié)果返回,一個(gè)是int 型,后兩個(gè)是varchar類型的值:
可不可以用記錄類型返回?
        if EXISTS(select * from ADInfo where ADID=v_ADID) then
                select v_Ver as Ver ,Url, LinkUrl from ADInfo where ADID=V_ADID;
        else  
        BEGIN
                SELECT v_Ver as Ver ,'' as Url ,'' as LinkUrl;
        END;
           end if;

論壇徽章:
3
數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2015-06-18 22:20:00數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2015-06-21 22:20:00數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2015-08-27 06:20:00
2 [報(bào)告]
發(fā)表于 2012-06-26 18:49 |只看該作者
回復(fù) 1# oracle_1010
在PostgreSQL可以很簡單的做到,具體見下面:

create table ADInfo(Adid INT,v_Ver int, Url text, LinkUrl text);
insert into adinfo values(1,1,'www.baidu.com','http://www.baidu.com');
insert into adinfo values(2,2,'www.google.com','http://www.google.com');

你可以創(chuàng)建一個(gè)返回類型:
CREATE TYPE ret_my_type AS
(
   Ver INT,
   Url VARCHAR,
   LinkUrl VARCHAR
);

CREATE OR REPLACE FUNCTION my_function(v_adid int) RETURNS SETOF ret_my_type AS 
$$
DECLARE
     v_rec ret_my_type;
BEGIN
    IF EXISTS(select * from ADInfo where ADID=v_ADID) then
        FOR v_rec IN select v_Ver as Ver ,Url, LinkUrl from ADInfo where ADID=V_ADID LOOP
            RETURN NEXT v_rec;
        END LOOP;
    ELSE
        FOR v_rec IN SELECT v_Ver as Ver ,'' as Url ,'' as LinkUrl LOOP
            RETURN NEXT v_rec;
        END LOOP;
    END IF;
END;
$$
LANGUAGE PLPGSQL;

postgres=# select * from my_function(2);
 ver |      url       |        linkurl        
-----+----------------+-----------------------
   2 | www.google.com | http://www.google.com
(1 row)

如果你不創(chuàng)建類型ret_my_type,可以使用RECORD這種通用類型返回?cái)?shù)據(jù),但調(diào)用的時(shí)候就得指定返回的數(shù)據(jù)類型:
CREATE OR REPLACE FUNCTION my_function2(v_adid int) RETURNS SETOF RECORD AS 
$$
DECLARE
     v_rec RECORD;
BEGIN
    IF EXISTS(select * from ADInfo where ADID=v_ADID) then
        FOR v_rec IN select v_Ver as Ver ,Url, LinkUrl from ADInfo where ADID=V_ADID LOOP
            RETURN NEXT v_rec;
        END LOOP;
    ELSE
        FOR v_rec IN SELECT v_Ver as Ver ,'' as Url ,'' as LinkUrl LOOP
            RETURN NEXT v_rec;
        END LOOP;
    END IF;
END;
$$
LANGUAGE PLPGSQL;

postgres=# select * from my_function(2);
ERROR:  function my_function(integer) does not exist
LINE 1: select * from my_function(2);
                      ^
HINT:  No function matches the given name and argument types. You might need to add explicit type casts.
因?yàn)闆]有指定返回的具體類型,所以報(bào)錯(cuò)了,指定類型:

postgres=# select * from my_function2(2) as (Ver int, Url text, Linkurl text);
 ver |      url       |        linkurl        
-----+----------------+-----------------------
   2 | www.google.com | http://www.google.com
(1 row)

論壇徽章:
0
3 [報(bào)告]
發(fā)表于 2012-06-28 16:40 |只看該作者
謝謝你,其實(shí)我后來做出來了,用的方法就是你寫的其中一種,本來里面有三條查詢語句的,不過第一個(gè)查詢語句主要是用來賦值的,所以當(dāng)時(shí)就在那里糾結(jié)的!
雖然這個(gè)問題已經(jīng)解決了,不過還是要謝謝你)
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號(hào)-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號(hào):11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP