用户表:
ID Name
1 usr1
2 usr2
3 usr3
上表中,ID为主键。我的要求是在将数据插入表中时,我只想指定
名字像INSERT INTO user VALUES('usr4')
。执行查询后,有没有办法自动为“usr4”创建ID?
我尝试使用串行数据类型。为此,我们还必须指定关键字default,例如INSERT INTO user VALUES(default,'usr4')
。那么,有什么办法可以做到这一点INSERT INTO user VALUES('usr4')
。注意:ID 应该是唯一的。
使用内置数据类型serial
or bigserial
.
create table users (
id serial primary key,
name varchar(100) not null unique -- ?
);
命名列;省略serial 或bigserial 列的名称。
insert into users (name) values ('usr4');
一般规则是您必须为 INSERT 语句中使用的每一列提供一个值。如果不指定列名,则必须为每一列提供一个值,包括“Id”,并且必须按照列在表中出现的顺序提供它们。
如果指定列名,则可以省略具有默认值的列和可为空的列,并且可以按任意顺序放置列名。值的顺序必须与您指定的列名称的顺序匹配。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)