A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© qly2046 中级黑马   /  2013-12-29 10:11  /  1161 人查看  /  4 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 qly2046 于 2013-12-29 11:43 编辑

怎样用SQL语句设置主键,并且让种子值自加1?如何用SQL语句删除主键?

评分

参与人数 1技术分 +1 收起 理由
陈福军 + 1

查看全部评分

4 个回复

倒序浏览
alter table Student add constraint 约束的名字 primary('stuId');
//stuId是主键名字

id int primary key identity(1,1),--主键,自动+1
删除主键:

alter table 表名 drop constraint 主键名

评分

参与人数 1技术分 +1 收起 理由
陈福军 + 1

查看全部评分

回复 使用道具 举报
1. MSSQLServer: CREATE TABLE T_Bus(FNumber VARCHAR(20),FDriverName VARCHAR(20),FUsedYears INT, PRIMARY KEY(FNumber))
2. Oracle: CREATE TABLE T_Bus(FNumber VARCHAR2(20),FDriverName VARCHAR2(20),FUsedYears NUMBER(10),PRIMARY(10),PRIMARY KEY(FNumber))
3. 用标识列字段自增可以避免并发等问题,不要开发人员控制自增。用标识列的字段在insert的时候不能指定主键的值。将字段的“是标识列”设置为“是”,一个表示能有一个标识列;Guid算法是一种可以产生唯一标识的高效算法,它使用网卡MAC, 地址,纳秒级时间,芯片ID码等算出来的,这样保证每次生成的GUID永远不会重复,无论是同一个计算机上还是不同的计算机。
4. ALTER TABLE T_person DROP PRIMARY KEY;

评分

参与人数 1技术分 +1 收起 理由
陈福军 + 1

查看全部评分

回复 使用道具 举报
去除主键

            Alter table  表名  Drop Constraint PrimaryKey

            解释一下,上面的 PrimaryKey 是完整性约束条件的名字,Access数据库为主键约束默认取名PrimaryKey。当然如果主键约束被自己取了别的名字,这里也要做相应的改变了。



添加主键

            Alter table 表名 Add  Constraint  PrimaryKey  Primary  Key (主键字段名)

            解释一下,第一个PrimaryKey和上面的一样,是自己为主键完整性约束取的名字。 后面的 Primary Key (主键字段)当然就是主键约束短语了,除了Primary Key之外,还可以是Foreign key 或 Check 短语。



       具体的可以查查CONSTRAINT的用法,它用来添加完整性约束条件,并且指定该约束条件的名字(这样就方便以后删除这个约束条件)。Constrain也可以用在Create语句中,在建表时就用它来设置 PRIMARY KEY, FOREIGN KEY, CHECK 等约束。

评分

参与人数 1技术分 +1 收起 理由
陈福军 + 1

查看全部评分

回复 使用道具 举报
自动加1;
create table mytest
(
id int primary key identity(1,1),--主键,自动+1
name varchar(20) unique not null,--不允许重复,不允许为空
Age tinyint,
notetime smalldatetime default getdate()
)

insert into mytest  values ('张三',20,getdate())

insert into mytest (name,age)values ('李四',20)

评分

参与人数 1技术分 +1 收起 理由
陈福军 + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马