Author URL:http://www.cnblogs.com/xbf321/archive/2008/11/02/1325067.html
Microsoft URL:http://technet.microsoft.com/zh-cn/library/ms188001.aspx
ÕªÒª
1,EXECµÄʹÓÃ
2£¬sp_executesqlµÄʹÓÃ
MSSQLΪÎÒÃÇÌṩÁËÁ½ÖÖ¶¯Ì¬Ö´ÐÐSQLÓï¾äµÄÃüÁ·Ö±ðÊÇEXECºÍsp_executesql;ͨ³£,sp_executesqlÔò¸ü¾ßÓÐÓÅÊÆ£¬ËüÌṩÁËÊäÈëÊä³ö½Ó¿Ú£¬¶øEXECûÓС£»¹ÓÐÒ»¸ö×î´óµÄºÃ´¦¾ÍÊÇÀûÓÃsp_executesql£¬Äܹ»ÖØÓÃÖ´Ðмƻ®£¬Õâ¾Í´ó´óÌṩÁËÖ´ÐÐÐÔÄÜ(¶ÔÓÚÕâ¸öÎÒÔÚºóÃæµÄÀý×ÓÖлáÏê¼Ó˵Ã÷)£¬»¹¿ÉÒÔ±àд¸ü°²È«µÄ´úÂë¡£EXECÔÚijЩÇé¿öÏ»á¸üÁé»î¡£³ý·ÇÄúÓÐÁîÈËÐÅ·þµÄÀíÓÉʹÓÃEXEC£¬·ñ²à¾¡Á¿Ê¹ÓÃsp_executesql.
1,EXECµÄʹÓÃ
EXECÃüÁîÓÐÁ½ÖÖÓ÷¨£¬Ò»ÖÖÊÇÖ´ÐÐÒ»¸ö´æ´¢¹ý³Ì£¬ÁíÒ»ÖÖÊÇÖ´ÐÐÒ»¸ö¶¯Ì¬µÄÅú´¦Àí¡£ÒÔÏÂËù½²µÄ¶¼ÊǵڶþÖÖÓ÷¨¡£
ÏÂÃæÏÈʹÓÃEXECÑÝʾһ¸öÀý×Ó,´úÂë1
DECLARE @TableName VARCHAR(50),@Sql NVARCHAR(MAX),@OrderID INT;
SET @TableName = 'Orders';
SET @OrderID = 10251;
SET @sql = 'SELECT * from '+QUOTENAME(@TableName) +'WHERE OrderID = '+CAST(@OrderID AS VARCHAR(10))+' ORDER BY ORDERID DESC'
EXEC(@sql);
×¢ ......
½ñÌì±àдÁËÒ»¸ö·ÖÒ³£¬ÔÚµ÷ÊÔÖгöÏÖÁËÈçϵĴíÎó:
java.sql.SQLException: [Microsoft][SQLServer 2000 Driver for JDBC]Invalid call Statement method: {0}
at com.microsoft.jdbc.base.BaseExceptions.createException(Unknown Source)
at com.microsoft.jdbc.base.BaseExceptions.getException(Unknown Source)
at com.microsoft.jdbc.base.BasePreparedStatement.executeQuery(Unknown Source)
at com.wmsz.pub.PagerHelp.initialize(PagerHelp.java:37)
at com.wmsz.business.UsersDaoImpl.findAllUsers(UsersDaoImpl.java:62)
at com.wmsz.business.UsersServiceImpl.findAllUsers(UsersServiceImpl.java:67)
at com.wmsz.servlet.FindAllUserServlet.doPost(FindAllUserServlet.java:51)
at com.wmsz.servlet.FindAllUserServlet.doGet(FindAllUserServlet.java:19)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:114)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:91)
at com.caucho.server.dispatch.ServletFilterChain.doFilter(ServletFilterCha ......
Êýѧº¯Êý
¡¡¡¡1.¾ø¶ÔÖµ
¡¡¡¡S:select abs(-1) value
¡¡¡¡O:select abs(-1) value from dual
¡¡¡¡2.È¡Õû(´ó)
¡¡¡¡S:select ceiling(-1.001) value
¡¡¡¡O:select ceil(-1.001) value from dual
¡¡¡¡3.È¡Õû£¨Ð¡£©
¡¡¡¡S:select floor(-1.001) value
¡¡¡¡O:select floor(-1.001) value from dual
¡¡¡¡4.È¡Õû£¨½ØÈ¡£©
¡¡¡¡S:select cast(-1.002 as int) value
¡¡¡¡O:select trunc(-1.002) value from dual
¡¡¡¡5.ËÄÉáÎåÈë
¡¡¡¡S:select round(1.23456,4) value 1.23460
¡¡¡¡O:select round(1.23456,4) value from dual 1.2346
¡¡¡¡6.eΪµ×µÄÃÝ
¡¡¡¡S:select Exp(1) value 2.7182818284590451
¡¡¡¡O:select Exp(1) value from dual 2.71828182
¡¡¡¡7.È¡eΪµ×µÄ¶ÔÊý
¡¡¡¡S:select log(2.7182818284590451) value 1
¡¡¡¡O:select ln(2.7182818284590451) value from dual; 1
¡¡¡¡8.È¡10Ϊµ×¶ÔÊý
¡¡¡¡S:select log10(10) value 1
¡¡¡¡O:select log(10,10) value from dual; 1
¡¡¡¡9.ȡƽ·½
¡¡¡¡S:select SQUARE(4) value 16
¡¡¡¡O:select power(4,2) value from dual 16
¡¡¡¡10.ȡƽ·½¸ù
¡¡¡¡S:select SQRT(4) value 2
¡¡ ......
Êýѧº¯Êý
¡¡¡¡1.¾ø¶ÔÖµ
¡¡¡¡S:select abs(-1) value
¡¡¡¡O:select abs(-1) value from dual
¡¡¡¡2.È¡Õû(´ó)
¡¡¡¡S:select ceiling(-1.001) value
¡¡¡¡O:select ceil(-1.001) value from dual
¡¡¡¡3.È¡Õû£¨Ð¡£©
¡¡¡¡S:select floor(-1.001) value
¡¡¡¡O:select floor(-1.001) value from dual
¡¡¡¡4.È¡Õû£¨½ØÈ¡£©
¡¡¡¡S:select cast(-1.002 as int) value
¡¡¡¡O:select trunc(-1.002) value from dual
¡¡¡¡5.ËÄÉáÎåÈë
¡¡¡¡S:select round(1.23456,4) value 1.23460
¡¡¡¡O:select round(1.23456,4) value from dual 1.2346
¡¡¡¡6.eΪµ×µÄÃÝ
¡¡¡¡S:select Exp(1) value 2.7182818284590451
¡¡¡¡O:select Exp(1) value from dual 2.71828182
¡¡¡¡7.È¡eΪµ×µÄ¶ÔÊý
¡¡¡¡S:select log(2.7182818284590451) value 1
¡¡¡¡O:select ln(2.7182818284590451) value from dual; 1
¡¡¡¡8.È¡10Ϊµ×¶ÔÊý
¡¡¡¡S:select log10(10) value 1
¡¡¡¡O:select log(10,10) value from dual; 1
¡¡¡¡9.ȡƽ·½
¡¡¡¡S:select SQUARE(4) value 16
¡¡¡¡O:select power(4,2) value from dual 16
¡¡¡¡10.ȡƽ·½¸ù
¡¡¡¡S:select SQRT(4) value 2
¡¡ ......
SQLServer´æ´¢¶àÓïÑÔÊý¾ÝµÄ¼¸ÖÖ·½·¨
http://www.examda.com/ncre/three/db/fudao/20100111/102352311.html
±¾ÎĸÅÊöÁËÔÚÊý¾Ý¿âÉè¼ÆÖУ¬ÈçºÎ´¦Àí¶à¹úÓïÑÔµÄÎÊÌ⣬ÕâÀïµÄ¶à¹úÓïÑÔÊÇÖ¸ÖîÈçÕâÑùµÄÒµÎñ£ºÔÚERPÈí¼þÖУ¬ÎÒÃÇÔÚÌîд¿Í»§Ãû³Æʱ£¬³ýÁËÐèÒªÌîд¿Í»§µÄÖÐÎÄÃû³Æ£¬»¹ÐèÒªÌîдËûµÄÓ¢ÎÄÃû³Æ¡£ Ò»°ãµÄ£¬Èç¹ûÊÇÆÕͨµÄÏîÄ¿ÐÍÈí¼þ£¬¾Í±È½Ï¼òµ¥ÁË£¬ÄãÖ»ÐèÒªÉè¼Æ³ö¹Ì¶¨µÄ ChineseNameºÍEnglishName×ֶξͿÉÒÔÁË¡£±¾ÎIJ¢²»ÌÖÂÛÕâÖÖÐÎʽ£¬¶øÊÇÌÖÂÛÔÚ´óÐÍƽ̨»¯µÄERPÈí¼þÖÐÈçºÎʵÏÖͨÓû¯µÄ¶àÓïÑÔ´æ´¢ºÍ¶ÁÈ¡¡£
¡¡¡¡×Ó±í·½Ê½
¡¡¡¡µÚÒ»ÖÖ·½Ê½Êǽ¨Á¢Ò»ÕÅ×Ó±í£¬U9´ó¸Å¾ÍÊÇÕâ¸öÑù×Ó£¬ÄãÐèҪעÒâµÄÊÇ£¬Ã¿Ò»¸öʵÌåÈç¹û°üº¬¶àÓïÑÔ×ֶΣ¬¶¼»á³öÏÖÒÔ_TrlΪºó׺µÄ±í¡£Ò²ÐíÄã»á¾õµÃÂé·³£¬Æäʵ²»È»£¬ÕâЩ¶¼ÊÇƽ̨ÔÚºǫ́×Ô¶¯´¦ÀíÁË£¬Äã½ö½öÐèÒª±ê¼ÇÕâ¸ö×Ö¶ÎÊǶàÓïÑÔ×ֶξͿÉÒÔÁË¡£
¡¡¡¡´ÓÀíÂÛÉÏÀ´Ëµ£¬ËûµÄ´æ´¢ÊÇ×î·ûºÏÊý¾Ý¿âÉè¼ÆÔÔòµÄ£¬²»¹ÜÄãµÄϵͳʹÓöàÉÙÓïÑÔ£¬Êý¾Ý¿â½á¹¹ÊDz»±äµÄ¡£µ«ÊÇÎÒ×ܾõµÃ²éѯÆðÀ´SQL»á±È½Ï¸´ÔÓ£¬ËäÈ»ÕâÊÂƽ̨Ҳ»á°ïÖúÄãÍê³É¡£ÎÒÔÚÏ룬Èç¹ûÎÒÒªÒ»¸ö¶àÓïÑÔ²ßÂÔÈçºÎʵÏÖÄØ£¿¶àÓïÑÔ²ßÂÔµÄÀý×Ó£ºÈç¹û´Ë×Ö¶ÎûÓжÔÓ¦µÄ·±ÌåÖÐÎÄ£¬È¡¼òÌåÖÐÎÄ£¬Èç¹û»¹Ã»ÓУ¬È¡Ä¬ÈϵÄÓïÑÔÄÚÈÝ¡ ......
ÔÚÊÓͼÉÏ´´½¨Ë÷ÒýµÄÁíÒ»¸öºÃ´¦ÊÇ£º²éѯÓÅ»¯Æ÷¿ªÊ¼ÔÚ²éѯÖÐʹÓÃÊÓͼË÷Òý
£¬
¶ø²»ÊÇÖ±½ÓÔÚ from
×Ó¾äÖÐÃüÁîÊÓͼ¡£ÕâÑùÒ»À´£¬¿É´ÓË÷ÒýÊÓͼ¼ìË÷Êý¾Ý¶øÎÞÐèÖØбàÂ룬ÓÉ´Ë´øÀ´µÄ¸ßЧÂÊҲʹÏÖÓвéѯ»ñÒæ¡£ÔÚÊÓͼÉÏ´´½¨µÄµÚÒ»¸öË÷Òý±ØÐëÊÇΨһ¾Û¼¯Ë÷Òý¡£ÔÚ´´
½¨Î¨Ò»¾Û¼¯Ë÷Òýºó£¬¿É´´½¨ÆäËü·Ç¾Û¼¯Ë÷Òý¡£ÊÓͼÉϵÄË÷ÒýÃüÃû¹æÔòÓë±íÉϵÄË÷ÒýÃüÃû¹æÔòÏàͬ¡£Î¨Ò»Çø±ðÊDZíÃûÓÉÊÓͼÃûÌæ»»¡£(Sql
ServerÁª»ú°ïÖú)
ûÑо¿¹ý£¬Ëµ²»³öʲô¶«Î÷À´£¬ÏÖÔÚÖ»°Ñ·½·¨¼ÇÏÂÀ´¡£
Óï¾ä£º
Create VIEW vXXX WITH SCHEMABINDING AS……
SELECT 1000 [ID]
from dbo.TABLENAME
Create UNIQUE CLUSTERED INDEX idxXXX ON vXXX(cXXX)
Ò»¸ö±ê×¼ÊÓͼת»»ÎªÒ»¸öË÷ÒýÊÓͼ±ØÐë×ñÊØÒÔϹæÔò
£º
A£®ÊÓͼ±ØÐëʹÓÃWith SchemabindingÑ¡ÏîÀ´´´½¨£»
Èç¹û´´½¨ÊÓͼʱûÓÐwith Schemabinding£¬ÊÔͼ´´½¨ÊÓͼʱ¾Í»á±¨´í£º……ÒòΪ¸ÃÊÓͼδ°ó¶¨µ½¼Ü¹¹
B£®ÔÚÕâ¸öÊÓͼÖв»ÄÜʹÓÃÆäËûÊÓͼ¡¢µ¼³ö±í¡¢Ðм¯º¯Êý»ò×Ô²éѯ£¬Ò²¾ÍÊÇ˵ֻÄÜʹÓÃ±í£»
C£®ÊÓͼËùÓõ½µÄ»ù±¾±í±ØÐëºÍÊÓͼÊôÓÚͬһ¸öËùÓÐÕߣ»
D£®ÊÓͼֻÄÜÁ´½Óͬһ¸öÊý¾Ý¿âÖ ......
»°Ëµ°³ÊǸöÀÁÈË¡£¡£¡£¡£
×°ÍêSQLSERVER2005 ÒòΪ¿ª»úºÜÂý ËùÒÔÄؾͰѿª»ú·þÎñ¸ã³ÉÊÖ¶¯µÄÁË
ÕâÑù¿ª»ú¿ìÁ˺ܶà
¿ÉÊÇÎÊÌâÒ²À´ÁË
ÿ´ÎÒªÓÃSqlServerµÄʱºòÒªÒ»¸öÒ»¸ö·þÎñÈ¥¿ªÆðÀ´ ¡£¡£¡£¡£
Âé·³°¡¡£¡£¡£¡£¡£
²»±È2000Óиö ¿ª¹ØµÄ³ÌÐò
ËùÒÔÉÏÍøÕÒÁËϽ̳Ì
×Ô¼ºÐ´¸öÅú´¦Àí ×Ô¶¯Æô¶¯·þÎñ
ÍÛ¹þ¹þ
ͻȻ¾õµÃ Ö»ÒªÓÐÍøÂç ÓïÑÔ²»ÊÇɶ´óµÄÕÏ°
дÆðÀ´¶¼²î²»¶àѽ
ÍÛ¹þ¹þ
@echo off
echo ¿ªÆôSQLSERVER·þÎñ°´1
echo ¹Ø±ÕSQLSERVER·þÎñ°´2
set /p ans=
¡¡¡¡if %ans%==1 goto sta
¡¡¡¡if %ans%==2 goto sto
:sta
echo ×¼±¸¿ªÆô·þÎñ
net start SQLWriter
net start ReportServer
net start MsDtsServer
net start msftesql
net start SQLBrowser
net start MSSQLSERVEROLAPService
net start SQLSERVERAGENT
net start MSSQL$SQLEXPRESS
net start MSSQLSERVER
goto exit
:sto
echo ×¼±¸¹Ø±Õ·þÎñ
net stop SQLWriter
net stop ReportServer
net stop MsDtsServer
net stop msftesql
net stop SQLBrowser
net stop MSSQLSERVEROLAPService
net stop SQLSERVERAGENT
net stop MSSQL$SQLEXPRESS
net stop MSSQLSERVER
goto exit
:exit
echo o ......