SQLÖÐJOINºÍUNIONÇø±ð¡¢Ó÷¨¼°Ê¾Àý
1.JOINºÍUNIONÇø±ð
join ÊÇÁ½Õűí×ö½»Á¬ºóÀïÃæÌõ¼þÏàͬµÄ²¿·Ö¼Ç¼²úÉúÒ»¸ö¼Ç¼¼¯£¬
unionÊDzúÉúµÄÁ½¸ö¼Ç¼¼¯(×Ö¶ÎÒªÒ»ÑùµÄ)²¢ÔÚÒ»Æð£¬³ÉΪһ¸öеļǼ¼¯ ¡£
JOINÓÃÓÚ°´ÕÕONÌõ¼þÁª½ÓÁ½¸ö±í£¬Ö÷ÒªÓÐËÄÖÖ£º
INNER JOIN£ºÄÚ²¿Áª½ÓÁ½¸ö±íÖеļǼ£¬½öµ±ÖÁÉÙÓÐÒ»¸öͬÊôÓÚÁ½±íµÄÐзûºÏÁª½ÓÌõ¼þʱ£¬ÄÚÁª½Ó²Å·µ»ØÐС£ÎÒÀí½âµÄÊÇÖ»Òª¼Ç¼²»·ûºÏONÌõ¼þ£¬¾Í²»»áÏÔʾÔÚ½á¹û¼¯ÄÚ¡£
LEFT JOIN / LEFT OUTER JOIN£ºÍⲿÁª½ÓÁ½¸ö±íÖеļǼ£¬²¢°üº¬×ó±íÖеÄÈ«²¿¼Ç¼¡£Èç¹û×ó±íµÄij¼Ç¼ÔÚÓÒ±íÖÐûÓÐÆ¥Åä¼Ç¼£¬ÔòÔÚÏà¹ØÁªµÄ½á¹û¼¯ÖÐÓÒ±íµÄËùÓÐÑ¡ÔñÁбíÁоùΪ¿ÕÖµ¡£Àí½âΪ¼´Ê¹²»·ûºÏONÌõ¼þ£¬×ó±íÖеļǼҲȫ²¿ÏÔʾ³öÀ´£¬ÇÒ½á¹û¼¯ÖиÃÀà¼Ç¼µÄÓÒ±í×Ö¶ÎΪ¿ÕÖµ¡£
RIGHT JOIN / RIGHT OUTER JOIN£ºÍⲿÁª½ÓÁ½¸ö±íÖеļǼ£¬²¢°üº¬ÓÒ±íÖеÄÈ«²¿¼Ç¼¡£¼òµ¥Ëµ¾ÍÊǺÍLEFT JOIN·´¹ýÀ´¡£
FULL JOIN / FULL OUTER JOIN£ºÍêÕûÍⲿÁª½Ó·µ»Ø×ó±íºÍÓÒ±íÖеÄËùÓÐÐС£¾ÍÊÇLEFT JOINºÍRIGHT JOINºÍºÏ²¢£¬×óÓÒÁ½±íµÄÊý¾Ý¶¼È«²¿ÏÔʾ¡£
JOINµÄ»ù±¾Óï·¨£º
Select table1.* from table1 JOIN table2 ON table1.id=table2.id
sqlд·¨
ÄÚÁ¬½Óinner join£º
SELECT msp.name, party.name
from msp JOIN party ON party=code
»ò
SELECT msp.name, party.name
from msp inner JOIN party ON party=code
×óÁ¬½Óleft join £º
SELECT msp.name, party.name
from msp LEFT JOIN party ON party=code
ÓÒÁ¬½Óright join £º
SELECT msp.name, party.name
from msp RIGHT JOIN party ON msp.party=party.code
È«Á¬½Ó(full join)£º
SELECT msp.name, party.name
from msp FULL JOIN party ON msp.party=party.code
UNIONÔËËã·û
½«Á½¸ö»ò¸ü¶à²éѯµÄ½á¹û¼¯×éºÏΪµ¥¸ö½á¹û¼¯£¬¸Ã½á¹û¼¯°üº¬ÁªºÏ²éѯÖеÄËùÓвéѯµÄÈ«²¿ÐС£UNIONµÄ½á¹û¼¯ÁÐÃûÓëUNIONÔËËã·ûÖеÚÒ»¸öSelectÓï¾äµÄ½á¹û¼¯µÄÁÐÃûÏàͬ¡£ÁíÒ»¸öSelectÓï¾äµÄ½á¹û¼¯ÁÐÃû½«±»ºöÂÔ¡£
ÆäÖÐÁ½ÖÖ²»Í¬µÄÓ÷¨ÊÇUNIONºÍUNION ALL£¬Çø±ðÔÚÓÚUNION´Ó½á¹û¼¯ÖÐɾ³ýÖØ¸´µÄÐС£Èç¹ûʹÓÃUNION ALL ½«°üº¬ËùÓÐÐв¢ÇÒ½«²»É¾³ýÖØ¸´µÄÐС£
UNIONºÍUNION ALLµÄÇø±ð£º
union ¼ì²éÖØ¸´
union all ²»×ö¼ì²é
±ÈÈç select 'a' union select 'a' Êä³ö¾ÍÊÇÒ»ÐÐ a
±ÈÈç select 'a' union all select 'a' Êä³ö¾ÍÊÇÁ½ÐÐ a
2. ͨ¹ýÏÂÃæµÄÀý×Ó£¬¿ÉÒÔÇåÎúµÄ¿´³öºÍÀí½â2ÕßµÄÇø±ð
ʵÀý1 µäÐ͵Ķþ±íÁ¬½ÓÑÝʾ
¼Ù¶¨ÓÐÁ½¸ö±íTable1ºÍTable2£¬Æä°üº¬µÄÁкÍÊý¾Ý·Ö
Ïà¹ØÎĵµ£º
×ֺţº ´ó´ó ÖÐÖРСС
Ëø¶¨Êý¾Ý¿âµÄÒ»¸ö±í
SELECT * from table WITH (HOLDLOCK)
×¢Òâ: Ëø¶¨Êý¾Ý¿âµÄÒ»¸ö±íµÄÇø±ð
SELECT * from table WITH (HOLDLOCK)
ÆäËûÊÂÎñ¿ÉÒÔ¶ÁÈ¡±í£¬µ«²»ÄܸüÐÂɾ³ý
SELECT * from table WITH (TABLOCKX)
ÆäËûÊÂÎñ²»ÄܶÁÈ¡±í,¸üкÍɾ³ý
SELECT Óï¾äÖГ¼ÓË ......
ÆäʵÄã¿ÉÒÔʹÓÃÊÂÎñ´¦Àí
±È·½ËµÔÚÒ»¸ö×Ö¶ÎÀïÃæÌí¼ÓÒ»¸öboolean µÄ×ֶε±ÄãÒª´¦Àí¸Ã×ֶεÄʱºò¾Í True ÄÄô±ðµÄÈ˶¼²»¿ÉÒÔ½øÐвÙ×÷
¡¡Èç¹ûÊÇFalse ÄÄô¾Í¿ÉÒÔ½øÐвÙ×÷¡«¡«ºÇ¿É¡«¡«ÎÒÊÇÕâÑùµÄ
¡¡¡¡²»¹ýÄã¿ÉÒÔ¿´¿´¡¡
¡¡SQLËø»úÖÆ
¡¡¡¡ÒÔÏÂÊÇÎÒÕÒµÄһЩÁÏ¡¡Èç¹ûÒªÀí½âSQLËø»úÖÆ ×îºÃ°ÑÏÂÀ´¿´ÍêŶ
ĬÈϵÄÊÂÎñ¸ôÀë¼ ......
SQL Server 2005 (MSSQLSERVER) ·þÎñ²»ÄÜÆô¶¯
ÔÒò:VIAÐÒ锸øÆôÓÃÁË£¬Í£ÓÓVIAÐÒé”ÎÊÌâ½â¾ö¡£
"VIAÐÒé"Í£Ó÷½·¨£º¿ªÊ¼->³ÌÐò->Microsoft SQL Server 2005->ÅäÖù¤¾ß->SQL Server Configuration Manager ->´ò¿ªºóÕÒµ½"SQL Server 2005 ÍøÂçÅäÖÃ"->MSSQLSERVER ÊôÐÔµÄÐÒé &nb ......
--²éѯӦÓóÌÐòµÄµÈ´ý
SELECT TOP 10
wait_type,waiting_tasks_count AS tasks,
wait_time_ms,max_wait_time_ms AS max_wait,
signal_wait_time_ms AS signal
from sys.dm_os_wait_stats
ORDER BY wait_time_ms DESC
--²éѯÔÚÈÎһʱ¿ÌËùÓÐÊÚȨ¸øµ±Ç°Ö´ÐÐÊÂÎñ»òµ±Ç°Ö´ÐÐÊÂÎñµÈ´ýµÄËø
SELECT
request_session_id A ......