-
SQLServer高可用的常见问题分析
每次谈到SQLServer的高可用,很多的DBA,特别是SQLServerDBA心里一痛:因为大家都认为SQLServer无法或者很难实现SQLServer。也有很多的DBA朋友脑袋一拍,给出答案“高可用不就是微软的那几个技术吗,如Replication,FailoverClustering”…1.难道SQLServer在高可用上面就显得这么的无力吗?回答:不是的,其实SQLServer很给力...
数据库操作教程 2022-09-23 17:03:06 -
浅谈SQLServer中的三种物理连接操作(性能比较)
在SQLServer中,我们所常见的表与表之间的InnerJoin,OuterJoin都会被执行引擎根据所选的列,数据上是否有索引,所选数据的选择性转化为LoopJoin,MergeJoin,HashJoin这三种物理连接中的一种。理解这三种物理连接是理解在表连接时解决性能问题的基础,下面我来对这三种连接的原理,适用场景进行描述...
数据库操作教程 2022-09-23 17:01:23 -
被遗忘的SQLServer比较运算符谓词
官方的参考文档http://technet.microsoft.com/zh-cn/library/ms187074%28SQL.90%29.aspx他们作用于比较运算符和子查询之间,作用类似Exists、notexists、in、notin以及其他逻辑意义,这些语法同样被SQLServer2000支持但是很少看到有人用它们。复制代码代码如下:setnocountonusetempdbgoif(object_id('t1')isnotnull)droptablet1createtablet1(nint)insertintot1select2unionselect3if(object_id('t2')isnotnull)droptablet2createtablet2(nint)insertintot2select1unionselect2unionselect3unionselect4select*fromt2wheren>all(selectnfromt1)--4select*fromt2wheren>any(selectnfromt1)--3,4--select*fro...
数据库操作教程 2022-09-23 16:58:36 -
sql时间函数整理的比较全了
1.当前系统日期、时间selectgetdate()2.dateadd在向指定日期加上一段时间的基础上,返回新的datetime值例如:向日期加上2天selectdateadd(day,2,'2004-10-15')--返回:2004-10-1700:00:00.000例如:查询目前时间最近三天的内容降序排列select*fromtablewheretimebetweendateadd(day,-3,getdate())andgetdate()orderbyc_Iddesc3.datediff返回跨两个指定日期的日期和时间边界数。selectdatediff(day,'2004-09-01','2004-09-18')--返回:174.datepart返回代表指定日期的指定日期部分的整数...
数据库操作教程 2022-09-23 16:53:54 -
mssqlinsertinto和insertintoselect性能比较
使用insertintotable(field,...)values(value,...),insertintotable(field,...)values(value,...)...的情况 使用insertintotable(field,...)select(value,...)unionallselect(value,...)unionallselect(value,...)...的情况我一次插入的数据是:1190条。用insertinto所用的时间在510毫秒上下徘徊,而用insertintoselect所用的时间在16毫秒上下徘徊...
数据库操作教程 2022-09-23 16:52:19 -
SQL级联删除与级联更新的方法
复制代码代码如下:ondeletecascade当你更新或删除主键表时,那么外键表也会跟随一起更新或删除,需要在建表时设置级联属性CREATETABLECountries(CountryIdINTPRIMARYKEY)INSERTINTOCountries(CountryId)VALUES(1)INSERTINTOCountries(CountryId)VALUES(2)INSERTINTOCountries(CountryId)VALUES(3)CREATETABLECities(CityIdINTPRIMARYKEY ,CountryIdINTREFERENCESCountriesONDELETECASCADE);INSERTINTOCitiesVALUES(1,1)INSERTINTOCitiesVALUES(2,1)INSERTINTOCitiesVALUES(3,2)CREATETABLEBuyers(CustomerIdINTPRIMARYKEY,CityIdINTREFERENCESCitiesONDELETECASCADE);INSERTINTOBuyers&...
数据库操作教程 2022-09-23 16:47:39 -
SQLServer比较日期大小的方法
在机房收费系统中,有几处这样的情况:起始日期和终止日期,相信聪明的你肯定可以想象出为什么要有两个日期控件!是的,就是从一张表中查找出在这两个日期范围类的记录!有的人就说了,这还不简单!假如我们将第一个控件定义成Begin,第二个控件定义成Over!那么查询语句不就是复制代码代码如下:"select*fromrecharge_infowheredate<'"&over.value&"'anddate>'"&begin.value&"'" 这有什么难的!但是,事实并不是这么简单的,如果查询语句像这样写的话,你是肯定查找不出来的,那么我们到底该怎能在SQLServer中来比较两个日期的大小呢?这里我们就要借用CONVERT()函数了CONVERT()函数是把日期转换为新数据类型的通用函数。CONVERT()函数可以用不同的格式显示日期/时间数据...
数据库操作教程 2022-09-23 16:46:14 -
Windows下使用性能监视器监控SqlServer的常见指标
上边文章中提到win的性能监视器是监控数据库性能必备的工具,接下来我就给大家介绍一些常见的监控指标,其实无非就是磁盘,cpu,内存等硬件的运行指标还有数据库自身的像锁啊、用户连接数啊、还有就是根据自身业务决定的需要注意的参数指标。1.SQLServerBuffer:BufferCacheHitRatio 这是一个很重要查看内存是否不足的参数...
数据库操作教程 2022-09-23 16:45:42 -
SQLServer数据库中的表名称、字段比较
前言项目中一般分测试环境(QAS),生产环境(PRD),当我们的项目经历了一次周期跨度较长的更新后,当我们发布到生产环境时,首要的任务是将新增的表,字段更新到生产数据库。很多时候,当我们发布更新的时候,已经很难记得做了哪些变更...
数据库操作教程 2022-09-23 16:42:58 -
SQLServer中row_number函数的常见用法示例详解
一.SQLServerRow_number函数简介ROW_NUMBER()是一个Window函数,它为结果集的分区中的每一行分配一个连续的整数。行号以每个分区中第一行的行号开头...
数据库操作教程 2022-09-23 16:42:08 -
sqlserver比较两个表的列
一、问题给了两个各有四五十个列的表,找出他们相同的列和不同的列二、查询两个表的列,存在临时表--#a,#b都是临时表,当前连接断开后自动删除--RANK()OVER(ORDERBYsyscolumns.nameDESC)AS是SQL2005支持的,在每行记录前加上自增序号--IDENTITY(INT,1,1)函数必须要和into联合使用1、将表的列存入#a--'destTbl'比较的表名select* into#afrom(select RANK()OVER(ORDERBYsyscolumns...
数据库操作教程 2022-09-23 16:41:47 -
SQl语句(常见)
新建表:create table [表名]([自动编号字段] int IDENTITY (1,1) PRIMARY KEY ,[字段1] nVarChar(50) default '默认值' null ,[字段2] ntext null ,[字段3] datetime,[字段4] money null ,[字段5] int default 0,[字段6] Decimal (12,4) default 0,[字段7] image null ,)删除表:Drop table [表名]插入数据:INSERT INTO [表名] (字段1,字段2) VALUES (100,'51WINDOWS.NET')删除数据:DELETE&n...
数据库操作教程 2022-09-23 16:31:48