¹ØÓÚSQL ServerËÀËø
transaction 1:
------------------------------------------------------
begin transaction
update table1 set cola = 'str1'
Waitfor time '10:12:00'
update table2 set colb = 'str2'
rollback transaction
transaction 2:
------------------------------------------------------
begin transaction
update table2 set colb = 'str2'
Waitfor time '10:12:00'
update table1 set cola = 'str1'
rollback transaction
ͬʱÔËÐÐÕâÁ½¸öÊÂÎñ£¬½«µ¼ÖÂËÀËø¡£(ÏÈ´´½¨table1ºÍtable2£¬²¢²åÈëһЩֵ£»waitfor time Êʵ±ÐÞ¸Ä)
SQL Server±¾Éí»á´¦ÀíËÀËø£¬Í¨¹ýÑ¡ÔñÒ»¸öËÀËøÎþÉüÆ·£¬»Ø¹öËÀËøÎþÉüÆ·µÄÊÂÎñ£¬À´±ÜÃâËÀËø¡£
SQL ServerÔÚÉÏÃæÕâÁ½¸öÊÂÎñÖÐ×Ô¶¯Ñ¡ÔñÒ»¸ö×÷ΪËÀËøÎþÉüÆ·£¬¸ÃÊÂÎñ½«ÊÕµ½ÈçÏÂÏûÏ¢£º
------------------------------------------------------
Msg 1205, Level 13, State 56, Line 7
ÊÂÎñ(½ø³Ì ID 52)ÓëÁíÒ»¸ö½ø³Ì±»ËÀËøÔÚ Ëø ×ÊÔ´ÉÏ£¬²¢ÇÒÒѱ»Ñ¡×÷ËÀËøÎþÉüÆ·¡£ÇëÖØÐÂÔËÐиÃÊÂÎñ¡£
SQL ServerÑ¡ÔñËÀËøÎþÉüÆ·¸ù¾ÝµÄÊÇ´ú¼Û×îСÔÔò£¬Óû§Ò²¿ÉÒÔͨ¹ýÉèÖÃDEADLOCK_PRIORITYÑ¡Ïî½øÐиÉÔ¤¡£
ÀýÈ磬ÔÚÊÂÎñ1 set DEADLOCK_PRIORITY low£¬ÔÚÊÂÎñ2 set DEADLOCK_PRIORITY high£¬Ôò·¢ÉúËÀËøÊ±SQL Server½«Ñ¡ÔñÊÂÎñ1×÷ΪËÀËøÎþÉüÆ·¡£
ÈçºÎ±ÜÃâËÀËø£º
1. ¶à¸ö²¢·¢ÊÂÎñ°´ÕÕͬÑùµÄ˳Ðò·ÃÎʶÔÏó
2. ÔÚÊÂÎñÖбÜÃâÓû§½»»¥
3. ¾¡Á¿Ëõ¶ÌÊÂÎñµÄÖ´ÐÐʱ¼ä£¬¿Í»§¶Ë²»Ó¦°ÑÒ»¸öÊÂÎñ·Ö³É¶à´Î·¢ËÍ¡£
4. ÉèÖøüµÍµÄ¸ôÀë¼¶±ð
5. ʹÓÃÀ¦°óÁ¬½Ó
Ïà¹ØÎĵµ£º
-->Title:Generating test data
-->Author:wufeng4552
-->Date :2009-09-25 09:56:07
if object_id('tb')is not null drop table tb
go
create table tb(ID int,name text)
insert tb select 1,'test'
go
--·½·¨1
select sql_variant_property(ID,'BaseType') from tb
--·½·¨2
select object_name(ID)± ......
--ÔÚÈÕ³£Î¬»¤£¬¿ª·¢Öг£Óöµ½Ð´Ò»ÏµÁнṹÀàÐ͵ÄsqlÓï¾ä£¬ºÜ·³ºÜÀÛÆäʵ¿ÉÒÔ
--ÀûÓÃSQL*PLUS»·¾³ÃüÁî Éú³É½Å±¾Îļþ
set heading off --¹Ø±ÕÁеıêÌâ
set feedback off --¹Ø±Õ·´À¡ÐÅÏ¢
  ......
ÎÞÂÛÄúÊÇһλ SQL µÄÐÂÊÖ£¬»òÊÇһλֻÊÇÐèÒª¶Ô SQL ¸´Ï°Ò»ÏµÄ×ÊÁϲִ¢Òµ½çÀϽ«£¬Äú¾ÍÀ´¶ÔµØ·½ÁË£¡
- SQL Ö¸Áî: SQL ÈçºÎ±»ÓÃÀ´´¢´æ¡¢¶ÁÈ¡¡¢ÒÔ¼°´¦ÀíÊý¾Ý¿âÖ®ÖеÄ×ÊÁÏ¡£
- ±í¸ñ´¦Àí: SQL ÈçºÎ±»ÓÃÀ´´¦ÀíÊý¾Ý¿âÖеıí¸ñ¡£
- SQLÓï·¨: ÕâÒ»Ò³ÁгöËùÓÐÔÚÕâ¸ö½Ì²ÄÖб»Ìáµ½µÄ SQL Óï·¨
SQL SELECT
Store_Information ±í¸ñ ......