重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这里的PRIMARYKEY是主键,KEY不是主键,就是普通索引。再增加一个也是可以的。
让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:域名注册、虚拟主机、营销软件、网站建设、邢台县网站维护、网站推广。
mysql的key和index有点相近是索引约束,单独的key和其它关键词结合的key(primarykey)实际表示的意义是不同。
扩展资料
primarykey和key的区别:
primarykey是主键,一般为自动增长并且是非空、int类型的,主要用来保证数据的唯一性;
Key是索引约束,对表中字段进行约束索引的,都是通过primaryforeignunique等创建的。
举例说明:
CREATETABLEwh_logrecord(
logrecord_idint(11)NOTNULLauto_increment,
user_namevarchar(100)defaultNULL,
operation_timedatetimedefaultNULL,
logrecord_operationvarchar(100)defaultNULL,
PRIMARYKEY(logrecord_id),
KEYwh_logrecord_user_name(user_name)
)
解析:KEYwh_logrecord_user_name(user_name),本表的user_name字段与wh_logrecord_user_name表user_name字段建立外键,括号外是建立外键的对应表,括号内是对应字段。
create table 表名
(
)
一个表中只能有一个主键约束和唯一约束,但一个主键约束可以在多列上.
courseidint,
scoreint,primarykey(studentno) );
②修改时:ALTER TABLE table_name ADD CONSTRAINT pk_name PRIMARY KEY(列名);
前提是原先没有设置主键。
2.外键语法①创建时:createtablesc (studentnoint,
courseidint,
scoreint,foreignkey(courseid) );②修改时:ALTER TABLE news_info[子表名] ADD CONSTRAINT FK_news_info_news_type[约束名] FOREIGN KEY (info_id)[子表列] REFERENCES news_type[主表名] (id)[主表列] ;
3.使用组合主键
如果一列不能唯一区分一个表里的记录时,可以考虑多个列组合起来达到区分表记录的唯一性,形式①创建时:createtablesc (studentnoint,
courseidint,
scoreint,primarykey(studentno,courseid) );
②修改时:alter table tb_name add primary key (字段1,字段2,字段3);