sql server 中 怎么让自动增1的主键列 临时的 让它可以手动插入指定值?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql server 中 怎么让自动增1的主键列 临时的 让它可以手动插入指定值?相关的知识,希望对你有一定的参考价值。
它提示说要把什么什么设置为ON
用java的Connection对象的哪个方法执行 SET IDENTITY_INSERT 表名 ON?
这是不是一个存储过程?
stmt=fr_conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
stmt.executeUpdate("SET IDENTITY_INSERT 表名 ON insert into 表名.. SET IDENTITY_INSERT 表名 OFF");
这个试了不行,还是抛一样的异常:
[Microsoft][SQLServer 2000 Driver for JDBC][SQLServer]仅当使用了列的列表,并且 IDENTITY_INSERT 为 ON 时,才能在表 '学生信息表' 中为标识列指定显式值。
我是这样搞的:
Database db = new Database();//这里封装了数据库操作
db.update("set IDENTITY_INSERT 学生信息表 on insert into 学生信息表 select * from 减少的学生 where 学生ID="+ xsid + " set IDENTITY_INSERT 学生信息表 off");
学生信息表 减少的学生 这两张表一模一样。只是 前者学生ID是自动增1,后者不增。
还有:列1,列2,列3... sql server中是可以不要的。
如果写了列的话,语法是错的,出错说:
第 1 行: '学生ID' 附近有语法错误。
打开企业管理器,列的属性里有 自动增长的标识,你要打开,并设置每次自动增长几。
看到标识这一栏没,改成 是。
参考技术A 设置 SET IDENTITY_INSERT 表名 ON 这个属性时,插入语句必须显示出各列的名称在java中调用:
Statement stmt=fr_conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
stmt.executeUpdate("SET IDENTITY_INSERT 表名 ON insert into 表名.. SET IDENTITY_INSERT 表名 OFF");
insert语句需要列出全部的列名:
insert into 表名 列1,列2,列3...
values( 值1,值2,值3... )本回答被提问者采纳 参考技术B SET IDENTITY_INSERT 表名 ON
--你的插入语句
SET IDENTITY_INSERT 表名 OFF
Sql Server 主键 外键约束
表通常具有包含唯一标识表中每一行的值的一列或一组列。 这样的一列或多列称为表的主键 (PK),用于强制表的实体完整性。 由于主键约束可保证数据的唯一性,因此经常对标识列定义这种约束。
如果为表指定了主键约束, 数据库引擎 将通过为主键列自动创建唯一索引来强制数据的唯一性。 当在查询中使用主键时,此索引还允许对数据进行快速访问。 如果对多列定义了主键约束,则一列中的值可能会重复,但来自主键约束定义中所有列的值的任何组合必须唯一。
如下图所示, Purchasing.ProductVendor 表中的 ProductID 和 VendorID 列构成了针对此表的复合主键约束。 这确保了 ProductVendor 表中的每个行都具有 ProductID 和 VendorID的一个唯一组合。 这样可以防止插入重复的行。
-
一个表只能包含一个主键约束。
-
主键不能超过 16 列且总密钥长度不能超过 900 个字节。
-
由主键约束生成的索引不会使表中的索引数超过 999 个非聚集索引和 1 个聚集索引。
-
如果没有为主键约束指定聚集或非聚集索引,并且表中没有聚集索引,则使用聚集索引。
-
在主键约束中定义的所有列都必须定义为不为 Null。 如果没有指定为 Null 性,则参与主键约束的所有列的为 Null 性都将设置为不为 Null。
-
如果在 CLR 用户定义类型的列中定义主键,则该类型的实现必须支持二进制排序。
外键 (FK) 是用于在两个表中的数据之间建立和加强链接的一列或多列的组合,可控制可在外键表中存储的数据。 在外键引用中,当包含一个表的主键值的一个或多个列被另一个表中的一个或多个列引用时,就在这两个表之间创建了链接。 这个列就成为第二个表的外键。
例如,因为销售订单和销售人员之间存在一种逻辑关系,所以 Sales.SalesOrderHeader 表含有一个指向 Sales.SalesPerson 表的外键链接。 SalesOrderHeader 表中的 SalesPersonID 列与 SalesPerson 表中的主键列相对应。 SalesOrderHeader 表中的 SalesPersonID 列是指向 SalesPerson 表的外键。 通过创建此外键关系,如果 SalesPerson 表中不存在外键关系,则 SalesPersonID 的值将无法插入到 SalesOrderHeader 表。
表最多可以将 253 个其他表和列作为外键引用(传出引用)。 SQL Server 2016 将可在单独的表中引用的其他表和列(传入引用)的数量限制从 253 提高至 10,000。 (兼容性级别至少必须为 130。)数量限制的提高带来了下列约束:
-
只有 DELETE DML 操作才支持超过 253 个外键引用。 不支持 UPDATE 和 MERGE 操作。
-
对自身进行外键引用的表仍只能进行 253 个外键引用。
-
列存储索引、内存优化表、Stretch Database 或已分区外键表暂不支持进行超过 253 个外键引用。
外键约束的索引
与主键约束不同,创建外键约束不会自动创建对应的索引。 但是由于以下原因,对外键手动创建索引通常是有用的:
-
当 在查询中组合相关表中的数据时,经常在联接条件中使用外键列,方法是将一个表的外键约束中的一列或多列与另一个表中的主键列或唯一键列匹配。 索引使 数据库引擎 可以在外键表中快速查找相关数据。 但是,创建此索引并不是必需的。 即使没有对两个相关表定义主键或外键约束,也可以对来自这两个表中的数据进行组合,但两个表间的外键关系说明已用其键作为条件对其进行了优化,以便组合到 查询中。
-
对主键约束的更改可由相关表中的外键约束检查。
引用完整性
尽管外键约束的主要目的是控制可以存储在外键表中的数据,但它还可以控制对主键表中数据的更改。 例如,如果在 Sales.SalesPerson 表中删除一个销售人员行,而这个销售人员的 ID 由 Sales.SalesOrderHeader 表中的销售订单使用,则这两个表之间关联的完整性将被破坏; SalesOrderHeader 表中删除的销售人员的销售订单因为与 SalesPerson 表中的数据没有链接而变得孤立了。
外 键约束防止这种情况发生。 如果主键表中数据的更改使之与外键表中数据的链接失效,则这种更改将无法实现,从而确保了引用完整性。 如果试图删除主键表中的行或更改主键值,而该主键值与另一个表的外键约束中的值相对应,则该操作将失败。 若要成功更改或删除外键约束中的行,必须先在外键表中删除或更改外键数据,这会将外键链接到不同的主键数据。
以上是关于sql server 中 怎么让自动增1的主键列 临时的 让它可以手动插入指定值?的主要内容,如果未能解决你的问题,请参考以下文章
sQL数据库表的主键列设为标识,增量为1,下次插入数据时能不插入主键列吗