SQL Server 2008¼¸ÏîÐÂÌØÐÔ¸ÅÊö
¼Æ»®ÓÚ2008ÄêµÚÒ»¼¾¶È·¢²¼µÄSQL Server 2008²»½ö¶ÔÔÓÐÐÔÄܽøÐÐÁ˸Ľø£¬»¹Ìí¼ÓÁËÐí¶àÐÂÌØÐÔ£¬±ÈÈçÐÂÌíÁËÊý¾Ý¼¯³É¹¦ÄÜ£¬¸Ä½øÁË·ÖÎö·þÎñ£¬±¨¸æ·þÎñ£¬ÒÔ¼°Office¼¯³ÉµÈµÈ¡£
¡¡¡¡SQL Server¼¯³É·þÎñ
¡¡¡¡SSIS(SQL Server¼¯³É·þÎñ)ÊÇÒ»¸öǶÈëʽӦÓóÌÐò£¬ÓÃÓÚ¿ª·¢ºÍÖ´ÐÐETL(½âѹËõ¡¢×ª»»ºÍ¼ÓÔØ)°ü¡£SSIS´úÌæÁËSQL 2000µÄDTS¡£ÕûºÏ·þÎñ¹¦ÄܼȰüº¬ÁËʵÏÖ¼òµ¥µÄµ¼Èëµ¼³ö°üËù±ØÐèµÄWizardµ¼Ïò²å¼þ¡¢¹¤¾ßÒÔ¼°ÈÎÎñ£¬Ò²Óзdz£¸´ÔÓµÄÊý¾ÝÇåÀí¹¦ÄÜ¡£SQL Server 2008 SSISµÄ¹¦ÄÜÓкܴóµÄ¸Ä½øºÍÔöÇ¿£¬±ÈÈçËüµÄÖ´ÐгÌÐòÄܹ»¸üºÃµØ²¢ÐÐÖ´ÐС£ÔÚSSIS 2005£¬Êý¾Ý¹ÜµÀ²»ÄÜ¿çÔ½Á½¸ö´¦ÀíÆ÷¡£¶øSSIS 2008Äܹ»ÔÚ¶à´¦ÀíÆ÷»úÆ÷ÉÏ¿çÔ½Á½¸ö´¦ÀíÆ÷ ¡£¶øÇÒËüÔÚ´¦Àí´ó¼þ°üÉÏÃæµÄÐÔÄܵõ½ÁËÌá¸ß¡£SSISÒýÇæ¸ü¼ÓÎȶ¨£¬ËøËÀÂʸüµÍ¡£
¡¡¡¡Lookup¹¦ÄÜÒ²µÃµ½Á˸Ľø¡£LookupÊÇSSISÒ»¸ö³£ÓõĻñÈ¡Ïà¹ØÐÅÏ¢µÄ¹¦ÄÜ¡£±ÈÈç´ÓCustomerID²éÕÒCustomer Name£¬»ñÈ¡Êý¾Ý¼¯¡£LookupÔÚSSISÖкܳ£¼û£¬¶øÇÒ¿ÉÒÔ´¦ÀíÉϰÙÍòÐеÄÊý¾Ý¼¯£¬Òò´ËÐÔÄÜ¿ÉÄܺܲSQL 2008¶ÔLookupµÄÐÔÄÜ×÷³öºÜ´óµÄ¸Ä½ø£¬¶øÇÒÄܹ»´¦Àí²»Í¬µÄÊý¾ÝÔ´£¬°üÀ¨ ADO.NET£¬XML£¬OLEDBºÍÆäËûSSISѹËõ°ü¡£
¡¡¡¡SQL 2008¿ÉÒÔÖ´ÐÐTSQLµÄMERGEÃüÁî¡£ÓÃMERGEÃüÁֻÐèÒ»¸öÓï¾ä¾Í¿ÉÒÔ¶ÔÐнøÐÐ UPDATE¡¢INSERT»ò DELETE¡£ÏÂÃæµÄÀý×Ó¾ÍÊÇÈçºÎÓÃMERGEÃüÁîÀ´°ÑеÄInventory Item descriptions Áбí²åÈëÒÑÓеÄInventory MasterÖС£³ýÁË descriptions£¬ NewInventory±í¸ñÖл¹¼ÓÈëÁËÆäËûһЩ²¿·Ö¡£Èç¹ûûÓÐMERGEÓï¾ä£¬¾ÍÐèÒªÖ´ÐÐÁ½¸öÃüÁî²ÅÄÜÍê³É¡£µÚÒ»¸öÃüÁî²éÕÒÆ¥ÅäµÄDescriptionÈ»ºó¸üС£µÚ¶þ¸öÃüÁî²éÕÒ²»Æ¥ÅäÏîÈ»ºó²åÈë¡£ÓÐÁËMERGE£¬Ò»¸öÓï¾ä¾Í¿ÉÒÔÍê³ÉÕâÁ½¸öÈÎÎñ¡£²½ÖèÈçÏ£º
¡¡¡¡MERGE InventoryMaster AS im
¡¡¡¡USING (SELECT InventoryID, Descr from NewInventory) AS src
¡¡¡¡ON im. InventoryID = src. InventoryID
¡¡¡¡WHEN MATCHED THEN
¡¡¡¡UPDATE SET im.Descr = src.Descr
¡¡¡¡WHEN NOT MATCHED ,RAID0Êý¾Ý»Ö¸´;THEN
¡¡¡¡INSERT (InventoryID, Descr) VALUES (src. InventoryID, src.Descr);
¡¡¡¡·ÖÎö·þÎñ
¡¡¡¡SSAS(SQL Server·ÖÎö·þ
Ïà¹ØÎĵµ£º
--
SQL Server£º
Select
TOP
N
*
from
TABLE
Order
By
NewID
()
--
Access£º
Select
TOP
N
*
from
TABLE
Order
By
Rnd(ID)
Rnd(ID) ÆäÖеÄID ......
declare @a int
set @a = 1
while @a<1000000
begin
insert into Test(name) values(@a)
set @a = @a + 1
end ......
ÈçºÎ·ÀÖ¹³ÌÐòÖÐSQL½Å±¾±»SQL SERVERµÄʼþ̽²éÆ÷¸ú×Ù£¬±£ÕÏ×Ô¼ºµÄÈí¼þ²»±»ËûÈË·ÖÎö£¿
ÏÂÃæÊÇÒ»¸öÍ£Ö¹ËùÓÐSQLSERVERµÄ¸ú×ÙÆ÷µÄ½Å±¾(Á½ÖÖ·½·¨µÄÔÀíÏàͬ)£º
µÚÒ»ÖÖ·½·¨£º
procedure SQLCloseAllTrack;
const
sql = 'declare @TID integer ' +
'declare Trac Cursor For ' +
'SELECT Distinct Traceid from ......
¼Æ»®ÓÚ2008ÄêµÚÒ»¼¾¶È·¢²¼µÄSQL Server 2008²»½ö¶ÔÔÓÐÐÔÄܽøÐÐÁ˸Ľø£¬»¹Ìí¼ÓÁËÐí¶àÐÂÌØÐÔ£¬±ÈÈçÐÂÌíÁËÊý¾Ý¼¯³É¹¦ÄÜ£¬¸Ä½øÁË·ÖÎö·þÎñ£¬±¨¸æ·þÎñ£¬ÒÔ¼°Office¼¯³ÉµÈµÈ¡£
¡¡¡¡SQL Server¼¯³É·þÎñ
¡¡¡¡SSIS(SQL Server¼¯³É·þÎñ)ÊÇÒ»¸öǶÈëʽӦÓóÌÐò£¬ÓÃÓÚ¿ª·¢ºÍÖ´ÐÐETL(½âѹËõ¡¢×ª»»ºÍ¼ÓÔØ)°ü¡£SSIS´úÌæÁËSQL 2000µÄDTS¡£Õ ......