-
分享SQLServer删除重复行的6个方法
1.如果有ID字段,就是具有唯一性的字段复制代码代码如下:delecttablewhereidnotin(selectmax(id)fromtablegroupbycol1,col2,col3...)groupby子句后跟的字段就是你用来判断重复的条件,如只有col1,那么只要col1字段内容相同即表示记录相同。2.如果是判断所有字段也可以这样复制代码代码如下:select*into#aafromtablegroupbyid1,id2,....deletetableinsertintotableselect*from#aa3.没有ID的情况复制代码代码如下:selectidentity(int,1,1)asid,*into#tempfromtabeldelect#whereidnotin(selectmax(id)from#groupbycol1,col2,col3...)delecttableinsetintotable(...)select.....from#temp4.col1+','+col2+','...col5联合主键复制代码代码如下:select*fromtablewhe...
数据库操作教程 2022-09-23 20:41:46 -
SQLServer参数化查询经验分享
什么是参数化查询? 一个简单理解参数化查询的方式是把它看做只是一个T-SQL查询,它接受控制这个查询返回什么的参数。通过使用不同的参数,一个参数化查询返回不同的结果...
数据库操作教程 2022-09-23 20:36:52 -
扩展性很好的一个分页存储过程分享
这是经常用的一个分页存储过程希望大家指点不足复制代码代码如下:USE[a6756475746]GO/******Object:StoredProcedure[dbo].[tbl_order_SearchWhereAndPage]ScriptDate:11/01/201109:37:39******/SETANSI_NULLSONGOSETQUOTED_IDENTIFIERONGOALTERPROCEDURE[dbo]...
数据库操作教程 2022-09-23 20:31:39 -
mssqlserver数据库附加不上解决办法分享
错误15105,从网上找了一些解决方案,一般都是说文件的权限不足的问题,当然附加的时候必须是有数据库附加权限才可以操作的。解决办法1:给相应的MDF文件给FullControl的权限,如果不知道是什么用户可以去SqlServer的配置中心去找但是我遇到这个用上述方法就不可以...
数据库操作教程 2022-09-23 20:30:55 -
sqlserver清空servicebroker中的队列的语句分享
复制代码代码如下:USETestDBdeclare@conversationuniqueidentifierwhileexists(select1fromsys.transmission_queue)beginset@conversation=(selecttop1conversation_handlefromsys...
数据库操作教程 2022-09-23 20:30:24 -
合并SQL脚本文件的方法分享
概述--------------------------------------------------------------------------------在平时的工作中,我会经常的碰到这样需要合并SQL脚本的问题。如,有很多的SQL脚本文件,需要按照一定的先后顺序,再生成一个合并SQL脚本文件,然后再发布到用户SQLServer服务器上...
数据库操作教程 2022-09-23 20:29:15 -
SqlServer表死锁的解决方法分享
其实不光是上面描述的情况会锁住表,还有很多种场景会使表放生死锁,解锁其实很简单,下面用一个示例来讲解:1首先创建一个测试用的表:复制代码代码如下:CREATETABLETest(TIDINTIDENTITY(1,1))2执行下面的SQL语句将此表锁住:复制代码代码如下:SELECT*FROMTestWITH(TABLOCKX)3通过下面的语句可以查看当前库中有哪些表是发生死锁的:复制代码代码如下:SELECTrequest_session_idspid,OBJECT_NAME(resource_associated_entity_id)tableNameFROMsys.dm_tran_locksWHEREresource_type='OBJECT'4上面语句执行结果如下:spid:被锁进程ID。tableName:发生死锁的表名...
数据库操作教程 2022-09-23 20:28:14 -
将MSSQLServer导入/导出到远程服务器教程的图文方法分享
1、打开本地企业管理器,先创建一个SQLServer注册来远程连接服务器端口SQLServer。步骤如下图:图1:2、弹出窗口后输入内容...
数据库操作教程 2022-09-23 20:26:33 -
针对SQL2000的分页存储过程代码分享
复制代码代码如下:------------------------------------------------------针对SQL2000的分页存储过程--Time:2008-9-25----------------------------------------------------ALTERPROCEDURE[dbo].[uoSp_RecordPager]--要分页显示的表名,可多表连查,但不能使用别名。--例:uo_ArticleLEFTJOINuo_ArticleClassONuo_Article.AClassID=uo_ArticleClass.ID@Table_infovarchar(100),--用于定位记录的主键(惟一键)字段,可以是逗号分隔的多个字段@field_idnvarchar(1000),--要显示的页码@CurrentPageint=1,--每页的大小(记录数)@PageSizeint=10,--以逗号分隔的要显示的字段列表,如果不指定,则为*...
数据库操作教程 2022-09-23 20:23:11 -
分享一下SQLServer执行动态SQL的正确方式
SQLServer执行动态SQL的话,应该如何实现呢?下面就为您介绍SQLServer执行动态SQL两种正确方式,希望可以让您对SQLServer执行动态SQL有更深的了解动态SQL:codethatisexecuteddynamically.它一般是根据用户输入或外部条件动态组合的SQL语句块.动态SQL能灵活的发挥SQL强大的功能、方便的解决一些其它方法难以解决的问题.相信使用过动态SQL的人都能体会到它带来的便利,然而动态SQL有时候在执行性能(效率)上面不如静态SQL,而且使用不恰当,往往会在安全方面存在隐患(SQL注入式攻击). 动态SQL可以通过EXECUTE或SP_EXECUTESQL这两种方式来执行. EXECUTE 执行Transact-SQL批中的命令字符串、字符串或执行下列模块之一:系统存储过程、用户定义存储过程、标量值用户定义函数或扩展存储过程.SQLServer2005扩展了EXECUTE语句,以使其可用于向链接服务器发送传递命令.此外,还可以显式设置执行字符串或命令的上下文 SP_EXECUTESQL 执行可以多次重复使用或动态生成的Tra...
数据库操作教程 2022-09-23 18:20:34 -
分享一个简单的sql注入
所谓SQL注入,就是通过把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令。具体来说,它是利用现有应用程序,将(恶意)的SQL命令注入到后台数据库引擎执行的能力,它可以通过在Web表单中输入(恶意)SQL语句得到一个存在安全漏洞的网站上的数据库,而不是按照设计者意图去执行SQL语句...
数据库操作教程 2022-09-23 18:19:45 -
SQLserver中字符串逗号分隔函数分享
继SQl-Function创建函数数据库输出的结果用逗号隔开,在开发中也有许多以参数的形式传入带逗号字条串参数(数据大时不建议这样做)例:查找姓名为“张三,李二”的数据此时在数据库里就要对此参数做处理如图:函数代码如下CREATEFUNCTION[dbo].[fnSplitStr](@sTextNVARCHAR(Max),@sDelimCHAR(1))RETURNS@retArrayTABLE(valueVARCHAR(100))ASBEGINDECLARE@posStartBIGINT,@posNextBIGINT,@valLenBIGINT,@sValueNVARCHAR(100);IF@sDelimISNULLBEGINIFLEN(@sText)>100SET@sText=SUBSTRING(@sText,1,100)INSERT@retArray(value)VALUES(@sText);ENDELSEBEGINSET@posStart=1;WHILE@posStart<=LEN(@sText)BEGINSET@posNext=CHARINDEX(@sDelim,@...
数据库操作教程 2022-09-23 18:10:15