Форум программистов, компьютерный форум CyberForum.ru

PostgreSQL

Войти
Регистрация
Восстановить пароль
 
Tester64
395 / 356 / 43
Регистрация: 22.05.2013
Сообщений: 2,502
#1

Сложную строку в число - PostgreSQL

15.12.2016, 03:25. Просмотров 215. Ответов 2
Метки нет (Все метки)

Гуру, подскажите куда копать... уже час над "мелочью" бьюсь...

Надо строку начинающуюсь на число превратить в число
Например вида "234-a03k=sjkow%" надо превратить в 234 откинув "лишнее".

("234-a03k=sjkow%")::INTEGER => ERROR!

пробовал даже
SELECT REGEXP_REPLACE("234-a03k=sjkow%", '[^0-9]', '----')::TEXT...
тоже не правильно "очищает"
Думаю просто знания регулярки не хватает... подскАжите?

Добавлено через 18 минут
...как всегда... 2 часа проигрался и сам нашел
SQL
1
SUBSTRING(TRIM(' 234-a03k=sjkow%'), '(^[0-9]*)*')::INTEGER
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.12.2016, 03:25     Сложную строку в число
Посмотрите здесь:

Дано целое число. Вывести его строку-описание вида «отрицательное чет-ное число», «нулевое число», «положительное нечетное число» и т. д. C++
C (СИ) Считать строку, и найти число вхождений символа в эту строку (с использованием strchr)
C++ Программа на С, которая вводит число типа int с клавиатуры, преобразует ее в строку (str), выводит на дисплей число и строку.
Преобразовать число в строку записать строку в обратном порядке Turbo Pascal
Prolog Дана строка S и число N. Преобразовать строку S в строку длины N следующим образом - см. текст задачи

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
grgdvo
504 / 445 / 121
Регистрация: 02.09.2012
Сообщений: 1,311
15.12.2016, 05:34     Сложную строку в число #2
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Лучше так
SQL
1
SELECT SUBSTRING(TRIM(' 234-a03k=sjkow%'), '^[0-9]+')::INTEGER
По умолчанию звездочка "жадная" штука, что может приводить к странным на первый взгляд вещам.
Так, в вашем случае при ошибочной входной строке будет ошибка преобразования
SQL
1
SELECT SUBSTRING(TRIM('a234-a03k=sjkow%'), '(^[0-9]*)*')::INTEGER  --> ERROR!!!
А так будет просто NULL
SQL
1
SELECT SUBSTRING(TRIM('a234-a03k=sjkow%'), '^[0-9]+')::INTEGER
Отличие можно увидеть так

SQL
1
SELECT regexp_matches('a234-a03k=sjkow%', '^[0-9]+')
возвращает пустоту (NULL)

SQL
1
SELECT regexp_matches('a234-a03k=sjkow%', '(^[0-9]*)*')
возвращает массив с пустой строкой (строка нулевой длины)
SQL
1
{""}
что к числу уже не преобразуется также как и
SQL
1
SELECT ''::INTEGER --> ERROR!!!
Tester64
395 / 356 / 43
Регистрация: 22.05.2013
Сообщений: 2,502
15.12.2016, 13:42  [ТС]     Сложную строку в число #3
Цитата Сообщение от grgdvo Посмотреть сообщение
Лучше так
Спасибо! проверю... не подумал проверить поставив в начало букву... хотя можно попробовать символ "0" в начало всегда добавля...
(регулярку так и не выучил - применять пока негде - первый раз за много лет)
Yandex
Объявления
15.12.2016, 13:42     Сложную строку в число
Ответ Создать тему
Опции темы

Текущее время: 11:35. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru