Поиск текста с помощью регулярных выраженийsearch text with regular expressions

Use-Case

In general, when you migrate a database, the dependent objects also need to be migrated. For example, a linked server or specific column values of specific tables that reference a renamed table. Let’s get in-depth about the process of handling such changes dynamically using the SQL REPLACE function with T-SQL constructs.

In one complex database migration project, the server has multiple Linked Server configurations. These linked servers were referred and mentioned in multiple stored procedures. It is a matter of the fact to find and replace the stored procedure scripts but the intent is to automate the entire process to make sure that we are not going to do any manual updates.

Let me take you through the simple steps.

Step 1:

In this case, the search pattern is employee. Also, you see that the custom escape character is used to escape special characters ‘’ in the search pattern.

1
2
3
4
5
6

DECLARE@searchPatternVARCHAR(100)=’employee’;

SELECTDISTINCT

‘sp_helptext »’+OBJECT_SCHEMA_NAME(id)+’.’+OBJECT_NAME(id)+»’ ‘

FROMsyscomments

WHERETEXTLIKE’%’+REPLACE(REPLACE(@searchPattern,’]’,’\]’),'[‘,’\[‘)+’%’ESCAPE’\’

ORDERBY’sp_helptext »’+OBJECT_SCHEMA_NAME(id)+’.’+OBJECT_NAME(id)+»’ ‘;

We can see in the output that 13 objects are listed by satisfying the search condition employee.

Step 2:

Now, it is simple to loop through the listed objects and generate the script and store it a temp table.

Step 3:

Perform a simple update to change the keyword create to “ALTER”. This way the script is ready to execute on the target database. In some cases, you just need to retain the script. That is still fine but don’t run this step.

1
2
3
4
5

UPDATE@sptemp

SET

storedProcedureText=REPLACE(REPLACE(storedProcedureText,’CREATE PROCEDURE’,’ALTER PROCEDURE’),@searchpattern,@replacestring);

SELECTstoredProcedureText

FROM@sptemp;

It’s time to copy and paste result into new query window then make sure everything looks good to run the SQL.

In the below output you can see that search pattern employee is replaced by Prashanth.

You can refer the complete code in the Appendix section.

Appendix

T-SQL code to replace a string in all intended Stored Procedures automatically.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32

SETNOCOUNTON;

DECLARE@sqlNVARCHAR(MAX),@searchpatternVARCHAR(100)=’employee’,@replacestringVARCHAR(100)=’Prashanth’;

 
— this will hold stored procedures text

DECLARE@sptempTABLE(storedProcedureTextVARCHAR(MAX));

DECLAREcurCURSORFAST_FORWARD

FORSELECTDISTINCT

‘sp_helptext »’+OBJECT_SCHEMA_NAME(id)+’.’+OBJECT_NAME(id)+»’ ‘

FROMsyscomments

WHERETEXTLIKE’%’+REPLACE(REPLACE(@searchpattern,’]’,’\]’),'[‘,’\[‘)+’%’ESCAPE’\’

ORDERBY’sp_helptext »’+OBJECT_SCHEMA_NAME(id)+’.’+OBJECT_NAME(id)+»’ ‘;

 
—Open Cursor

OPENcur;

FETCHNEXTFROMcurINTO@sql;

WHILE@@FETCH_STATUS=

BEGIN

—stored procedure script into a column

INSERTINTO@sptemp

EXEC(@sql);

— Add GO keyword

INSERTINTO@sptemp

VALUES(‘GO’);

FETCHNEXTFROMcurINTO@sql;

END;

CLOSEcur;

DEALLOCATEcur;

UPDATE@sptemp

SET

storedProcedureText=REPLACE(REPLACE(storedProcedureText,’CREATE PROCEDURE’,’ALTER PROCEDURE’),@searchpattern,@replacestring);

SELECTstoredProcedureText

FROM@sptemp;

Функции для работы со строками

Последнее обновление: 29.07.2017

Для работы со строками в T-SQL можно применять следующие функции:

  • LEN: возвращает количество символов в строке. В качестве параметра в функцию передается строка, для которой надо найти длину:

    SELECT LEN('Apple')  -- 5
  • LTRIM: удаляет начальные пробелы из строки. В качестве параметра принимает строку:

    SELECT LTRIM('  Apple')
  • RTRIM: удаляет конечные пробелы из строки. В качестве параметра принимает строку:

    SELECT RTRIM(' Apple    ')
  • CHARINDEX: возвращает индекс, по которому находится первое вхождение подстроки в строке. В качестве
    первого параметра передается подстрока, а в качестве второго — строка, в которой надо вести поиск:

    SELECT CHARINDEX('pl', 'Apple')	-- 3
  • PATINDEX: возвращает индекс, по которому находится первое вхождение определенного шаблона в строке:

    SELECT PATINDEX('%p_e%', 'Apple')	-- 3
  • LEFT: вырезает с начала строки определенное количество символов. Первый параметр функции — строка, а второй — количество символов, которые надо вырезать сначала строки:

    SELECT LEFT('Apple', 3)	-- App
  • RIGHT: вырезает с конца строки определенное количество символов. Первый параметр функции — строка, а второй — количество символов, которые надо вырезать сначала строки:

    SELECT RIGHT('Apple', 3)	-- ple
  • SUBSTRING: вырезает из строки подстроку определенной длиной, начиная с определенного индекса.
    Певый параметр функции — строка, второй — начальный индекс для вырезки, и третий параметр — количество вырезаемых символов:

    SELECT SUBSTRING('Galaxy S8 Plus', 8, 2)	-- S8
  • REPLACE: заменяет одну подстроку другой в рамках строки. Первый параметр функции — строка, второй — подстрока, которую надо заменить, а третий — подстрока, на которую надо заменить:

    SELECT REPLACE('Galaxy S8 Plus', 'S8 Plus', 'Note 8')	-- Galaxy Note 8
  • REVERSE: переворачивает строку наоборот:

    SELECT REVERSE('123456789')	-- 987654321
  • CONCAT: объединяет две строки в одну. В качестве параметра принимает от 2-х и более строк, которые надо соединить:

    SELECT CONCAT('Tom', ' ', 'Smith')	-- Tom Smith
  • LOWER: переводит строку в нижний регистр:

    SELECT LOWER('Apple')	-- apple
  • UPPER: переводит строку в верхний регистр

    SELECT UPPER('Apple')	-- APPLE
  • SPACE: возвращает строку, которая содержит определенное количество пробелов

Например, возьмем таблицу:

CREATE TABLE Products
(
    Id INT IDENTITY PRIMARY KEY,
    ProductName NVARCHAR(30) NOT NULL,
    Manufacturer NVARCHAR(20) NOT NULL,
    ProductCount INT DEFAULT 0,
    Price MONEY NOT NULL
);

И при извлечении данных применим строковые функции:

SELECT UPPER(LEFT(Manufacturer,2)) AS Abbreviation,
	   CONCAT(ProductName, ' - ',  Manufacturer) AS FullProdName
FROM Products
ORDER BY Abbreviation

НазадВперед

另请参阅See Also

CONCAT (Transact-SQL)CONCAT (Transact-SQL)CONCAT_WS (Transact-SQL)CONCAT_WS (Transact-SQL)FORMATMESSAGE (Transact-SQL)FORMATMESSAGE (Transact-SQL)QUOTENAME (Transact-SQL)QUOTENAME (Transact-SQL)REVERSE (Transact-SQL)REVERSE (Transact-SQL)STRING_AGG (Transact-SQL)STRING_AGG (Transact-SQL)STRING_ESCAPE (Transact-SQL)STRING_ESCAPE (Transact-SQL)STUFF (Transact-SQL)STUFF (Transact-SQL)TRANSLATE (Transact-SQL)TRANSLATE (Transact-SQL)数据类型 (Transact-SQL) Data Types (Transact-SQL) 字符串函数 (Transact-SQL)String Functions (Transact-SQL)

Example: Split an IP address into 4 respective octets using MySQL SUBSTRING_INDEX() function

The following MySQL command splits an IP address into 4 respecting octets (unit of digital information). Assume the IP addresses are stored in a sample table called ‘log_file’.

mysql> SELECT ip, SUBSTRING_INDEX(ip,'.',1) AS part1, 
SUBSTRING_INDEX(SUBSTRING_INDEX(ip,'.',2),'.',-1) AS part2, 
SUBSTRING_INDEX(SUBSTRING_INDEX(ip,'.',-2),'.',1) AS part3, 
SUBSTRING_INDEX(ip,'.',-1) AS part4  FROM log_file;
+-----------------+-------+-------+-------+-------+
| ip              | part1 | part2 | part3 | part4 |
+-----------------+-------+-------+-------+-------+
| 127.0.0.1       | 127   | 0     | 0     | 1     |
| 192.128.0.15    | 192   | 128   | 0     | 15    |
| 255.255.255.255 | 255   | 255   | 255   | 255   |
+-----------------+-------+-------+-------+-------+
3 rows in set (0.00 sec)

All String Functions

Previous:
SUBSTRNext:
SUBSTRING

SQL References

SQL Keywords
ADD
ADD CONSTRAINT
ALTER
ALTER COLUMN
ALTER TABLE
ALL
AND
ANY
AS
ASC
BACKUP DATABASE
BETWEEN
CASE
CHECK
COLUMN
CONSTRAINT
CREATE
CREATE DATABASE
CREATE INDEX
CREATE OR REPLACE VIEW
CREATE TABLE
CREATE PROCEDURE
CREATE UNIQUE INDEX
CREATE VIEW
DATABASE
DEFAULT
DELETE
DESC
DISTINCT
DROP
DROP COLUMN
DROP CONSTRAINT
DROP DATABASE
DROP DEFAULT
DROP INDEX
DROP TABLE
DROP VIEW
EXEC
EXISTS
FOREIGN KEY
FROM
FULL OUTER JOIN
GROUP BY
HAVING
IN
INDEX
INNER JOIN
INSERT INTO
INSERT INTO SELECT
IS NULL
IS NOT NULL
JOIN
LEFT JOIN
LIKE
LIMIT
NOT
NOT NULL
OR
ORDER BY
OUTER JOIN
PRIMARY KEY
PROCEDURE
RIGHT JOIN
ROWNUM
SELECT
SELECT DISTINCT
SELECT INTO
SELECT TOP
SET
TABLE
TOP
TRUNCATE TABLE
UNION
UNION ALL
UNIQUE
UPDATE
VALUES
VIEW
WHERE

MySQL Functions
String Functions

ASCII
CHAR_LENGTH
CHARACTER_LENGTH
CONCAT
CONCAT_WS
FIELD
FIND_IN_SET
FORMAT
INSERT
INSTR
LCASE
LEFT
LENGTH
LOCATE
LOWER
LPAD
LTRIM
MID
POSITION
REPEAT
REPLACE
REVERSE
RIGHT
RPAD
RTRIM
SPACE
STRCMP
SUBSTR
SUBSTRING
SUBSTRING_INDEX
TRIM
UCASE
UPPER

Numeric Functions
ABS
ACOS
ASIN
ATAN
ATAN2
AVG
CEIL
CEILING
COS
COT
COUNT
DEGREES
DIV
EXP
FLOOR
GREATEST
LEAST
LN
LOG
LOG10
LOG2
MAX
MIN
MOD
PI
POW
POWER
RADIANS
RAND
ROUND
SIGN
SIN
SQRT
SUM
TAN
TRUNCATE

Date Functions
ADDDATE
ADDTIME
CURDATE
CURRENT_DATE
CURRENT_TIME
CURRENT_TIMESTAMP
CURTIME
DATE
DATEDIFF
DATE_ADD
DATE_FORMAT
DATE_SUB
DAY
DAYNAME
DAYOFMONTH
DAYOFWEEK
DAYOFYEAR
EXTRACT
FROM_DAYS
HOUR
LAST_DAY
LOCALTIME
LOCALTIMESTAMP
MAKEDATE
MAKETIME
MICROSECOND
MINUTE
MONTH
MONTHNAME
NOW
PERIOD_ADD
PERIOD_DIFF
QUARTER
SECOND
SEC_TO_TIME
STR_TO_DATE
SUBDATE
SUBTIME
SYSDATE
TIME
TIME_FORMAT
TIME_TO_SEC
TIMEDIFF
TIMESTAMP
TO_DAYS
WEEK
WEEKDAY
WEEKOFYEAR
YEAR
YEARWEEK

Advanced Functions
BIN
BINARY
CASE
CAST
COALESCE
CONNECTION_ID
CONV
CONVERT
CURRENT_USER
DATABASE
IF
IFNULL
ISNULL
LAST_INSERT_ID
NULLIF
SESSION_USER
SYSTEM_USER
USER
VERSION

SQL Server Functions
String Functions
ASCII
CHAR
CHARINDEX
CONCAT
Concat with +
CONCAT_WS
DATALENGTH
DIFFERENCE
FORMAT
LEFT
LEN
LOWER
LTRIM
NCHAR
PATINDEX
QUOTENAME
REPLACE
REPLICATE
REVERSE
RIGHT
RTRIM
SOUNDEX
SPACE
STR
STUFF
SUBSTRING
TRANSLATE
TRIM
UNICODE
UPPER

Numeric Functions
ABS
ACOS
ASIN
ATAN
ATN2
AVG
CEILING
COUNT
COS
COT
DEGREES
EXP
FLOOR
LOG
LOG10
MAX
MIN
PI
POWER
RADIANS
RAND
ROUND
SIGN
SIN
SQRT
SQUARE
SUM
TAN

Date Functions
CURRENT_TIMESTAMP
DATEADD
DATEDIFF
DATEFROMPARTS
DATENAME
DATEPART
DAY
GETDATE
GETUTCDATE
ISDATE
MONTH
SYSDATETIME
YEAR

Advanced Functions
CAST
COALESCE
CONVERT
CURRENT_USER
IIF
ISNULL
ISNUMERIC
NULLIF
SESSION_USER
SESSIONPROPERTY
SYSTEM_USER
USER_NAME

MS Access Functions
String Functions
Asc
Chr
Concat with &
CurDir
Format
InStr
InstrRev
LCase
Left
Len
LTrim
Mid
Replace
Right
RTrim
Space
Split
Str
StrComp
StrConv
StrReverse
Trim
UCase

Numeric Functions
Abs
Atn
Avg
Cos
Count
Exp
Fix
Format
Int
Max
Min
Randomize
Rnd
Round
Sgn
Sqr
Sum
Val

Date Functions
Date
DateAdd
DateDiff
DatePart
DateSerial
DateValue
Day
Format
Hour
Minute
Month
MonthName
Now
Second
Time
TimeSerial
TimeValue
Weekday
WeekdayName
Year

Other Functions
CurrentUser
Environ
IsDate
IsNull
IsNumeric

SQL Quick Ref

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *

Adblock
detector