Ò׽ؽØͼÈí¼þ¡¢µ¥Îļþ¡¢Ãâ°²×°¡¢´¿ÂÌÉ«¡¢½ö160KB

SQL ServerÊý¾Ý¿âËø»úÖƼ°ÀàÐÍ

Microsoft SQL Server£¨ÒÔϼò³ÆSQL Server£©×÷ΪһÖÖÖÐСÐÍÊý¾Ý¿â¹ÜÀíϵͳ£¬ÒѾ­µÃµ½Á˹㷺µÄÓ¦Ó㬸Ãϵͳ¸üÇ¿µ÷ÓÉϵͳÀ´¹ÜÀíËø¡£ÔÚÓû§ÓÐSQLÇëÇóʱ£¬ÏµÍ³·ÖÎöÇëÇó£¬×Ô¶¯ÔÚÂú×ãËø¶¨Ìõ¼þºÍϵͳÐÔÄÜÖ®¼äΪÊý¾Ý¿â¼ÓÉÏÊʵ±µÄËø£¬Í¬Ê±ÏµÍ³ÔÚÔËÐÐÆڼ䳣³£×Ô¶¯½øÐÐÓÅ»¯´¦Àí£¬ÊµÐж¯Ì¬¼ÓËø¡£
¡¡¡¡¶ÔÓÚÒ»°ãµÄÓû§¶øÑÔ£¬Í¨¹ýϵͳµÄ×Ô¶¯Ëø¶¨¹ÜÀí»úÖÆ»ù±¾¿ÉÒÔÂú×ãʹÓÃÒªÇ󣬵«Èç¹û¶ÔÊý¾Ý°²È«¡¢Êý¾Ý¿âÍêÕûÐÔºÍÒ»ÖÂÐÔÓÐÌØÊâÒªÇ󣬾ͱØÐë×Ô¼º¿ØÖÆÊý¾Ý¿âµÄËø¶¨ºÍ½âËø£¬Õâ¾ÍÐèÒªÁ˽âSQL ServerµÄËø»úÖÆ£¬ÕÆÎÕÊý¾Ý¿âËø¶¨·½·¨¡£
¡¡¡¡ËøµÄ¶àÁ£¶ÈÐÔÒÔ¼°ËøÉý¼¶
¡¡¡¡Êý¾Ý¿âÖеÄËøÊÇÖ¸Ò»ÖÖÈí¼þ»úÖÆ£¬ÓÃÀ´Ö¸Ê¾Ä³¸öÓû§£¨Ò²¼´½ø³Ì»á»°£¬ÏÂͬ£©ÒѾ­Õ¼ÓÃÁËijÖÖ×ÊÔ´£¬´Ó¶ø·ÀÖ¹ÆäËûÓû§×ö³öÓ°Ïì±¾Óû§µÄÊý¾ÝÐ޸Ļòµ¼ÖÂÊý¾Ý¿âÊý¾ÝµÄ·ÇÍêÕûÐԺͷÇÒ»ÖÂÐÔ¡£Õâ¶ùËùν×ÊÔ´£¬Ö÷ÒªÖ¸Óû§¿ÉÒÔ²Ù×÷µÄÊý¾ÝÐС¢Ë÷ÒýÒÔ¼°Êý¾Ý±íµÈ¡£¸ù¾Ý×ÊÔ´µÄ²»Í¬£¬ËøÓжàÁ£¶È£¨multigranular£©µÄ¸ÅÄҲ¾ÍÊÇÖ¸¿ÉÒÔËø¶¨µÄ×ÊÔ´µÄ²ã´Î¡£SQL ServerÖÐÄܹ»Ëø¶¨µÄ×ÊÔ´Á£¶È°üÀ¨£ºÊý¾Ý¿â¡¢±í¡¢ÇøÓò¡¢Ò³Ãæ¡¢¼üÖµ£¨Ö¸´øÓÐË÷ÒýµÄÐÐÊý¾Ý£©¡¢Ðбêʶ·û£¨RID£¬¼´±íÖеĵ¥ÐÐÊý¾Ý£©¡£
¡¡¡¡²ÉÓöàÁ£¶ÈËøµÄÖØÒªÓÃ;ÊÇÓÃÀ´Ö§³Ö²¢·¢²Ù×÷ºÍ±£Ö¤Êý¾ÝµÄÍêÕûÐÔ¡£SQL Server¸ù¾ÝÓû§µÄÇëÇó£¬×ö³ö·ÖÎöºó×Ô¶¯¸øÊý¾Ý¿â¼ÓÉϺÏÊʵÄËø¡£¼ÙÉèijÓû§Ö»²Ù×÷Ò»¸ö±íÖеIJ¿·ÖÐÐÊý¾Ý£¬ÏµÍ³¿ÉÄÜ»áÖ»Ìí¼Ó¼¸¸öÐÐËø£¨RID£©»òÒ³ÃæËø£¬ÕâÑù¿ÉÒÔ¾¡¿ÉÄܶàµØÖ§³Ö¶àÓû§µÄ²¢·¢²Ù×÷¡£µ«ÊÇ£¬Èç¹ûÓû§ÊÂÎñÖÐƵ·±¶Ôij¸ö±íÖеĶàÌõ¼Ç¼²Ù×÷£¬½«µ¼Ö¶ԸñíµÄÐí¶à¼Ç¼Ðж¼¼ÓÉÏÁËÐм¶Ëø£¬Êý¾Ý¿âϵͳÖÐËøµÄÊýÄ¿»á¼±¾çÔö¼Ó£¬ÕâÑù¾Í¼ÓÖØÁËϵͳ¸ººÉ£¬Ó°ÏìϵͳÐÔÄÜ¡£Òò´Ë£¬ÔÚÊý¾Ý¿âϵͳÖУ¬Ò»°ã¶¼Ö§³ÖËøÉý¼¶(lock escalation)¡£ËùνËøÉý¼¶ÊÇÖ¸µ÷ÕûËøµÄÁ£¶È£¬½«¶à¸öµÍÁ£¶ÈµÄËøÌæ»»³ÉÉÙÊýµÄ¸ü¸ßÁ£¶ÈµÄËø£¬ÒÔ´ËÀ´½µµÍϵͳ¸ººÉ¡£ÔÚSQL ServerÖе±Ò»¸öÊÂÎñÖеÄËø½Ï¶à£¬´ïµ½ËøÉý¼¶ÃÅÏÞʱ£¬ÏµÍ³×Ô¶¯½«Ðм¶ËøºÍÒ³ÃæËøÉý¼¶Îª±í¼¶Ëø¡£ÌرðÖµµÃ×¢ÒâµÄÊÇ£¬ÔÚSQL ServerÖУ¬ËøµÄÉý¼¶ÃÅÏÞÒÔ¼°ËøÉý¼¶ÊÇÓÉϵͳ×Ô¶¯À´È·¶¨µÄ£¬²»ÐèÒªÓû§ÉèÖá£
¡¡¡¡SQL ServerËøÀàÐÍ
¡¡¡¡1£® HOLDLOCK: ÔڸñíÉϱ£³Ö¹²ÏíËø£¬Ö±µ½Õû¸öÊÂÎñ½áÊø£¬¶ø²»ÊÇÔÚÓï¾äÖ´ÐÐÍêÁ¢¼´ÊÍ·ÅËùÌí¼ÓµÄËø¡£
¡¡¡¡2£® NOLOCK£º²»Ìí¼Ó¹²ÏíËøºÍÅÅËüËø£¬µ±Õâ¸öÑ¡ÏîÉúЧºó£¬¿ÉÄܶÁµ½Î´Ìá½»¶ÁµÄÊý¾Ý»ò“ÔàÊý¾Ý”£¬Õâ¸öÑ¡Ïî½ö½öÓ¦ÓÃÓÚSELECTÓï¾ä¡£
¡¡¡¡3£® PAGLOCK£ºÖ¸¶¨Ìí¼ÓÒ³Ëø£¨·ñÔòͨ³£¿ÉÄÜÌí¼Ó±íËø£©¡£¡¡
¡¡¡¡4£® READ


Ïà¹ØÎĵµ£º

SQL ServerÖ÷¼ü×Ô¶¯Ôö³¤µÄÉèÖÃ

ÔÚSQL ServerÖУ¬Èç¹û°Ñ±íµÄÖ÷¼üÉèΪidentityÀàÐÍ£¬Êý¾Ý¿â¾Í»á×Ô¶¯ÎªÖ÷¼ü¸³Öµ¡£ÀýÈ磺
create table customers (
id int identity(1,1) primary key not null,
name varchar(15)
);
insert into customers(name) values("name1"),("name2");
select id from customers;

²éѯ½á¹ûΪ£º
id
---
1
2
ÓÉ´Ë¿ ......

SQLÉí·ÝÖ¤¸ñʽÑéÖ¤


SQL°æ±¾Éí·ÝÖ¤¸ñʽÑéÖ¤ 0Ϊ´íÎó£¬1ΪÕýÈ·
CREATE  function [dbo].[IsID](@str nvarchar(18),@sex int)--´«ÈëÁ½¸ö±äÁ¿ Éí·ÝÖ¤ºÍÐÔ±ð(ÄÐ1Å®2)
returns bit
as
begin
declare @len int
declare @result bit
--set @result=0
set @len=len(@str)
if(@len!=18 and @len!=15)--³¤¶ÈÊÇ18λ»ò15λ
 begin
& ......

Oracle DBAÈÕ³£sqlÁÐ±í¼°³£ÓÃÊÓͼ

²»´íµÄ×ÊÁÏ,ת¹ýÀ´,·½±ãÈÕºó²é¿´Ê¹ÓÃ!!!
--¼à¿ØË÷ÒýÊÇ·ñʹÓÃ
alter index &index_name monitoring usage;
alter index &index_name nomonitoring usage;
select * from v$object_usage where index_name =
&index_name;
--ÇóÊý¾ÝÎļþµÄI/O·Ö²¼
select
df.name,phyrds,phywrts,phyblkrd,phyblkwrt,sin ......

SQL Select N to M Records (single Table)

È¡±íÀïnµ½mÌõ¼Í¼µÄ¼¸ÖÖ·½·¨:
1. Ö»ÐèÒª²éѯǰMÌõÊý¾Ý(0 to M),
1.1 ʹÓà top(M) ·½·¨:
select top(3) * from [tablename]
 
1.2 ʹÓà set rowcount ·½·¨:
http://msdn.microsoft.com/zh-cn/library/ms188774(SQL.90).aspx
set rowcount M
select * from [tablename]
set rowcount 0
ȨÏÞ ÒªÇó¾ßÓÐ public ......
© 2009 ej38.com All Rights Reserved. ¹ØÓÚE½¡ÍøÁªÏµÎÒÃÇ | Õ¾µãµØͼ | ¸ÓICP±¸09004571ºÅ