簡體   English   中英

較低的 function 在 SQL Z30162ED78B6C10F74FCZF14Z 中用於 function 時被忽略

[英]Lower function being ignored when used in a function in SQL Oracle

我在 SQL Oracle 中創建不區分大小寫的 function 時遇到問題。 我被要求創建一個名為 function

containsText(pString1, pString2)

查找 pString2 是否在 pString1 中。 我正在使用 lower() function 但它似乎忽略了命令。 如果有人想要 go,這里是腳本。

首先創建表:

-- create types --
create or replace type artist_type as object 
(artistName     varchar(50), 
 artistRole     varchar(25))
/ 
create type artist_array_type  
as varray(5) of artist_type
/ 
create or replace type review_type as object 
(reviewerName   varchar(25), 
 reviewDate     date,
 reviewText     varchar(250), 
 reviewScore    number)
/
create or replace type review_table_type as table of review_type
/
create or replace type album_type as object 
(albumTitle         varchar(50),
 albumPlaytime      number(3), -- minutes
 albumReleaseDate   date, 
 albumGenre         varchar(15),
 albumPrice         number(9,2),
 albumTracks        number(2),
 albumArtists       artist_array_type,
 albumReviews       review_table_type,
member function discountPrice return number,
member function containsText (pString1 varchar2, pString2 varchar2) return integer)
not instantiable not final 
/
create or replace type disk_type under album_type 
( mediaType         varchar(10),
 diskNum            number(2), -- number of disks
 diskUsedPrice      number(9,2),
 diskDeliveryCost   number(9,2), 
overriding member function discountPrice return number)
/
create or replace type mp3_type under album_type
(downloadSize   number, -- size in MB
 overriding member function discountPrice return number)
/
-- create tables --
create table albums of album_type 
object id system generated
nested table albumReviews store as store_reviews 
/ 

這是一行數據:

insert into albums 
values (disk_type('The Essential Bob Dylan', 99, '8-Jul-2016', 'Pop', 37.00, 32, 
artist_array_type(artist_type('Bob Dylan', 'Composer'), 
                  artist_type('Bob Dylan', 'Vocals')), 
review_table_type(review_type('Shawn', '24-Jul-2018', 'Wife loved it!', 5), 
                  review_type('Reuben', '2-Aug-2019', 'Great compilation of some of his most known songs', 5)),
'Vinyl', 2, NULL, 11));

這是 function:

create or replace type body album_type
as 
member function discountPrice return number is

    begin 
        return null;
    end discountPrice;

    member function containsText (pString1 varchar2, pString2 varchar2) return integer is

    begin
        if lower(pString1) like lower('%' || pString2 || '%') then 
             return 1;
        else
            return 0;
        end if;
    end containsText;
end;

最后是 select 語句:

select containsText('This is great', 'Great') from albums

應該返回 1 但返回 0。

此外,我嘗試了以下替代 if 語句。

   begin
        if instr(lower(pString1), lower(pString2)) > 0 then 
             return 1;
        else
            return 0;
        end if;
    end containsText;
end;

您的代碼沒有調用成員 function,而是調用了不同的獨立 function。 使用如下代碼調用類型擁有的成員 function:

select a.containsText('This is great', 'Great') result
from albums a;

RESULT
------
     1

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM