• Новости
  • Темы
    • Экономика
    • Здоровье
    • Авто
    • Наука и техника
    • Недвижимость
    • Туризм
    • Спорт
    • Кино
    • Музыка
    • Стиль
  • Спецпроекты
  • Телевидение
  • Знания
    • Энциклопедия
    • Библия
    • Коран
    • История
    • Книги
    • Наука
    • Детям
    • КМ школа
    • Школьный клуб
    • Рефераты
    • Праздники
    • Гороскопы
    • Рецепты
  • Сервисы
    • Погода
    • Курсы валют
    • ТВ-программа
    • Перевод единиц
    • Таблица Менделеева
    • Разница во времени
Ограничение по возрасту 12
KM.RU
Рефераты
Главная → Рефераты → Информатика, программирование
  • Новости
  • В России
  • В мире
  • Экономика
  • Наука и техника
  • Недвижимость
  • Авто
  • Туризм
  • Здоровье
  • Спорт
  • Музыка
  • Кино
  • Стиль
  • Телевидение
  • Спецпроекты
  • Книги
  • Telegram-канал

Поиск по рефератам и авторским статьям

Работа с регулярными выражениями в SQL Server

Христофоров Юрий

В SQL Server 7/2000 нет встроенной поддержки работы с регулярными выражениями. Но SQL Server похволяет работать с COM-объектами. В VBScript (библиотека vbscript.dll) есть специальный объект для работы с регулярными выражениями - RegExp.

Ниже приведен код хранимой процедуры sp_RegExpReplace, которая позволяет заменять текст, удовлетворяющий заданному регулярному выражению на другой заданный текст в строке.

Текст процедуры sp_RegExpReplace:

CREATE PROCEDURE [dbo].sp_RegExpReplace

 @strIn1 varchar(8000),

 @strIn2 varchar(8000),

 @strPattern varchar(2000),

 @strOut varchar(8000) OUT

AS

 DECLARE @object int, @hr int

 DECLARE @src varchar(255), @desc varchar(255)

 -- создаем объект RegExp для работы с регулярными выражениями

 EXEC @hr = sp_OACreate 'VBScript.RegExp', @object OUT

 

 IF (@hr <> 0) BEGIN

         EXEC sp_OAGetErrorInfo @object, @src OUT, @desc OUT

         SELECT hr=convert(varbinary(4),@hr), Source=@src, Description=@desc

  RETURN

 END

 

 EXEC @hr = sp_OASetProperty @object, 'Pattern', @strPattern

 IF (@hr <> 0) BEGIN

         EXEC sp_OAGetErrorInfo @object, @src OUT, @desc OUT

         SELECT hr=convert(varbinary(4),@hr), Source=@src, Description=@desc

  RETURN @hr

 END

 -- будет глобальная замена

 EXEC @hr = sp_OASetProperty @object, 'Global', 1

 IF (@hr <> 0) BEGIN

         EXEC sp_OAGetErrorInfo @object, @src OUT, @desc OUT

         SELECT hr=convert(varbinary(4),@hr), Source=@src, Description=@desc

  RETURN @hr

 END

 -- вызов метода Replace

 EXEC @hr = sp_OAMethod @object, 'Replace', @strOut OUT, @strIn1, @strIn2

 IF (@hr <> 0) BEGIN

         EXEC sp_OAGetErrorInfo @object, @src OUT, @desc OUT

         SELECT hr=convert(varbinary(4),@hr), Source=@src, Description=@desc

  RETURN @hr

 END

 -- удаляем объект

 EXEC @hr = sp_OADestroy @object

 IF (@hr <> 0) BEGIN

         EXEC sp_OAGetErrorInfo @object, @src OUT, @desc OUT

         SELECT hr=convert(varbinary(4),@hr), Source=@src, Description=@desc

  RETURN @hr

 END

 RETURN 0

Необходимо учитывать, что пользователь, от имени которого будет запускаться наша процедура, должен входить в роль sysadmin (это ограничение накладывают процедуры sp_OACreate, sp_OASetProperty, sp_OAMethod, sp_OADestroy).

Протестируем процедуру sp_RegExpReplace - удалим с ее помощью из заданной строки все HTML-теги.

DECLARE @strOut varchar(8000)

EXEC sp_RegExpReplace 'Это тестовый <b>тест</b> <p> текст',

   '', '<.+?>', @strOut OUT

SELECT @strOut

GO

В результате значением переменной @strOut будет строка "Это тестовый тест текст".

Файлы SQL-скриптов прилагаются: sqlregexp.zip

Список литературы

Для подготовки данной работы были использованы материалы с сайта http://www.activex.net.ru/

Дата добавления: 02.10.2006

База рефератов на портале KM.RU существует с 1999 года. Она пополнялась не только готовыми рефератами, докладами, курсовыми, но и авторскими публикациями, чтобы учащиеся могли использовать их и цитировать при самостоятельном написании работ.


Это популяризирует авторские исследования и научные изыскания, что и является целью работы истинного ученого или публициста. Таким образом, наша база - электронная библиотека, созданная в помощь студентам и школьникам.


Уважаемые авторы! Если Вы все же возражаете против размещения Вашей публикации или хотите внести коррективы, напишите нам на почту info@corp.km.ru, мы незамедлительно выполним Вашу просьбу или требование.


официальный сайт © ООО «КМ онлайн», 1999-2025 О проекте ·Все проекты ·Выходные данные ·Контакты ·Реклама
]]>
]]>
Сетевое издание KM.RU. Свидетельство о регистрации Эл № ФС 77 – 41842.
Мнения авторов опубликованных материалов могут не совпадать с позицией редакции.

Мультипортал KM.RU: актуальные новости, авторские материалы, блоги и комментарии, фото- и видеорепортажи, почта, энциклопедии, погода, доллар, евро, рефераты, телепрограмма, развлечения.

Карта сайта


Подписывайтесь на наш Telegram-канал и будьте в курсе последних событий.


Организации, запрещенные на территории Российской Федерации
Telegram Logo

Используя наш cайт, Вы даете согласие на обработку файлов cookie. Если Вы не хотите, чтобы Ваши данные обрабатывались, необходимо установить специальные настройки в браузере или покинуть сайт.