首页
学习
活动
专区
圈层
工具
发布

Sql server DATEADD日期函数的使用

大家好,又见面了,我是你们的朋友全栈君。 DATEADD日期函数 DATEADD() 函数在日期中添加或减去指定的时间间隔。...日: 在当前日期上加两天 select DATEADD(day,2,'2014-12-30') 2015-01-01 select DATEADD(dd,2,'2014-12-30') 月: 在当前日期上加两个月...DATEADD(mm,2,'2014-12-30') 结果:2015-02-28 select DATEADD(MONTH,2,'2014-12-30') 结果:2015-02-28 年: 在当前日期上加两年...12-30 select DATEADD(year,2,'2014-12-30') 结果:2016-12-30 语法 DATEADD(datepart,number,date) date 参数是合法的日期表达式...文中存在的观点/描述不正确的地方,欢迎指正。 感谢您的阅读,如果您对我的博客所讲述的内容有兴趣,请继续关注我的后续博客,我是yxtic 。

2.6K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    SQL Server中的GUID

    1、在 SQL Server 中使用 GUID 如果在 SQL Server 的表定义中将列类型指定为 uniqueidentifier,则列的值就为 GUID 类型。...SQL Server 中的 NewID() 函数可以产生 GUID 唯一值,使用此函数的几种方式如下: 1) 作为列默认值 将 uniqueidentifier 的列的默认值设为 NewID(),这样当新行插入表中时...2)使用 T-SQL 在 T-SQL 中使用 NewID()函数,如“INSERT INTO Table(ID,… ) VALUES(NewID(),…)”来生成此列的 GUID 值。...而 Guid 计算全部 16 个字节,这种差异可能会给 SQL Server 中 uniqueidentifier 列的排序带来一定影响,当然这种排序意义也不大。....NET Framework 中可以使用类 GuidConverter 提供将 Guid 结构与各种其他表示形式相互转换的类型转换器。

    7.1K20

    SQL Server 返回最后插入记录的自动编号ID

    SCOPE_IDENTITY 返回为当前会话和当前作用域中的任何表最后生成的标识值 SCOPE_IDENTITY 和 @@IDENTITY 返回在当前会话中的任何表内所生成的最后一个标识值。...当将某行插入 T1 时,触发器被激发,并在 T2 中插入一行。此例说明了两个作用域:一个是在 T1 上的插入,另一个是作为触发器的结果在 T2 上的插入。...@@IDENTITY 返回插入到当前会话中任何作用域内的最后一个 IDENTITY 列值,该值是插入 T2 中的值。...SCOPE_IDENTITY() 返回插入 T1 中的 IDENTITY 值,该值是发生在相同作用域中的最后一个 INSERT。...ajqc的实验:(40条本地线程,40+40条远程线程同时并发测试,插入1200W行),得出的结论是: 1.在典型的级联应用中.不能用@@IDENTITY,在CII850,256M SD的机器上1W

    3.2K40

    SQL Server 2008基于策略的管理

    基于策略的管理(Policy Based Management),使DBA们可以制定管理策略,并将这些策略应用到服务器、数据库以及数据环境中的其他对象上去。...执行模式:SQL Server 2008的基于策略的管理支持4种执行模式,这4种模式决定了策略对目标的影响程度。...l 更新时阻止(On Change - Prevent):这是最严格的一种,SQL Server 2008通过DDL Trigger的方式在订阅该策略的目标上发生操作时实施检查操作对策略的符合性,如果违反策略则回滚该操作...l 更新时记录(On Change - Log Only):SQL Server 2008通过Event Notification的机制在在订阅该策略的目标上发生操作时实施检查操作对策略的符合性,如果违反策略则发送消息...参考 SQL Server 2008安全性 教程:使用基于策略的管理来管理服务器

    94890

    谈谈基于SQL Server 的Exception Handlingp

    中使用RAISERROR将一个可预知的Error抛出;如何在Stored procedure中使用TRY/CATCH进行异常的捕捉;在Application如果处理从SQL Server抛出的Exception...实际上,SQL Server database Engine抛出、被我们的.NET最终捕获的SqlException,我们通过SqlException的属性可以得到Error的相关信息。...CreateUser(): 在这里我想特别说明一下SqlException.Number这个属性,它代表Database中的Error number[或者是@@ERROR、imessage_id...GO 我们的现在的目标是在Application中,如何得到这段Message。...要做到这点很简单,只需要用到SqlConnection的InfoMessage事件,当通过DbCommand执行上面一段Sql的时候,Print语句的执行将出发该事件。

    43710

    谈谈基于SQL Server 的Exception Handling

    [注:这里的Database主要指SQL Server]。...谈谈基于SQL Server 的Exception Handling - PART I 在这一节中,我们将对@@ERROR进行详细讨论,详细大家会对@@ERROR有一个深刻的认识;随后,我将介绍在T-SQL...谈谈基于SQL Server 的Exception Handling - PART II 大家已经习惯了在.NET编程语言中使用Try/Catch,不知道大家对T-SQL有没有深入的认识。...在本节中,将着重介绍在T-SQL中如何使用Try/Catch进行异常处理;当我们人为地进行异常处理的时候,我们制定异常相关的Message信息, 这些Message通过SQL Server特性的数据表进行维护...谈谈基于SQL Server 的Exception Handling - PART III 对于基于SQL Server的ADO.NET应用来说,SqlException将是我们最常见的异常,本节中将会对

    66710

    SQL Server 中的死锁检测

    从 SQL Server 2012 (11.x) 开始,xml_deadlock_report应使用扩展事件 (xEvent),而不是 SQL 跟踪或 SQL 事件探查器中的死锁图事件类。...同样从 SQL Server 2012 (11.x) 开始,当发生死锁时,system_health会话已捕获xml_deadlock_report包含死锁图的所有 xEvent。...由于system_health会话默认启用,因此不需要配置单独的 xEvent 会话来捕获死锁信息。无需执行任何其他操作即可使用 xEvent 捕获死锁信息xml_deadlock_report。...为了帮助最大限度地减少死锁:以相同的顺序访问对象。避免交易中的用户交互。- 保持交易简短并集中进行。使用较低的隔离级别。使用基于行版本控制的隔离级别。...view=sql-server-ver16https://www.mssqltips.com/sqlservertip/5658/capturing-sql-server-deadlocks-using-extended-events

    1.7K10

    SQL 中的日期和时间类型

    在我们SQL中一般支持三种数据类型。 date:日历日期,包括年(四位),月和日。 time: 一天中的时间,包括小时,分和秒。可以用变量time(p)来表示秒的小数点后的数字位数(默认是0)。 ...如果指定with timezone,则时区信息也会被存储 日期和时间类型的值可按如下方式说明: date:‘2018-01-17’ time:‘10:14:00’ timestamp:‘2018-01-...17 10:14:00.45’ 日期类型必须按照如上年月日的格式顺序指定。...我们可以利用cast e as t形式的表达式来讲一个字符串(或字符串表达式)e转换成类型t,其中t是date,time,timestamp中的一种。字符串必须符合正确的格式,像本段开头说的那样。...---- 我们可以利用extract(field from d),从date或time的值d中提取出单独的域,这里的域可是 year,month,day, hour,minute或者second中的任意一种

    4.8K60

    SQL Server生成随机日期模拟测试数据的需求

    最近碰到个SQL Server跑SQL的性能问题,同样是关系型数据库,因此在原理层面,不同数据库之间有些内容是可以借鉴的,但是SQL Server一些细节上和操作层面,略有不同,需要熟悉和积累。...Studio中执行。...此时t1中id字段由于设置了idntitiy,会得到从1到10000的值,但是c1字段为空,由于测试需求,需要让c1字段存储"yyyymmdd"的日期数值。 3. ...生成随机日期的数据中间表 SQL Server生成随机数可以用函数rand(),例如, select cast(rand()*1000 as int); 如果生成随机的日期,找了一种方式, declare...,"select ... into t2 from t1"则从t1表取出所有的记录(10000条),包括了自增的主键字段id,以及每行随机生成的日期字符串c1,插入到t2,字段名称是id和random_date

    2.3K20

    sql删除一条记录后其他记录的id自动迁移,使id连续

    在写一个应用时,有这么一个操作:客户端传过来点击的位置,进行运算后得到相应数据在数据库里的id,然后显示对应的信息。...但是在进行delete后数据显示就混乱了,发现根本原因是原本连续的数据id(例如:1、2、3、4),在sqlite的delete语句执行完后(比如说删除id为2的数据),变得不连续(1、3、4)。...删除后点击第三个数据,结果他显示成第二个,而第二个早就删除了,因此显示的信息完全混乱。...(Object[]) ids); //更新id,使id大于要删除的id的往前移动一位。...db.execSQL("update tb_diary2 set _id=_id-1 where _id > ?",(Object[] )ids); 很多网友都说这样会影响性能,应该用触发器进行操作。

    1.7K20

    SQL Server中的锁的简单学习

    开发人员不用担心SQL Server是如何决定使用哪个锁的。因为SQL Server已经做了最好的选择。     在SQL Server中,锁的粒度如表1所示。...图10.使用一个表锁代替6000个键锁     虽然使用一个表锁代替了6000个键锁,但是会影响到并发,我们对不在上述查询中行做更新(id是50001,不在图10中查询的范围之内),发现会造成阻塞,如图...图11.锁升级提升性能以减少并发为代价 锁模式     当SQL Server请求一个锁时,会选择一个影响锁的模式。锁的模式决定了锁对其他任何锁的兼容级别。...在SQL Server中,资源是有层次的,一个表中可以包含N个页,而一个页中可以包含N个行。当我们在某一个行中加了锁时。可以理解成包含这个行的页,和表的一部分已经被锁定。...因此SQL Server锁定一个粒度比较低的资源时,会在其父资源上加上意向锁,告诉其他查询这个资源的某一部分已经上锁。

    2.5K60

    SQL Server 2008中增强的汇总技巧

    SQL Server 2008中SQL应用系列--目录索引 SQL Server 2008中对汇总有明显的增强,有点像Oracle的语法了。...注意:使用Rollup与指定的聚合列的顺序有关。...至此,如果还有美中不足的话,那就是分组还是有点凌乱,下面我们将隆重推出终极武器--Grouping_ID,它与Grouping类似,但提供更为精细的颗粒度,以确认分组级别,当然使用也更为复杂,请看下面的示例...,这里需要稍微解释一下,Grouping_ID接受几个输入列,返回二进制列列表计算的整数值,你可以把这三个维度,看作是(0,1,1)、(0,1,0)这样类似的二进制,而Grouping_ID负责将运算结果以整数形式返回...小结:带有Cube,Rollup,grouping Sets的Group By函数在统计与分析中有着广泛的应用,相信它的高效简捷,在特定的场合会令你爱不释手!

    1.5K30
    领券