-
Нужно написать запрос, который выводил все записи, в которых встречается какой либо символ из английского и русского алфавита, как можно это сделать?
Нужно что-то похожее на
select * from table where field1 in ['A..'z']
-
Вернее
select * from table where ['A..'z'] in field1
-
> Dizzel (22.07.08 13:11) [1]
Это я ...
-
> DelphiN!
ХП + substring
-
В MS SQL можно так: field1 like '%[А-Я]%'
-
> stas © (22.07.08 13:24) [4]
В FireBird 2.1 так не работает
> turbouser © (22.07.08 13:23) [3]
А без хранимых процедур никак?
-
> DelphiN! (22.07.08 13:46) [5]
> А без хранимых процедур никак?
case -ом :)
-
> DelphiN! (22.07.08 13:46) [5]
Лови...
CREATE PROCEDURE EN_RU (
s varchar(50) character set cyrl)
returns (
idx integer)
as
declare variable i integer;
declare variable ch char(1) character set cyrl;
declare variable en varchar(30);
declare variable ru varchar(34);
begin
EN='ABCDEFGHIJKLMNOPQRSTUVWXYZ';
RU='АБВГДЕЁЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯ';
I=1;
while (i<=strlen(:S)) do
begin
Ch = substring(:S from :i for 1);
if ((:EN containing :Ch) or (:RU containing :Ch)) then
begin
IDX=:I;
break;
end
I=:I+1;
end
suspend;
end
-
UDF сделай
-
> turbouser © (22.07.08 13:53) [7]
>
> Лови...
Спасибо!
А можно ли проверить число ли в строке или нет? Только без ХП
-
можно еще
SELECT T1.*
FROM table1 T1
WHERE (T1.FIELD1 SIMILAR TO '[A-z]')
OR (T1.FIELD1 SIMILAR TO '[А-я]')
Но для использования нужен Firebird не ниже версии 2.5.0.20343
-
> А можно ли проверить число ли в строке или нет? Только без ХПАналогично
SELECT T1.*
FROM table1 T1
WHERE (T1.FIELD1 SIMILAR TO '[0-9]')
-
> DelphiN! (22.07.08 14:55) [9]
См. [8]
-
> PEAKTOP ©
2.5 еще альфа совсем...
-
> можно ли проверить число ли в строке или нет?
Можно, если ты понимаешь, что такое "число в строке")
-
> А можно ли проверить число ли в строке или нет?
'abcd345efg' LIKE '%345%'
-
Правильный$Вася (22.07.08 17:29) [15]
не он хочет узнать есть ли в строке abcd345efg число
-
> stas © (22.07.08 17:34) [16]
если число конкретное, то [15]
если узнать, а вообще число ли оно, то CAST
-
> А можно ли проверить число ли в строке или нет? Только без
> ХП
EXECUTE BLOCK. Аналог ХП, но можно задавать как и любой SELECT-запрос в компоненте TIBDataSet. Поддерживается с версии 2.0. Хороший пример есть в статье РЕАКТОРА "Firebird 2.0 на полную катушку".
-
Спасибо все за советы!
Так как используется FB ниже 2.5 придётся использовать ХП ...
BEGIN
USERTYPE = 'MEMBER';
NUM='0123456789';
I=1;
Ch = '/';
while ((ch <> '')and(usertype = 'MEMBER')) do
begin
Ch = substring(:S from :i for 1);
if ((:NUM containing :Ch)) then
begin
USERTYPE = 'NUM';
break;
end
I=:I+1;
end
suspend;
END
В FB 2.1 данная процедура работает хорошо, но при попытки использования ее в FB 1.5.1 ругается на строку
Ch = substring(:S from :i for 1);. Какой есть аналог функции для FB 1.5?
Вот ошибка :
Invalid token.
Dynamic SQL Error.
SQL error code = -104.
Token unknown - line 16, column 25.
:.
-
Если я заменяю :i на статическое число, то все работает, как решить это проблему?
Ch = substring(:S from :i for 1);
на
Ch = substring(:S from 1 for 1);
-
> Какой есть аналог функции для FB 1.5?
подключи UDF, в твоей версии неттакой встроенной функции, но есть в стандартном списке UDF
при этом понимает параметры-переменные
-
> Правильный$Вася (23.07.08 11:10) [21]
А как подключить UDF?
-
В смысле какое описание должно быть у "правильной" substring?
-
> В смысле какое описание должно быть у "правильной" substring?
в справке по IB6 написано
-
> В FB 2.1 данная процедура работает хорошо, но при попытки
> использования ее в FB 1.5.1 ругается на строку Ch = substring(:
> S from :i for 1);. Какой есть аналог функции для FB 1.5?
Так тыж FB 2.1 используешь (см [5]). К чему тогда о проблемах с FB 1.5 спрашивать?
-
> Loginov Dmitry © (23.07.08 22:27) [25]
> DelphiN! (23.07.08 10:03) [19]
> В FB 2.1 данная процедура работает хорошо, но при попытки
> использования ее в FB 1.5.1 ругается на строку
Основная версия FB в компании 2.1, однако на некоторых серверах еще осталась 1.5.1 ...
-
> Правильный$Вася (23.07.08 13:00) [24]
>
> в справке по IB6 написано
Не могу найти :(
-
> DelphiN! (23.07.08 11:57) [23]
см. \program files\firebird\udf\ib_udf.sql
выполняешь скрипт - будет в базе функция
substr
и еще много чего полезного :)
-
Найди RFUNC - там все есть, DLL скрипты на подключение/отключение UDF. Бесплатная библиотека
-
> turbouser © (24.07.08 08:36) [28]
>
> см. \program files\firebird\udf\ib_udf.sql
> выполняешь скрипт - будет в базе функция substr
> и еще много чего полезного :)
Заработало!!!
Огромное спасибо всем за помощь!