仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 885|回复: 7
打印 上一主题 下一主题

[学习教程] MSSQL编程:创立自界说模板 Building Custom Templ...

[复制链接]
谁可相欹 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-16 22:35:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
对于update操作,只需要把event中的旧行和新行值对调即可。创立|模板December23,2002
UsingandBuildingQueryAnalyzerTemplates
ByGregoryA.Larsen



BuildingCustomTemplates
Bynowyoushouldbesomewhatfamiliarwithusingpre-existingtemplatestobuildyourSQLcode.Itisnowtimetolookathowyoucanleveragetemplatestostreamlineyouradministration.Notonlycanyouuseexistingtemplates,butyoucanalsomodifytheexistingtemplatesandbuildyourownhomegrowntemplates.

SQLServercomeswithasetoftemplateswhenyouinstallSQLServer.TheMicrosoftsuppliedtemplatesarestored(ifyouusedthedefaultinstallation)inadirectorycalled"C:ProgramFilesMicrosoftSQLServer80ToolsTemplatesQLQueryAnalyzer."Inthisdirectorythereareanumberofsubdirectories,oneforeachfolderyouseeontheQATemplatepane.IfyoudidnttakethedefaultwheninstallingSQLServer,youcanfindthetemplatedirectorybysearchingforfilesthathavea"tql"extension.

ForexamplepurposesIamgoingtocreateanewtemplatetosupportcreatingadatabasebackup.Toensurethatmyhomegrowntemplatesarestoredseparatelyfromthestandardones,Iwillbuildanewtemplatefoldertoplacemycustomtemplates.Alltemplatesyoucreatemusthavea"tql"extentioninordertoberecognizedasatemplate.

BeforeIbuildmydatabasebackuptemplate,lcreateanewdirectoryforallmyhomegrowntemplatescalled"MyTemplates."ThisnewdirectoryiscreatedunderthelocationwhereallthestandardMicrosofttemplatesarestored.Inmycase,IwillcreateanewtemplatedirectorycalledC:ProgramFilesMicrosoftSQLServer80ToolsTemplatesQLQueryAnalyzerMyTemplates."NowIamreadytobuildatemplate.

ThetemplateIamgoingtocreateiscalled"DatabaseBackupToDiskFile.tql."WhateverInamethetemplateiswhatwillbedisplayedinthe"Template"paneinQA,minusthe"tql"extention.IwilluseNOTEPADtocreatethisnewtemplatethatwillbuildasimple"BACKUPDATABASE"command.Thetemplatebuiltwilllooklikethis:

--=========================================================--Backupdatabasetodiskfile--=========================================================backupdatabasetodisk=<disk_name,varchar(300),C:mssqlackup><db_name,varchar(128),dba>_<version,varvhar(100),ADHOC>.bak



Thistemplatecontainsthreedifferentparameters.Thefirstparameterisdb_nameandisusedtoidentifythedatabasethatwillbebackedup.Asyoucansee,thisparameterisdefinedasavarchar(128),anddefaultsto"DBA."Thesecondparameterisdisk_name,whichdefaultstothestandardplacefordatabasebackupsonmymachine.Thethirdparameterprovidesawaytospecifytheversionnameforthebackup.

NowIwillputthefinaltouchesonthescriptIambuilding.SofarIhaveusedtwostandardtemplatestocreatemyscript,whichcontainsacreatedatabaseandacreatetablestatement.NowIamgoingtousemycustombuilt"DatabaseBackupToDiskFile"templatetoadda"DATABASEBACKUP"commandtotheendofmyscript.

WhenIdisplaytheQA"Template"pane,Inowseeanewfoldercalled"MyTemplates."IfforsomereasonIdontseethenewtemplate,Irightclickonthe"Templates"folderandchoosethe"Refresh"option.Noticebelowthenewlyaddedtemplatefolder"MyTemplates."





NextIclickonthe"+"signnexttothe"MyTemplate"foldertoexpand.Intheexpandedviewmynewtemplate"DatabaseBackupToDiskFile"willbedisplayed,asinthescreenshotbelow.





NowIclickontheDatabaseBackupToDiskFiletemplate,dragittotheQApane,anddropitattheendofmyQAscript.AfterIdraganddropmytemplate,myscriptlookslikethis:

--=============================================--BasicCreateDatabaseTemplate--=============================================IFEXISTS(SELECT*FROMmaster..sysdatabasesWHEREname=NDemo_DB)DROPDATABASEDemo_DBGOCREATEDATABASEDemo_DBGO--=============================================--Createtablebasictemplate--=============================================IFEXISTS(SELECTnameFROMsysobjectsWHEREname=NMyTableANDtype=U)DROPTABLEMyTableGOCREATETABLEMyTable(IDintNULL,Descriptionvarchar(50)NOTNULL)GO--=========================================================--Backupdatabasetodiskfile--=========================================================backupdatabase<db_name,varchar(128),DBA>todisk=<disk_name,varchar(300),C:mssqlackup><db_name,varchar(128),dba>_version,varvhar(100),ADHOC>.bak



Nowallthatislefttocompletemyscriptistoreplacetheparameters.OnceagainIusetheReplaceTemplateParametermenutoreplaceparameters.ThistimeIonlyneedtoenteravalueforthedb_nameparameter;Ienter"Demo_DB."FortherestoftheparametersIwilltakethedefaultvalues.Myfinalscriptlooklikethis:

--=============================================--BasicCreateDatabaseTemplate--=============================================IFEXISTS(SELECT*FROMmaster..sysdatabasesWHEREname=NDemo_DB)DROPDATABASEDemo_DBGOCREATEDATABASEDemo_DBGO--=============================================--Createtablebasictemplate--=============================================IFEXISTS(SELECTnameFROMsysobjectsWHEREname=NMyTableANDtype=U)DROPTABLEMyTableGOCREATETABLEMyTable(IDintNULL,Descriptionvarchar(50)NOTNULL)GO--=========================================================--Backupdatabasetodiskfile--=========================================================backupdatabaseDemo_DBtodisk=C:mssqlackupDemo_DB_ADHOC.bak



Conclusion
Asyoucansee,templatesareusefulforbuildingscripts.Templatescansaveyouvaluabletimewhendevelopingcode.Bybuildingyourowntemplatesandcustomizingtheexistingtemplates,youcanstreamlineyourdevelopmentprocessandeliminatesyntaxerrors.Nexttimeyouwritesomecodethatmightbeusedoverandoveragain,considerusingitasabaseforbuildingaQAtemplate.
MySQL最初的开发者的意图是用mSQL和他们自己的快速低级例程(ISAM)去连接表格。经过一些测试后,开发者得出结论:mSQL并没有他们需要的那么快和灵活。
飘灵儿 该用户已被删除
沙发
发表于 2015-1-21 20:16:04 | 只看该作者
无法深入到数据库系统层面去了解和探究
若天明 该用户已被删除
板凳
发表于 2015-1-30 22:11:59 | 只看该作者
每天坚持做不一样的是,认真做笔录,定时复习。一个月你就可以有一定的收获。当然如果你想在sql方面有一定的造诣,你少不了需要看很多很多的书籍了。
小魔女 该用户已被删除
地板
发表于 2015-2-6 16:16:14 | 只看该作者
SP4是一个累积性的ServicePack,包含自以前的ServicePack发布以来所有的修补程序(包括MS03-031安全公告)。
蒙在股里 该用户已被删除
5#
发表于 2015-2-17 04:46:26 | 只看该作者
而SQLServer如果能像Oracle一样可以为登陆分配如:5%的cpu,10%的内存。就可以解决这个漏洞。
深爱那片海 该用户已被删除
6#
发表于 2015-3-5 15:58:23 | 只看该作者
连做梦都在想页面结构是怎么样的,绝非虚言
小女巫 该用户已被删除
7#
发表于 2015-3-12 10:19:50 | 只看该作者
如果是将来做数据库的开发设计,就应该详细学习T-SQL的各种细节,包括T-SQL的程序设计、存储过程、触发器以及具体使用某个开发语言来访问数据库。
老尸 该用户已被删除
8#
发表于 2015-3-19 20:03:40 | 只看该作者
从项目平台的选择上讲,我们关心的,应该是一款产品能不能满足任务需求,而不是网上怎么说。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-12-23 00:03

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表