mysql主外键怎么建立 mysql主键外键怎么用

mysql 如何建立外键

详细说明可以百度搜我的博客: mysql foreign外键详细使用方法和使用事项_2018_lcf

成都创新互联主营志丹网站建设的网络公司,主营网站建设方案,app开发定制,志丹h5小程序制作搭建,志丹网站营销推广欢迎志丹等地区企业咨询

---------下面是使用方法

使用外键的前提:

1. 表储存引擎必须是innodb,否则创建的外键无约束效果。

2. 外键的列类型必须与父表的主键类型完全一致。

3. 外键的名字不能重复(一般使用。

建外键表两种方式(创建表时关联/添加外键)

1) 第一种方式创建表时加外键使用实例:

mysql create table A( name char(12), id int(8) ,index(id))engine=innodb; //先建立A表,

mysql create table B( //建立B表,同时做外键

- id int(9),

- money int(9),

- index(id),

- foreign key(id) references A (id) //这个是必加项,foreign key(B表要关联的字段),references A表名 (对应字段)

- on delete cascade on update cascade //这里是可选项的,只加一项或都不加都可以的,看需求.

- )engine=innodb; //这个必须是innodb类型,并且和A表的一致

第二方式在已有的表上做和A表关联的外键(最好是新建好没有记录的,不然会因为记录对不上而创建不成功)

mysql create table C( //这里先创建一个空表C

- id int(7),

- money int(5),

- index(id)

- )engine=innodb;

mysql alter table Cadd constraint abc //在C表上添加和表A关联的外键,constraint 外键名(自己任意取)

- foreign key(id) references A(id) //和创建时一样的输入

- on delete cascade on update cascade; //一样是可选项,这行不写也可以通过.

注: @以上的cascade是上面介强的四种模式之一,是可以替换成其它模式的,如写成on update set null

@还可以同时做两个外键,如写成foreign key(id,money) references A(id,money) 即可

@两张表关联字段名可以取不一样名字,但类型必须一致

MySQL之主键、外键、连接

设置主键的思路:业务字段做主键、自增字典做主键、手动赋值字段做主键。

多表查询:分散在多个不同的表里的数据查询出来的操作。

外键:从表中用来引用主表中数据的那个公共字段。

连接有2种类型的连接:内连接(inner join)和外连接(outer join)

内连接:查询结果只返回符合连接条件的记录。

外连接:查询结果返回某一个表中的所有记录,以及另一个表中满足连接条件的记录。

其中左连接:left join,返回左表中的所有记录,以及右表中符合连接条件的记录。

右连接:right join,返回右表中的所有记录,以及左表中符合连接条件的记录。

在MySQL中如何设置主键和外键

添加主键~

ALTER

TABLE

table_name

ADD

CONSTRAINT

pk_name

PRIMARY

KEY(列名);

添加外键~

ALTER

TABLE

table_name

ADD

CONSTRAION

pk_name

FOREIGN

KEY(列名)

REFERENCES

table_name(列名);

基础语法~其他条件自行添加

mysql怎么定义外键

定义外键的方法和详细的操作步骤如下:

1、第一步,创建一个主从表,如下图所示,然后进入下一步。

2、其次,完成上述步骤后,选择主表,然后单击设计表进入表设计界面,如下图所示,然后进入下一步。

3、接着,完成上述步骤后,单击外键进入外键的设置界面,如下图所示,然后进入下一步。

4、然后,完成上述步骤后,设置外键名称,然后选择主表的外键字段,如下图所示,然后进入下一步。

5、随后,完成上述步骤后,设置与数据库,表名称和从属表的单词相对应的外键字段,如下图所示,然后进入下一步。

6、最后,完成上述步骤后,单击保存即可,如下图所示。这样,问题就解决了。


文章名称:mysql主外键怎么建立 mysql主键外键怎么用
本文网址:http://pwwzsj.com/article/dosipco.html