-
sql自增id怎么使用?如何增加自增字段?
所属栏目:[MsSql教程] 日期:2022-03-03 热度:163
sql自增id怎么使用?sql自增id能够实现序号自动增加,那么具体怎么操作呢?下面我们一起来看看使用sql自增id怎样做自增字段操作,感兴趣的朋友可以了解一下。 1、SQL server中创建表,带有自增列。 create table Test_Table(Id int Identity(1,1), Name va[详细]
-
sql中identity自增的方法是什么?
所属栏目:[MsSql教程] 日期:2022-03-03 热度:122
一些新手对于sql中identity自增的用法不是很了解,对此本文给大家介绍sql中identity自增的基本用法,重新设置identity的值、向identity字段插入数据等操作,有需要的朋友可以参考。 一、identity的基本用法 1.含义 identity表示该字段的值会自动更新,不需[详细]
-
sql查询怎么样去除重复数据?教你三种方法
所属栏目:[MsSql教程] 日期:2022-03-03 热度:173
我们数据库的数据表中有大量的数据,我们查询的时候重复的数据都会展示而且查询时间长,那么要怎么实现sql查询去掉重复数据呢?下面小编给大家分享几种SQL查询去掉重复数据的方法,小编觉得比较实用,大家可以看看。 说明: 只要数据表列名数据相同,则说[详细]
-
sql serve中page结构怎么理解?一文带你看明白page结构
所属栏目:[MsSql教程] 日期:2022-03-03 热度:166
这篇文章给大家主要介绍的是SQL server中page结构的内容,下文会从详细介绍其概念、原理等等,对于新手理解page结构有一定的帮助,下面就跟随小编来学习一下吧。 SQL Server存储数据的基本单元是Page,每一个Page的大小是8KB,数据文件是由Page构成的。在[详细]
-
sqlserver中check约束是什么?如何创建?
所属栏目:[MsSql教程] 日期:2022-03-03 热度:166
本文给大家分享的是关于sqlserver中check约束的内容,下文会给大家介绍check约束的概念、语法、使用等等,有这方面学习需要的朋友们可以借鉴参考。 0.什么是Check约束? CHECK约束指在表的列中增加额外的限制条件。 注: CHECK约束不能在VIEW中定义。CHECK[详细]
-
sql server触发器有哪些类型,怎样创建?
所属栏目:[MsSql教程] 日期:2022-03-03 热度:60
什么是触发器?很多刚接触SQL sever的新手对于触发器不是很了解,其实触发器就是一种特殊类型的存储过程,触发器主要是通过事件进行触发被自动调用执行的。接下来我们就具体了解什么是触发器,触发器有什么优点,如何创建触发器等等。 什么是触发器 触发器[详细]
-
SQL中NULL是何意思?如何使用?
所属栏目:[MsSql教程] 日期:2022-03-03 热度:89
我们在使用SQL Server中或维护时,常会见到NULL,很多新手对于null是什么?不是很了解,对此下面就给大家介绍下关于null的通俗解释和使用。 下面是MSDN给出的一段简短描述(见Null Values): A value of NULL indicates that the value is unknown. A val[详细]
-
sqlserver分页有哪些办法,你知道几个?
所属栏目:[MsSql教程] 日期:2022-03-03 热度:58
这篇文章给大家分享的是有关sqlserver分页的内容,主要介绍4种sqlserver分页方法,分别三重循环、利用max、利用row_number关键字和offset /fetch next,下文有具体示例供大家参考学习。 这篇博客讲的是SQL server的分页方法,用的SQL server 2012版本。下[详细]
-
sql 怎样实现批量插入数据?有哪些办法?
所属栏目:[MsSql教程] 日期:2022-03-03 热度:185
sql server怎样实现批量插入数据?我们经常会需要做插入数据操作,那么对于批量数据我们如何插入呢?下面小编就给大家分享三种插入数据方式和批量插入实例 ,感兴趣的朋友可以参考参考。 一、Sql Server插入方案介绍 关于 SqlServer 批量插入的方式,有三[详细]
-
sql附加数据库失败是什么原因?如何解决?
所属栏目:[MsSql教程] 日期:2022-03-03 热度:138
一些朋友对于sql附加数据库失败怎么解决不是很清楚,下面小编给大家分享报错341和报错5120两种情况的解决办法,需要的朋友可参考。下面我们就来一起看看。 1、错误3415 问题:附加数据库的时候,发现总是附加失败,查看消息时发现问题如下: 查看消息后发[详细]
-
SQLServer Execpt和not in 性能差异
所属栏目:[MsSql教程] 日期:2021-12-24 热度:173
主要讲 except 和 not in 的性能上的区别。 复制代码 代码如下: CREATE TABLE tb1(ID int) CREATE TABLE tb2(ID int) BEGIN TRAN DECLARE @i INT = 500 WHILE @i 0 begin INSERT INTO dbo.tb1 VALUES ( @i -- v - int ) SET @i = @i -1 end COMMIT我测试的[详细]
-
确定触发器正在处理的是插入,删除还是更新触发
所属栏目:[MsSql教程] 日期:2021-12-24 热度:139
但是有时候,可以视看处进逻辑程度,可以把三者写成一个触发器,只是在其中稍作判断而已。 你可以根据从下面方法判断触发器是是处理了插入,删除还是更新触发的: 复制代码 代码如下: --宣告两个变量 DECLARE @D BIT = 0 DECLARE @I BIT = 0 --如果在DELETE[详细]
-
决定字段是否被更新 新旧数据写入Audit Log表中
所属栏目:[MsSql教程] 日期:2021-12-24 热度:100
Insus.NET解决这个问题,只有创建另外一个表,将存储用户决定要跟踪的表,以及这个表中需要跟踪的字段。 还要创建另外一个表[Audit],就是存储跟踪记录的表: 复制代码 代码如下: Audit SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO SET ANSI_PADDING[详细]
-
SQL 计算一个数据库中所有表记录的数量
所属栏目:[MsSql教程] 日期:2021-12-24 热度:175
复制代码 代码如下: CREATE TABLE #tmptb(tbname sysname,tbrows int ,tbREserved varchar(10),tbData varchar(10) ,tbIndexSize varchar(10),tbUnUsed varchar(10)) INSERT INTO #tmptb exec sp_MSForEachTable EXEC sp_spaceused ? SELECT * from #tmptb[详细]
-
sqlserver 动态创建临时表的语句说明
所属栏目:[MsSql教程] 日期:2021-12-24 热度:70
因此计划先把数据转插入一个临时表,再对临时表的数据进行分析。 问题点是如何动态创建临时表。原先Insus.NET使用下面代码实现: 复制代码 代码如下: DECLARE @s NVARCHAR(MAX) = IF OBJECT_ID([dbo].[#Tb]) IS NOT NULL DROP TABLE [dbo].[#Tb] CREATE TAB[详细]
-
某年第一周实施日期实现方法
所属栏目:[MsSql教程] 日期:2021-12-24 热度:151
复制代码 代码如下: SELECT [StartDate] FROM [dbo].[udf_Week](2012,2012) WHERE [Week] = 1 上面SQL语句执行结果: 但你还是觉得此方法很复杂,而且只需要日期部分,时间部分无需显示。因此Insus.NET更改并产生如下一个新函数,你把函数附加入你的数据库[详细]
-
在sql Server自定义一个用户定义星期代码
所属栏目:[MsSql教程] 日期:2021-12-24 热度:95
文件:.wmv;大小:19,535KB;长度:00:26:39。 下载地址:SqlFunction_udf_Week.rar 以下内容于20120105更新: 2012年刚到,开发的软件使用这个函数发现bug。2012年第一周应该是2012-01-01至2012-01-07,但此函数却把2012-01-08至2012-01-14当作第一周。[详细]
-
多表关联同时更新多条不同的记录方法说明
所属栏目:[MsSql教程] 日期:2021-12-24 热度:92
以下为测试例子。 1.首先创建两张临时表并录入测试数据: 复制代码 代码如下: create table #temptest1 ( id int, name1 varchar(50), age int ) create table #temptest2 ( id int, name1 varchar(50), age int ) 查询出此时的表数据为: #temptest1 #temp[详细]
-
SQL截取字符串函数了解
所属栏目:[MsSql教程] 日期:2021-12-24 热度:61
A.截取从字符串左边开始N个字符 Declare @S1 varchar(100) Select @S1=http://www.xrss.cn Select Left(@S1,4) ------------------------------------ 显示结果: http B.截取从字符串右边开始N个字符(例如取字符) Declare @S1 varchar(100) Select @S1=http[详细]
-
SqlServer中的日期与时间代码
所属栏目:[MsSql教程] 日期:2021-12-24 热度:79
一、Sql Server中的日期与时间函数 1. 当前系统日期、时间 select getdate() 2. dateadd 在向指定日期加上一段时间的基础上,返回新的 datetime 值 例如:向日期加上2天 select dateadd(day,2,2004-10-15) --返回:2004-10-17 00:00:00.000 3. datediff 返[详细]
-
SQL语句 一个简单的字符串分割函数
所属栏目:[MsSql教程] 日期:2021-12-24 热度:88
复制代码 代码如下: CREATE FUNCTION dbo.f_splitstr( @str varchar(8000) )RETURNS @r TABLE(id int IDENTITY(1, 1), value varchar(5000)) AS BEGIN /* Function body */ DECLARE @pos int SET @pos = CHARINDEX(,, @str) WHILE @pos 0 BEGIN INSERT @r(v[详细]
-
小议sqlserver数据库主键选取策略
所属栏目:[MsSql教程] 日期:2021-12-24 热度:177
因为主键可以唯一标识某一行记录,所以可以确保执行数据更新、删除的时候不会出现张冠李戴的错误。当然,其它字段可以辅助我们在执行这些操作时消除共享冲突,不过就不在这里讨论了。主键除了上述作用外,常常与外键构成参照完整性约束,防止出现数据不一致[详细]
-
sqlserver自动增长列引起的问题解决方法
所属栏目:[MsSql教程] 日期:2021-12-24 热度:50
有两个结构完全相同的表,由其中一个表插入另一个表中指定条件的数据,报如下错误: 仅当使用了列列表并且 IDENTITY_INSERT 为 ON 时,才能为表*中的标识列指定显式值。 在网上找到了解决方案,亲自试过,可以解决。 方法: 复制代码 代码如下: SET IDENTIT[详细]
-
sqlserver 存储过程动态参数调用实现代码
所属栏目:[MsSql教程] 日期:2021-12-24 热度:70
复制代码 代码如下: --创建测试表 CREATE TABLE [dbo].[Student]( [ID] [int] IDENTITY(1,1) NOT NULL PRIMARY KEY, [Name] [nvarchar](20) NOT NULL DEFAULT (), [Age] [int] NOT NULL DEFAULT (0), [Sex] [bit] NOT NULL DEFAULT (0), [Address] [nvarch[详细]
-
通过分析SQL语句的执行计划优化SQL
所属栏目:[MsSql教程] 日期:2021-12-24 热度:51
如何干预执行计划 - - 使用hints提示 基于代价的优化器是很聪明的,在绝大多数情况下它会选择正确的优化器,减轻了DBA的负担。但有时它也聪明反被聪明误,选择了很差的执行计划,使某个语句的执行变得奇慢无比。此时就需要DBA进行人为的干预,告诉优化器使[详细]