主键sqlserver,主键的作用

sqlserver 怎么设置主键自增长

比方说,你要创建一个表user_info,设置的主键名称是user_id,那么可以如下设置:

让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:申请域名网站空间、营销软件、网站建设、泽普网站维护、网站推广。

create

table

user_info

(user_id

int

primary

key

identity(1,1),//主键初值为1,每次自增1,数值可变化,但要符合之前定义的类型

user_name

varchar(20)

not

null,

....

)

希望能帮到你!~

sqlserver怎么获取主键的值

插入一条记录后想要立刻获取其数据表中的sql server主键返回值。这个主键是自动生成的,其实实现的方式有很多,比如再进行一次查询,获取出来。或者在插入数据之前取出最大值,在最大值上面加一等等,方法很多,但是有些很不方便。

个人感觉最快的方式就是,在插入数据后直接获取sql server主键的值,然后返回过来。

方法如下:

sql语句如下:

INSERT INTO tableName (fieldname ...) values (value ...) SELECT @@IDENTITY AS returnName;

在sql语句中加入SELECT @@IDENTITY AS returnName;用来获取sql server主键的值

在程序中获取返回值:

public int sqlexecutereader(string sql) { DBopen(); SqlCommand myComm = new SqlCommand(sql, Connection); int newID = Convert.ToInt32(myComm.ExecuteScalar()); DBclose(); return newID; }

当然在此处主键是int类型的自动增加的。DBopen();DBclose();的操作在此就不多说了。

Sqlserver 数据库自动编号主键怎么设计?

1.

首先删除主键,

然后重新创建主键,

重新创建主键的时候,

需要说明本主键是使用

非聚集索引

primary

key

nonclustered

(

sno

)

2.

a:

pad_index

=

{

on

|

off

}

指定索引填充。默认值为

off。

on

fillfactor

指定的可用空间百分比应用于索引的中间级页。

off

或不指定

fillfactor

考虑到中间级页上的键集,将中间级页填充到接近其容量的程度,以留出足够的空间,使之至少能够容纳索引的最大的一行。

b:

fillfactor

=fillfactor

指定一个百分比,指示在创建或重新生成索引期间,数据库引擎对各索引页的叶级填充的程度。fillfactor

必须为介于

1

100

之间的整数值。默认值为

0。如果

fillfactor

100

0,则数据库引擎将创建完全填充叶级页的索引。

c:

ignore_dup_key

=

{

on

|

off

}

指定在插入操作尝试向唯一索引插入重复键值时的错误响应。ignore_dup_key

选项仅适用于创建或重新生成索引后发生的插入操作。当执行

create

index、alter

index

update

时,该选项无效。默认值为

off。

on

向唯一索引插入重复键值时将出现警告消息。只有违反唯一性约束的行才会失败。

off

向唯一索引插入重复键值时将出现错误消息。整个

insert

操作将被回滚。

d:

statistics_norecompute

=

{

on

|

off}

指定是否重新计算分发统计信息。默认值为

off。

on

不会自动重新计算过时的统计信息。

off

启用统计信息自动更新功能。

若要恢复统计信息自动更新,请将

statistics_norecompute

设置为

off,或执行

update

statistics

但不包含

norecompute

子句。

e:

on

[primary]

是指

索引创建在

primary

这个文件组上。

3、

以全国的身份证为例子:

对于

身份证号码,

有个

“唯一”

的索引

而对于

姓名,

有个

“不唯一”

的索引。

“不唯一”

的索引

虽然不能定位到唯一的某一行,

但是可以缩小范围。定位到某些行。

4.

聚集索引

clustered

创建索引时,键值的逻辑顺序决定表中对应行的物理顺序。聚集索引的底层(或称叶级别)包含该表的实际数据行。一个表或视图只允许同时有一个聚集索引。

sqlserver数据库修改主键类型

如果每次要更新多行,那必须还要有一个唯一索引来定位要修改的记录,比如为Col_Uq,那可以如下写触发器:

create

trigger

tri_update_tb_1_pk

on

tb_1

for

update

as

if

not

update(col_pk)

return

update

tb_2

set

col_pk=i.col_pk

from

tb_2,inserted

i,deleted

d

where

tb_2.col_pk=d.col_pk

and

i.Col_Uq=d.Col_Uq

go

如果保证每次只更新一行,那可以如下写触发器:

create

trigger

tri_update_tb_1_pk

on

tb_1

for

update

as

if

not

update(col_pk)

return

if

(select

count(*)

from

inserted)

1

return

update

tb_2

set

col_pk=i.col_pk

from

tb_2,inserted

i,deleted

d

where

tb_2.col_pk=d.col_pk

go

SQLServer主键和唯一约束的区别

首先说明一点,主键又称主键约束,它也是一种约束,看下它和唯一约束的创建语法:

alter

table

Person

add

constraint

PK_Id

primary

key

(Id)

alter

table

Person

add

constraint

UQ_Name

unique

(Name)

主键和唯一约束都要求字段值唯一,除此外,它们还有如下区别:

·同一张表只能有一个主键,但能有多个唯一约束;

·主键字段值不能为NULL,唯一约束字段值可以为NULL;

·主键字段可以做为其他表的外键,唯一约束字段不可以做为其他表的外键;

·SQLServer默认为主键字段创建聚集索引,为唯一约束字段创建非聚集索引;

主键,唯一,但是不能为空;唯一约束,唯一,但是可以为空

sqlserver设置主键自增

创建表的时候可以 比如ID列自增

create table T1

(

id int identity(1,1),

ccode varchar(10),

cname varchar(100)

)


文章名称:主键sqlserver,主键的作用
网页链接:http://pwwzsj.com/article/dseeccj.html