十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
-
创新互联是专业的安多网站建设公司,安多接单;提供成都网站制作、网站设计,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行安多网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!
-为什么会有两个主键
主键的概念就只能允许一个表一个主键吧-
-,即使你能够找到两个字段都可以做唯一标识,那也只可能有一个主键吧!
有没有表结构啊,然后能否说下你到底拿两个主键来干什么····
1楼的还是1个主键啊,只是把KEY1和KEY2两个条件作为主键而已呀~
再看看别人怎么说的。
create table 表名
(
)
一个表中只能有一个主键约束和唯一约束,但一个主键约束可以在多列上.
工具/原料
电脑 MySQL
方法/步骤
设置主键:
1、通过终端进入到mysql命令行工具。
2、通过use关键字进行到目标数据库里。
3、如原表已有主键,先把原来的主键删除掉,通过DROPPRIMARYKEY命令:ALTERTABLE`jingyan`DROPPRIMARYKEY;。
4、主键已经没有了。
5、通过命令:ADDPRIMARYKEY来添加ALTERTABLE`jingyan`ADDPRIMARYKEY(`id`)。
6、输入后按下回车键即可看到queryok执行成功的字符。
7、回到数据库的可视化工具,即可显示现在的表在id列上添加了主键了。
设置外键:
1、创建好主从表。
2、选择主表,点击设计表,进入到表设计界面。
3、点击外键,进入到外键设置界面。
4、先设置外键名称和选择主表的外键字段。
5、然后在设置外键字段对应从表的数据库、表名和字。
6、点击保存就完成外键设置了。
一个表不能有2个主键,因为主键代表数据的物理组织形式,所以不能存在2个。但是允许用多个字段联合组成主键。
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);
直接在表里就可以建,把两列都选中,先设置都不为空,然后右建设为主建.如果想要查看建多主键的语句,可以把表手动建完后,再查看建表语句.