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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Замена текста средствами SQL 
V
    Опции темы
alexburzak
  Дата 10.9.2007, 18:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Обыкновенный запрос ввиде:
SELECT Mobile
FROM MyTable
получаю номера мобилок в формате 123-345678
Можно средствами SQL убрать символ "-"? Что-то вроде замена текста, вместо "-" поставить "".
Как это сделать?
PM   Вверх
Anark1
Дата 10.9.2007, 20:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 622
Регистрация: 15.12.2006
Где: RF -> Moscow

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



Помогут операторы CONCAT и SUBSTRING
Код

UPDATE fld SET text_fld = CONCAT(text_fld, 'к строке будет добавлено это предложение');


Код

SELECT SUBSTRING ('123-456789', 1, 3); 

этот запрос вытащит строку '123'. С первой позиции 3 символа.

Твой запрос примерно так :
Код

SELECT SUBSTRING('123-456789',1 ,3) str1;
SELECT SUBSTRING('123-456789',5 ,6) str2;
UPDATE mytable SET str = CONCAT(str1, '.', str2);

Код MySQL на вскидку. Сам не проверял.


Это сообщение отредактировал(а) Anark1 - 10.9.2007, 20:14


--------------------
Enjoy yourself, still you can...;)

user posted image

user posted image
PM MAIL ICQ   Вверх
Riddler
Дата 10.9.2007, 20:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



select replace(mobile,'-','') as nmob from MyTable

REPLACE ( original-string, search-string, replace-string )

Standards and compatibility
SQL/92    Vendor extension.
SQL/99    Vendor extension.
Исходя из последних 3-х строк полагаю что не на каждом сервере реализована функция замены строк, ну и конечно же синтаксис может отличаться, поскольку является расширением разработчика сервера.

PM MAIL   Вверх
alexburzak
  Дата 11.9.2007, 09:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Сделал вот так:
SELECT (SUBSTRING(Mobile, 0, 4) + SUBSTRING(Mobile, 5, 7) + ';') as Mobile
База данных MS SQL
Спасибо всем - вопрос решен.
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

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

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


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

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


 




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


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

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