SQLͨÅä·û¼°Ä£Ê½Æ¥Åä
ǰÌá,MS SQLµÄͨÅä·ûº¬Ò壺
ÐòºÅ
ͨÅä·û
º¬Òå
ʾÀý
1
%
°üº¬Áã¸ö»ò¶à¸ö×Ö·ûµÄÈÎÒâ×Ö·û´®¡£
WHERE title LIKE '%computer%' ½«²éÕÒÔÚÊéÃûÖÐÈÎÒâλÖðüº¬µ¥´Ê"computer" µÄËùÓÐÊéÃû¡£
2
_
Èκε¥¸ö×Ö·û¡£
WHERE au_fname LIKE '_ean' ½«²éÕÒÒÔ ean ½áβµÄËùÓÐ 4 ¸ö×ÖĸµÄÃû×Ö£¨Dean¡¢Sean µÈ£©¡£
3
[ ]
Ö¸¶¨·¶Î§ ([a-f]) »ò¼¯ºÏ ([abcdef]) ÖеÄÈκε¥¸ö×Ö·û¡£
WHERE au_lname LIKE '[C-P]arsen' ½«²éÕÒÒÔ arsen ½áβ²¢ÇÒÒÔ½éÓÚ C Óë P Ö®¼äµÄÈκε¥¸ö×Ö·û¿ªÊ¼µÄ×÷ÕßÐÕÊÏ£¬ÀýÈç Carsen¡¢Larsen¡¢Karsen µÈ¡£ÔÚ·¶Î§ËÑË÷ÖУ¬·¶Î§°üº¬µÄ×Ö·û¿ÉÄÜÒòÅÅÐò¹æÔòµÄÅÅÐò¹æÔò¶øÒì¡£
4
[^]
²»ÊôÓÚÖ¸¶¨·¶Î§ ([a-f]) »ò¼¯ºÏ ([abcdef]) µÄÈκε¥¸ö×Ö·û¡£
WHERE au_lname LIKE 'de[^l]%' ½«²éÕÒÒÔ de ¿ªÊ¼²¢ÇÒÆäºóµÄ×Öĸ²»Îª l µÄËùÓÐ×÷ÕßµÄÐÕÊÏ¡£
¶¨Òå²âÊÔ±í£º
create table EscapePattern(value varchar(100))
go
insert into EscapePattern
select 'aSQL'
union all select 'SQL'
union all select 'SQLa'
union all select 'ÖÐSQL'
union all select 'SQLÖÐ'
union all select 'aSQLa'
union all select 'ÖÐSQLÖÐ'
union all select 'SQaL'
union all select 'SQÖÐL'
union all select 'aSQaLa'
union all select 'ÖÐSQÖÐLÖÐ'
union all select 'Öйú_CN'
union all select 'a%ddd%b'
union all select '[]'
union all select '[[]'
union all select '[]]'
union all select '[[]]'
union all select '^-]'
union all select 'a^-]a'
È»ºó£¬ÎÒÃǽøÐÐÖð¸ö·ÖÎö
1¡¢ÎÒÃÇÖªµÀ£¬¶ÔÓÚ×Ö·û´®£¬Æä¿ªÊ¼ºÍ½áÊø±êʶ·ûΪµ¥ÒýºÅ£¬Èç¹û×Ö·û´®ÀïÃæÓе¥ÒýºÅ£¬ÎÒÃÇ¿ÉÒÔÖ±½ÓʹÓÃÁ½¸öµ¥ÒýºÅÀ´Ìæ´ú¡£
ÐÎÈ磺¿Õ´® '', µ¥ÒýºÅ '''', ×Ö·û´® 'abAB#Öйú×Ö·û´®', °üº¬µ¥ÒýºÅµÄ´® 'abAB#Öйú''×Ö·û´®'.
2¡¢'_' ¡¢ '%'ºÍ'['
(1) '_'Æ¥Åäµ¥¸ö×Ö·û£¬Àý:
select * from EscapePattern where value like '_SQL' --²éÕÒËĸö×Ö·û£¬²¢ÇÒÒÔ'SQL'½áÊøµÄ¼Ç¼
½á¹ûΪ£ºaSQL ÖÐSQL
ÆäÖÐlikeÓï¾ä»¹¿ÉÒÔÕâÑùд£º
'SQL_' ²éÕÒËĸö×Ö·û£¬²¢ÇÒÒÔ'SQL'¿ªÊ¼µÄ¼Ç¼£¬½á¹û£ºSQLa SQLÖÐ
'SQ_L' ²éÕÒËĸö×Ö·û£¬²¢ÇÒÒÔ'SQ'¿ªÊ¼£¬ÒÔ'L'½áÊøµÄ¼Ç¼£¬½á¹û£ºSQaL SQÖÐL
'_SQL_' ²éÕÒÎå¸ö×Ö·û£¬ÖмäµÄÈý¸ö×
Ïà¹ØÎĵµ£º
ÔÚSQL ServerµÄÐÔÄܵ÷ÓÅÖУ¬ÓÐÒ»¸ö²»¿É±ÈÄâµÄÎÊÌ⣺ÄǾÍÊÇÈçºÎÔÚÒ»¶ÎÐèÒª³¤Ê±¼äµÄ´úÂë»ò±»Æµ·±µ÷ÓõĴúÂëÖд¦ÀíÁÙʱÊý¾Ý¼¯?±í±äÁ¿ºÍÁÙʱ±íÊÇÁ½ÖÖÑ¡Ôñ¡£
¡¡¡¡ÔÚSQL ServerµÄÐÔÄܵ÷ÓÅÖУ¬ÓÐÒ»¸ö²»¿É±ÈÄâµÄÎÊÌ⣺ÄǾÍÊÇÈçºÎÔÚÒ»¶ÎÐèÒª³¤Ê±¼äµÄ´úÂë»ò±»Æµ·±µ÷ÓõĴúÂëÖд¦ÀíÁÙʱÊý¾Ý¼¯?±í±äÁ¿ºÍÁÙʱ±íÊÇÁ½ÖÖÑ¡Ôñ¡£¼ÇµÃÔÚ¸øÒ»¼Ò ......
ÓÃEXPLAIN PLAN ·ÖÎöSQLÓï¾ä
http://blog.csdn.net/kj021320/archive/2006/08/19/1096021.aspx
ÈçºÎÉú³Éexplain plan?
¡¡¡¡½â´ð:ÔËÐÐutlxplan.sql. ½¨Á¢plan ±í
¡¡¡¡Õë¶ÔÌØ¶¨SQLÓï¾ä£¬Ê¹Óà explain plan set statement_id = 'tst1' into plan_table
¡¡¡¡ÔËÐÐutlxplp.sql »ò utlxpls.sql²ì¿´explain plan
EXPLAIN PLA ......
RANK ( ) OVER ( [query_partition_clause] order_by_clause )
DENSE_RANK ( ) OVER ( [query_partition_clause] order_by_clause )
¿ÉʵÏÖ°´Ö¸¶¨µÄ×ֶηÖ×éÅÅÐò£¬¶ÔÓÚÏàͬ·Ö×é×ֶεĽá¹û¼¯½øÐÐÅÅÐò,
ÆäÖÐPARTITION BY Ϊ·Ö×é×ֶΣ¬ORDER BY Ö¸¶¨ÅÅÐò×Ö¶Î
over²»Äܵ¥¶ÀʹÓã¬ÒªºÍ·ÖÎöº¯Êý£ºrank(),dense_rank(),row_n ......
Transact-SQL
ÓïÑÔʹÓõÄÁ÷³Ì¿ØÖÆÃüÁîÓë³£¼ûµÄ³ÌÐòÉè¼ÆÓïÑÔÀàËÆÖ÷ÒªÓÐÒÔϼ¸ÖÖ¿ØÖÆÃüÁî¡£
4.6.1 IF…ELSE
ÆäÓï·¨ÈçÏ£º
IF <Ìõ¼þ±í´ïʽ>
<ÃüÁîÐлò³ÌÐò¿é>
[ELSE [Ìõ¼þ±í´ïʽ]
<ÃüÁîÐлò³ÌÐò¿é>]
ÆäÖÐ<Ìõ¼þ±í´ïʽ>¿ÉÒÔÊǸ÷ÖÖ±í´ïʽµÄ×éºÏ£¬µ«±í´ïʽµÄÖµ±ØÐëÊÇÂß¼Öµ“Õæ&rdq ......