SqlServer里设置主键自增长有几种方式?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SqlServer里设置主键自增长有几种方式?相关的知识,希望对你有一定的参考价值。

参考技术A 还可以使用
函数和触发器等方式变相实现自增列...
我举个触发器的例子:
--环境
create
table
test_5
(
id
int
primary
key
not
null,
value
int
)
--保存最大序列值的表
create
table
Sequence
(
rn
int
)
insert
Sequence
select
0
go
create
trigger
tr_test_5
on
test_5
Instead
of
insert
as
begin
declare
@n
int
update
Sequence
set
rn=rn+@@rowcount,@n=rn
insert
test_5
select
@n+row_number()over(order
by
getdate()),value
from
inserted
end
go
insert
test_5(value)
select
1
union
select
2
union
select
3
select
*
from
test_5
/*
id
value
-----------
-----------
1
1
2
2
3
3*/
第二个问题:
给你个例子:
--创建测试表
CREATE
TABLE
t1(ID
int
IDENTITY,A
int)
GO
--插入记录
INSERT
t1
VALUES(1)
GO
--1.
将IDENTITY(标识)列变为普通列
ALTER
TABLE
t1
ADD
ID_temp
int
GO
UPDATE
t1
SET
ID_temp=ID
ALTER
TABLE
t1
DROP
COLUMN
ID
EXEC
sp_rename
N't1.ID_temp',N'ID',N'COLUMN'
INSERT
t1
VALUES(100,9)
GO
--2.
将普通列变为标识列
CREATE
TABLE
t1_temp(ID
int,A
int
IDENTITY)
SET
IDENTITY_INSERT
t1_temp
ON
INSERT
t1_temp(ID,A)
SELECT
*
FROM
t1
SET
IDENTITY_INSERT
t1_temp
OFF
DROP
TABLE
T1
GO
EXEC
sp_rename
N't1_temp',N't1'
INSERT
t1
VALUES(109999)
GO
--显示处理结果
SELECT
*
FROM
t1
/*--结果:
ID
A
-----------------
-----------
1
1
100
9
109999
10
--*/
参考技术B 兄弟,很明显,你的是nvachar类型,作为主键肯定会出问题,一般作为主键的是int类型,主键一般是自动增长的,不需要录入,所以你每次这样插入会报错。建议你添加一int类型字段,设为主键,取消user_name作为主键

怎么设置主键自增

在这段代码里,还有就是插入数据怎么总是插入不了

use online;
create table admin(
id int not null unique,
zh varchar(20) not null unique,
mm varchar(20) not null unique,
primary key(id)
);
insert into admin values(NULL,'111','jack','123');
SELECT * FROM admin s;

以sqlserver为例,可用如下语句设置:

create table test
(id int identity(1,1),primary key(id),
name varchar(10))

其中identity(1, 1)为设置主键自增的部分,前边一个1表示从1开始计数,后边一个1表示每次增加的数量。primary key(id)代表id列为主键。

连续执行如下语句:

insert into test(name) values ('a')
insert into test(name) values ('b')
insert into test(name) values ('b')

如图可见,id列达到了自增的目的。

参考技术A 通过int或bigint设置,自增列的类型应为int或bigint型,可以设置起始和每次递增数。
拓展资料
数据库是“按照数据结构来组织、存储和管理数据的仓库”。是一个长期存储在计算机内的、有组织的、可共享的、统一管理的大量数据的集合。
数据库是存放数据的仓库。它的存储空间很大,可以存放百万条、千万条、上亿条数据。但是数据库并不是随意地将数据进行存放,是有一定的规则的,否则查询的效率会很低。当今世界是一个充满着数据的互联网世界,充斥着大量的数据。即这个互联网世界就是数据世界。数据的来源有很多,比如出行记录、消费记录、浏览的网页、发送的消息等等。除了文本类型的数据,图像、音乐、声音都是数据。
数据库是一个按数据结构来存储和管理数据的计算机软件系统。数据库的概念实际包括两层意思:
(1)数据库是一个实体,它是能够合理保管数据的“仓库”,用户在该“仓库”中存放要管理的事务数据,“数据”和“库”两个概念结合成为数据库。
(2)数据库是数据管理的新方法和技术,它能更合适的组织数据、更方便的维护数据、更严密的控制数据和更有效的利用数据。
数据库管理系统是为管理数据库而设计的电脑软件系统,一般具有存储、截取、安全保障、备份等基础功能。数据库管理系统可以依据它所支持的数据库模型来作分类,例如关系式、XML;或依据所支持的计算机类型来作分类,例如服务器群集、移动电话;或依据所用查询语言来作分类,例如SQL、XQuery;或依据性能冲量重点来作分类,例如最大规模、最高运行速度;亦或其他的分类方式。不论使用哪种分类方式,一些DBMS能够跨类别,例如,同时支持多种查询语言。
参考技术B sqlserver:选中表右键设计→选中自增列看下边的列属性→找到【标识规范】前边'+'点开→【是标识】设为'是',下边的就自己设了。

mysql:选中表右键设计→选中自增列看下边的列属性→ 英文版的下边是 [auto increment]就是自增的意思→勾上,就行了
参考技术C 主键在工具栏有一个钥匙图标,点击即可设置主键。自增则是在列属性中的标识规范中,将标识规范改为是就行了。追问

那我插入数据出现这个Column count doesn't match value count at row 1
是和没设置主键自增有关系吗?

本回答被提问者采纳

以上是关于SqlServer里设置主键自增长有几种方式?的主要内容,如果未能解决你的问题,请参考以下文章

怎么设置主键自增

sql 设置主键 自动增长

如何修改sql server主键自动增长

MyBatis+Oracle实现主键自增长的几种常用方式

sql主键列自增问题

如何设置主键自增从1000开始每次自增1