-
DATASET与DATAREADER对象有什么区别
DataReader和DataSet最大的区别在于,DataReader使用时始终占用SqlConnection(俗称:非断开式连接),在线操作数据库时,任何对SqlConnection的操作都会引发DataReader的异常。因为DataReader每次只在内存中加载一条数据,所以占用的内存是很小的...
数据库操作教程 2022-09-23 18:01:15 -
SQLserver表数据改变触发发送邮件的方法
今天遇到一个问题,原有生产系统正在健康运行,现需要监控一张数据表,当增加数据的时候,给管理员发送邮件。领到这个需求后,有同事提供方案:写触发器触发外部应用程序...
数据库操作教程 2022-09-23 18:00:59 -
通过使用正确的searcharguments来提高SQLServer数据库的性能
原文地址:http://www.sqlpassion.at/archive/2014/04/08/improving-query-performance-by-using-correct-search-arguments/今天的文章给大家谈谈在SQLServer上关于indexing的一个特定的性能问题。问题看看下面的简单的query语句,可能你已经在你看到过几百次了--ResultsinanIndexScanSELECT*FROMSales.SalesOrderHeaderWHEREYEAR(OrderDate)=2005ANDMONTH(OrderDate)=7GO上门的代码查询一个销售信息,需要一个特定的月份和年份的,这不是很复杂...
数据库操作教程 2022-09-23 18:00:56 -
SQLServer行转列实现思路记录
最近面试遇到了一道面试题,顿时有点迷糊,只说出了思路,后来百度了一下,整理了一下思路,于是记录下来,方便以后学习。(面试题请参见附件)相关的数据表:1.Score表 2.[User]表 SQL语句如下:--方法一:静态SQL复制代码代码如下:SELECT*FROM(SELECTUID,Name,Score,ScoreNameFROMScore,[User]WHEREScore.UID=[User].ID)ASSourceTablePIVOT(AVG(Score)FORScoreNameIN([英语],[数学]))ASa--方法二:动态SQL复制代码代码如下:DECLARE@sNVARCHAR(4000)SELECT@s=ISNULL(@s+',','')+QUOTENAME(ScoreName)FROM(selectdistinctScoreNamefromScore)asA---列名不要重复Declare@sqlNVARCHAR(4000)SET@sql='selectr.*from(selectUID,Name,ScoreName,ScorefromScore,...
数据库操作教程 2022-09-23 18:00:43 -
详解SQLServer的简单查询语句
前言对于一些原理性文章园中已有大量的文章尤其是关于索引这一块,我也是花费大量时间去学习,对于了解索引原理对于后续理解查询计划和性能调优有很大的帮助,而我们只是一些内容进行概括和总结,这一节我们开始正式步入学习SQL中简单的查询语句,简短的内容,深入的理解。简单查询语句所有复杂的语句都是由简单的语句组成基本都是由SELECT、FROM、WHERE、GROUPBY、HAVING、ORDERBY等组成,当然还包括一些谓词等等...
数据库操作教程 2022-09-23 18:00:38 -
SQLServer数据类型char、nchar、varchar、nvarchar的区别浅析
在SQLServer中,当我们设置字符型字段的时候,往往有很多个数据类型供我们选择,如:charncharvarcharnvarchar等,那么我们到底应该选择哪一个呢?下面就一一来描述其区别。char:固定长度,非Unicode字符数据,长度为n个字节...
数据库操作教程 2022-09-23 18:00:22 -
sqlserver判断数据库、表、列、视图是否存在
1判断数据库是否存在ifexists(select*fromsys.databaseswherename='数据库名')dropdatabase[数据库名]2判断表是否存在ifexists(select*fromsysobjectswhereid=object_id(N'[表名]')andOBJECTPROPERTY(id,N'IsUserTable')=1)droptable[表名]3判断存储过程是否存在ifexists(select*fromsysobjectswhereid=object_id(N'[存储过程名]')andOBJECTPROPERTY(id,N'IsProcedure')=1)dropprocedure[存储过程名]4判断临时表是否存在ifobject_id('tempdb...
数据库操作教程 2022-09-23 18:00:17 -
SQLSERVER2000通讯管道后复用劫持
作者:FLASHSKYSITE:WWW.XFOCUS.NET邮件:[email protected]通讯中,允许使用有名管道来进行通讯,一般情况下是如此命名的:默认实例:.pipesqlquery命名实例:.pipeMSSQL$instancenamesqlquery也可以通过1434UDP进行查询获得这个管道名称但是由于SQLSERVER2000对于这个管道的ACL设置为NULL,导致任何用户的权限都可以对这个管道进行劫持,以前的劫持都是利用先停掉服务,再建立这个名字管道,然后再启动服务来复用自己已经建立了名字的管道,但实际上SQLSERVER2000会判断是否已有同名管道,然后会取别的名字,而且低级权限的用户也启动和停止不了服务(除非是利用一些漏洞),但是实际上对管道的测试却发现:如果ACL设置成NULL的话,即使是后命名的管道,也可以劫持先命令的管道,只需要简单复用管道,然后自己建立几个管道的连接不释放(具体建立几个估计和真正的管道建立时的实例个数有关,如在我的测试下,.pipesqlquery只需要建立1个接可以劫持了,而.pipelsass则需要...
数据库操作教程 2022-09-23 18:00:05 -
简析SQLServer数据库用视图来处理复杂的数据查询关系
SQLServer数据库用视图来处理复杂的数据查询关系是本文我们主要要介绍的内容,该内容是这样想到的:在辅助教务系统那块的时候,我做的一个页面是对单个老师和整个学院老师的工作量查询,这个操作设计到了三个本数据库中的表和一个不同数据库中的一个教师信息表,如果用普通的SQL语句是非常难实现的,由于我刚开始做的视频播放系统,数据库的表相对比较少,没有涉及到这么复杂的处理关系,刚开始感觉很难。后来想到用视图可以解决多个表的复杂关系,但是另外一张表是不同数据库的,是否依然能进行操作,经过测试之后,居然可以将不同数据库中的两张表进行建立视图关系,从而视图就是一个虚拟的表,我们将需要查询的不同数据库中的表或者相同数据库中的表,放到一起,然后选择需要的字段,重新建立一个新的虚表,然后这个视图就可以作为一个新的表,进行操作...
数据库操作教程 2022-09-23 17:59:56 -
SQL2000安装后,SQLServer组无项目解决方法
昨天装了个SQL2000,打开企业管理器,发现SQLServer组下面没有任何的内容,提示“无项目”。之前sa设置的都是空密码就没碰到这个现象,这次sa用户设置了密码就出现这个情况!解决方法打开企业管理器,如下图,在“SQLServer组”上右击,选“新建SQLServer注册”,用向导选择一个服务器,一般都是本地,在上面默认的有,双击一下添加右边的框里就行了,选择验证方式,一般都是用电脑系统账号验证,因为站长是在本地使用的,完成注册,这样就OK了...
数据库操作教程 2022-09-23 17:59:53 -
SQLSERVER20009003错误的解决方法(只适用于SQL2000)
关于SQLSERVER9003错误解决方法只适用于SQL2000:"无法打开新数据库'POS'。CREATEDATABASE中止...
数据库操作教程 2022-09-23 17:59:47 -
SQLServer定时访问url激活数据同步示例
创建作业,执行以下命令execmaster..XP_cmdshell'http://srm.rapoo.cn?op=sapintferace&i=1&t=1'激活执行同步网步以下内容来自网络,介绍如何启用xp_cmdshell扩展存储过程将命令一、简介xp_cmdshell扩展存储过程将命令字符串作为操作系统命令shell执行,并以文本行的形式返回所有输出。三、SQLServer2005中的xp_cmdshell由于存在安全隐患,所以在SQLServer2005中,xp_cmdshell默认是关闭的...
数据库操作教程 2022-09-23 17:59:47