У меня проблемы с созданием функции в SQL Oracle, которая не учитывает регистр. Меня попросили создать функцию с именем
containsText(pString1, pString2)
, чтобы определить, находится ли pString2 в pString1. Я использую функцию lower (), но она, кажется, игнорирует команду. Если кто-то хотел бы попробовать, вот сценарии.
Сначала создайте таблицы:
-- 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));
Вотфункция:
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 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;