Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Функция определения страны по его коду, pl sql function 
:(
    Опции темы
yrysty
Дата 23.7.2014, 07:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 2
Регистрация: 23.7.2014

Репутация: нет
Всего: нет



Нужно написать функцию, которая определяет страну по заданному номеру.
На входе функции номер телефона. Код страны в начале строки. Количество цифр в кодах стран примерно варьируются от 1 до 5, поэтому нужно обрезать первые 5 символов строки. Проблема состоит в том что есть страны с одинаковыми кодами, например, в Казахстане и России это 7, в Штатах и Канаде 1. Чтобы код определился правильно нужно искать с конца этой обрезанной строки. Допустим есть номера: 77271111111 (Казахстан) и 74951111111 (Россия). Как видно после семёрки у номеров разные цифры, поэтому нужен поиск с конца.

Есть решение (пока что неправильное):

Код

create or replace 
FUNCTION get_country_name(p_num IN VARCHAR2) RETURN VARCHAR2 IS
   v_country_name VARCHAR2(50);
   v_code_list    SYS.Odcivarchar2list := SYS.Odcivarchar2list(substr(p_num, 1, 1),
                                                               substr(p_num, 1, 2),
                                                               substr(p_num, 1, 3),
                                                               substr(p_num, 1, 4),
                                                               substr(p_num, 1, 5));
BEGIN
   SELECT max(country_name) keep(dense_rank last order by length(country_code))
   INTO v_country_name 
     FROM countries 
       WHERE country_code in (select column_value from TABLE(CAST(v_code_list AS SYS.Odcivarchar2list)));
       
   RETURN v_country_name;
END get_country_name;

PM MAIL   Вверх
Zloxa
Дата 23.7.2014, 08:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3470
Регистрация: 12.9.2008

Репутация: 37
Всего: 161



Цитата(yrysty @  23.7.2014,  08:03 Найти цитируемый пост)
пока что неправильное

а что именно не так - нам самим намедетировать?

Цитата(yrysty @  23.7.2014,  08:03 Найти цитируемый пост)
WHERE country_code in (select column_value from TABLE(CAST(v_code_list AS SYS.Odcivarchar2list)));

Код

where substr(p_num,1,length(country_code)) = country_code




--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
yrysty
Дата 23.7.2014, 12:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 2
Регистрация: 23.7.2014

Репутация: нет
Всего: нет



допустим когда я ввожу номер 77271111111 функция может выдать страну Россия, хоть это Казахстан
PM MAIL   Вверх
Zloxa
Дата 23.7.2014, 14:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3470
Регистрация: 12.9.2008

Репутация: 37
Всего: 161



Цитата(yrysty @  23.7.2014,  13:47 Найти цитируемый пост)
допустим когда я ввожу номер 77271111111 функция может выдать страну Россия, хоть это Казахстан 

Не воспроизводится
Код

SQL> create table countries
  2    as select '7' country_code, 'Россия' country_name from dual
  3       union all
  4       select '77' country_code, 'Казахстан' country_name from dual;
 
Table created
SQL> create or replace
  2  FUNCTION get_country_name(p_num IN VARCHAR2) RETURN VARCHAR2 IS
  3     v_country_name VARCHAR2(50);
  4     v_code_list    SYS.Odcivarchar2list := SYS.Odcivarchar2list(substr(p_num, 1, 1),
  5                                                                 substr(p_num, 1, 2),
  6                                                                 substr(p_num, 1, 3),
  7                                                                 substr(p_num, 1, 4),
  8                                                                 substr(p_num, 1, 5));
  9  BEGIN
 10     SELECT max(country_name) keep(dense_rank last order by length(country_code))
 11     INTO v_country_name
 12       FROM countries
 13         WHERE country_code in (select column_value from TABLE(CAST(v_code_list AS SYS.Odcivarchar2list)));
 14  
 15     RETURN v_country_name;
 16  END get_country_name;
 17  /
 
Function created
SQL> select get_country_name('77271111111') from dual;
 
GET_COUNTRY_NAME('77271111111'
--------------------------------------------------------------------------------
Казахстан



--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Oracle"
Zloxa
LSD

Данный раздел предназначен для обсуждения проблем с Oracle Database, другие продукты Oracle здесь не обсуждаются. Просьба при создании темы, придерживаться следующих правил:

  • при создании темы давайте ей осмысленное название, описывающее суть проблемы
  • указывайте используемую версию базы, способ соединения и язык программирования
  • при ошибках обязательно приводите код ошибки и сообщение сервера
  • приводите код в котором возникла ошибка, по возможности дайте тестовый пример демонстрирующий ошибку
  • при вставке кода используйте соответсвующие теги: [code=sql] [/code] для подсветки SQL и PL/SQL кода, [code=java] [/code] - для Java, и т.д.

  • документация по Oracle: 9i, 10g, 11g
  • книги по Oracle можно поискать здесь
  • действия модераторов можно обсудить здесь

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Zloxa, LSD.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Oracle | Следующая тема »


 




[ Время генерации скрипта: 0.4369 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.