ÓÅ»¯µÄms sql server·ÖÒ³sqlÓï¾ä
ÓÅ»¯µÄms sql server·ÖÒ³sqlÓï¾ä
·¢²¼Ê±¼ä: 2009-8-15 00:00 | ·¢²¼×÷Õß: hjh | | ²é¿´: 3´Î
ÌØµã£ºÒ»´Î²éѯ£¬Êý¾Ý¿âDatabnseÖ»·µ»ØÒ»Ò³µÄÊý¾Ý¡£¶ø·ñÔòÈ¡³öËùÓеÄÊý¾Ý¡£
˵Ã÷£º
pagesize£º ÿҳ³ÊÏּǼÊý
cureentpage£ºµ±Ç°Ò³Êý
select * from ( select TOP pagesize * from ( SELECT TOP pagesize*cureentpage * from user_table ORDER BY id ASC ) as aSysTable ORDER BY id DESC ) as bSysTable ORDER BY id ASC
Àý×Ó˵Ã÷£º
¼ÙÈçÊý¾Ý¿âDatabnse±íÈçÏ£º
user_table:
id:Ö÷¼ü£¬×ÔÔö
username:×Ö·û
password:×Ö·û
¼ÙÉèÓÐ80Ìõ¼Ç¼£¬Ã¿Ò³³ÊÏÖ10Ìõ¼Ç¼£¬id ´Ó1µ½80
Ŀǰ°´ÕÕidÉýÐòÅÅÁÐÈ¡³öµÚÈýÒ³µÄÊý¾ÝÒò¸ÃΪ£ºËùÈ¡µÃ¼Ç¼µÄid Òò¸ÃΪ 21µ½30¡£
Õâʱ¸ÃÓï¾äÒò¸ÃΪ£º
select * from ( select TOP 10 * from ( SELECT TOP 30 * from user_table ORDER BY id ASC ) as aSysTable ORDER BY id DESC ) as bSysTable ORDER BY id ASC
˼ÏëÈçÏ£º
ÏȰ´ÕÕid´ÓСµ½´óÉýÐòÈ¡³ö30Ìõ¼Ç¼£¨3*10£©,Ò²¾Í£ºid ÔÚ 1-30 Ö®¼äµÄ¼Ç¼ £¨SELECT TOP 30 * from user_table ORDER BY id ASC£©
È»ºó°´ÕÕID½µÐòÅÅÁÐÕâ30Ìõ¼Ç¼£¬µÃµ½¼Ç¼Ϊid ÔÚ£º´Ó30µ½ 1
È»ºóÔÚÕâÒ»²¿·Ý30Ìõ¼Ç¼ÖÐÈ¡³öǰ10Ìõ¼Ç¼£ºÈ¡µÃµÄ¼Ç¼Ϊ£ºid ÔÚ30-21Ö®¼ä¡£Õâ¾ÍÔÛÃÇÐèÇóµÄÊý¾Ý£¬µ«ÕâʱÊǰ´ÕÕ½µÐòÅÅÁе쬲»·ûºÏÒªÇó¡£
×îºóÔÚÖØÐÂÅÅÐòµÃµ½×îÖÕÔÛÃÇÐèÇóµÄÊý¾Ý¡£idÔÚ21-30Ö®¼ä¡£
ÆÚÍû¶Ô´ó²¿·ÝÈËÓÐËù°ïÖú¡£
ÈçÓÐÒÉÄÑÎÊÌ⣬ÆÚÍûºÍ´ó²¿·ÝÈËÒ»¿é¹µÍ¨¡£
email:yanek@126.com
Ïà¹ØÎĵµ£º
SQLÓï¾äÖеÄÈý¸ö¹Ø¼ü×Ö:MINUS(¼õÈ¥),INTERSECT(½»¼¯)ºÍUNION ALL(²¢¼¯);
¹ØÓÚ¼¯ºÏµÄ¸ÅÄî,ÖÐѧ¶¼Ó¦¸Ãѧ¹ý,¾Í²»¶à˵ÁË.ÕâÈý¸ö¹Ø¼ü×ÖÖ÷ÒªÊǶÔÊý¾Ý¿âµÄ²éѯ½á¹û½øÐвÙ×÷,ÕýÈçÆäÖÐÎĺ¬ÒåÒ»Ñù:Á½¸ö²éѯ,MINUSÊÇ´ÓµÚÒ»¸ö²éѯ½á¹û¼õÈ¥µÚ¶þ¸ö²éѯ½á¹û,Èç¹ûÓÐÏཻ²¿·Ö¾Í¼õÈ¥Ïཻ²¿·Ö;·ñÔòºÍµÚÒ»¸ö²éѯ½á¹ûûÓÐÇø±ð. INTERSECTÊÇÁ½¸ö² ......
¡¡¡¡1.µ¼³öÕû¸öÊý¾Ý¿â
¡¡¡¡ mysqldump -u Óû§Ãû -p Êý¾Ý¿âÃû > µ¼³öµÄÎļþÃû
¡¡¡¡ mysqldump -u wcnc -p smgp_apps_wcnc > wcnc.sql
¡¡¡¡2.µ¼³öÒ»¸ö±í
¡¡¡¡ mysqldump -u Óû§Ãû -p Êý¾Ý¿âÃû ±íÃû> ......
SQL Server2005¶Áȡע²á±í
DECLARE @result varchar(255)
EXEC master.dbo.xp_regread 'HKEY_LOCAL_MACHINE','SOFTWARE\OperationControlSystem\ClientID','Prefix',@result OUT ---×¢Òâ±ØÐëÓÐOUT·ñÔò@resultΪ¿Õ
SELECT @result
¼ÙÈçÔÚÖ´Ðйý³ÌÖгöÏÖ´íÎ󣬿ÉÄÜÊÇδÕÒµ½´æ´¢¹ý³Ì_master.dbo.xp_regread
ÔÒò£º×ö°²È« ......
SQLÑ»·Óï¾ä
declare @i int
set @i=1
while @i<30
begin
insert into test (userid) values(@i)
set @i=@i+1
end
---------------
while Ìõ¼þ
begin
Ö´ÐвÙ×÷
set @i=@i+1
end
WHILE
ÉèÖÃÖØ¸´Ö´ÐÐ SQL Óï¾ä»òÓï¾ä¿éµÄÌõ¼þ¡£Ö»ÒªÖ¸¶¨µÄÌõ¼þÎªÕæ£¬¾ÍÖØ¸´Ö´ÐÐÓï¾ä¡£¿ÉÒÔʹÓà BREAK ºÍ CONTI ......
Ò»¡¢½»²æÁ¬½Ó£¨CROSS JOIN£©
½»²æÁ¬½Ó£¨CROSS JOIN£©£ºÓÐÁ½ÖÖ£¬ÏÔʽµÄºÍÒþʽµÄ£¬²»´øON×Ӿ䣬·µ»ØµÄÊÇÁ½±íµÄ³Ë»ý£¬Ò²½ÐµÑ¿¨¶û»ý¡£
ÀýÈ磺ÏÂÃæµÄÓï¾ä1ºÍÓï¾ä2µÄ½á¹ûÊÇÏàͬµÄ¡£
Óï¾ä1£ºÒþʽµÄ½»²æÁ¬½Ó£¬Ã»ÓÐCROSS JOIN¡£
SELECT O.ID, O.ORDER_NUMBER, C.ID, C.NAME
from ORDERS O , CUSTOMERS C
WHERE O.ID=1;
Óï¾ä2£ ......