设立MySQL数据表主键

设置MySQL数据表主键

?

设置MySQL数据表主键:

? ? 使用“primary key”关键字创建主键数据列。被设置为主键列不允许出现重复的值,很多情况下与“auto_increment”递增数字相结合。如下SQL语句所示:

<pre>

  1. Mysql>create?table?books(bookid?int(11)?NOT?NULL?AUTO_INCREMENT?PRIMARY?KEY,bookname?varchar(50));?
  2. Mysql>insert?into?books(bookname)?values(“book1”),(“book2”),(“book3”);?
  3. Mysql>select?*?from?books;?

</pre>

??? 若要修改列主键或类型,请参考 ALTER TABLE 语句。


设置MySQL数据表外键

??? 外键是设置当前表中的某一列与别一数据表中的主键列关联。主要目的是控制与外键表中的数据,保持数据一致性,完整性,也就是说:当前表中这一列的数据必须是关联外键列中的某一数据,而且相关联的两个数据列的类型必须相同;当关联外键列某一数据修改或删除时,将触当前表的某一项相应操作。可解发以下事件以及参数:


触发事件:on delete和on update


可设参数:cascade(跟随外键改动);

restrict(限制外表中的外键改动);

set Null(设空值);

set Default(设默认值);

no action [默认]

??? 设置关联的语句由[指定主键关键字:foreign key(列名)]和[引用外键关键字: references <外键表名>(外键列名)]组成。例如创建一个关于books的购物车数据表“gbooks”,其中“gbookid”与books表中的“bookid”创建外键关联。

<pre>

  1. Mysql>create?table?gbooks(gid?int(11)?not?null?auto_increment?primary?key,gbookid?int(11),goodsum?int(4),foreign?key(gbookid)?references?books(bookid)?on?delete?cascade?on?update?cascade);?

</pre>

??? 删除外键:

??? 首先,使用SHOW CREATE TABLE语句查看创建表描述。其中“CONSTRAINT”关键字后面有一个引号括起来的名称,它就是这个表外键的代表,是在创建外键时自动生成的名称,当然在创建的过程中可以直接用“CONSTRAINT”关键字自定义名称。其查看的完整语句如下:

<pre>

  1. Mysql>show?create?table?gbooks;?

</pre>

??? 这里代表外键的名称是“gbooks_ibfk_1”,目标找到了,再使用ALTER语句进行删除。

<pre>

  1. Mysql>ALTER?TABLE?gbooks?

免责声明: 本文仅代表作者个人观点,与无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。

相关资料

设立MySQL数据表主键

相关文章:

你感兴趣的文章:

标签云: