SELECT游标列表中需要别名,以避免函数中出现重复的列名

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SELECT游标列表中需要别名,以避免函数中出现重复的列名相关的知识,希望对你有一定的参考价值。

我有以下功能:

CREATE OR REPLACE Function FindOffers
    ( przebieg_max IN number )
    RETURN offer_type_table
AS
    l_offers offer_type_table := offer_type_table();

BEGIN
    FOR i IN (
        SELECT * FROM szczegoly_oferty sz, oferty ofe
        WHERE  sz.przebieg <= przebieg_max AND sz.oferta_id = ofe.idk
    )
    LOOP
        l_offers.EXTEND;
        l_offers(l_offers.COUNT) := (offer_type('Auto',i.rok_produkcji,i.cena_aktualna,i.przebieg));
    END LOOP;

    RETURN l_offers;

EXCEPTION
    WHEN OTHERS THEN
        raise_application_error(-20001,'An error was encountered - '||SQLCODE||' -ERROR- '||SQLERRM);
END;

在编译期间,它向我显示以下错误:

Alias required in SELECT list of cursor to avoid duplicate column names.

我在select查询中使用了表的别名。哪里可以问题?

答案

它似乎

szczegoly_ofertyoferty都有至少一个共同的列。

为了避免歧义,你必须使用别名来单独表达列名,使用别名szofe,如SELECT sz.col1, ofe.col1, ofe.col2中的SELECT list

另一答案

只选择您需要的列。并学会使用正确的,明确的JOIN语法:

FOR i IN (
    SELECT ?.rok_produkcji, ?.cena_aktualna, sz.przebieg
    FROM szczegoly_oferty sz JOIN
         oferty ofe
         ON sz.przebieg <= przebieg_max AND sz.oferta_id = ofe.idk
)
. . .

?是您填写表别名。

以上是关于SELECT游标列表中需要别名,以避免函数中出现重复的列名的主要内容,如果未能解决你的问题,请参考以下文章

MySQL之select查询function函数

引用 SELECT 列表中其他地方的别名

在游标中调用函数 for 循环

OracleSql语句学习

使用Group By注意事项

oracle 隐式游标,显示游标,游标循环,动态SELECT语句和动态游标,异常处理,自定义异常