mysql完整新约束

php中文网
发布: 2016-06-07 15:46:54
原创
1701人浏览过

主键:primary key 可以指定一列或多列为主键,主键在表中的总是唯一的,且构成主键的一部分的列的不允许为空。 惟一性原则:表中不同的行在主键上有唯一的。有必要区分primary key和super key。 unique唯一键键 一个表只能有一个主键,但可以有多个唯一键。

主键:primary key
可以指定一列或多列为主键,主键在表中的值总是唯一的,且构成主键的一部分的列的值不允许为空。
惟一性原则:表中不同的行在主键上有唯一的值。有必要区分primary key和super key。
unique唯一键键

一个表只能有一个主键,但可以有多个唯一键。唯一键可以为空值。

替代键:unique

一个表只能有一个主键,但可以有多个替代键。替代键可以为空值。
它可以是数据表内不作为主键的其他任何列。在替代键列内不允许出现数据重复的现象。

外键foreign key

如果存储在表A中的数据也必须存在表B中,且两个表中的数据必须一致,这种类型关系称为参照完整新约束。

参照动作:

定义外键时可以添加更新时的参照动作:当一个表执行一种动作时参照表也执行相应的动作。

参照动作有:uodata和delete
参照表的响应动作有:
① RESTRICT(限制外表中的外键改动,默认值)
② CASCADE(跟随外键改动)
③ SET NULL(设空值)
④ SET DEFAULT(设默认值)

⑤ NO ACTION(无动作,默认的)

HMCSS通用企业网站系统1.0
HMCSS通用企业网站系统1.0

HMCSS是由河马工作室全新开发的通用的企业网站系统,是PHP+MYSQL的架构,采用DIV+CSS的方式进行网页布局,网站的功能包括有:企业简介,图片展示幻灯,产品图片滚动,企业荣誉,实力展示,产品分类及展示,网上招聘,在线留言,联系我们,在线地图等内容,另外还带有完整的管理后台,如网站SEO优化关键词等都可以自由设定。 HMCSS目前发布的是1.0版本,就是上述的这些内容。后面我们还要加上产品

HMCSS通用企业网站系统1.0 0
查看详情 HMCSS通用企业网站系统1.0
check完整性约束
check保证该列的值绝对符合条件。不允许不符合check条件的任何插入和更新操作。

例如:

create table student(
stu_id          int not null primary key,
stu_name        varchar(5) not null,
stu_tel         int(5) unique,
stu_score       int(2) check (stu_score>=60)
);
登录后复制
这个表的主键是stu_id,其中stu_name不允许为空值,所有的行中stu_tel不能有重复,且所有学生的成绩stu_score必须大于60分。

例:参照完整性约束。
create table student1(
id		int not null primary key,
stu_address	varchar(5),
foreign key(id) references student(stu_id)
on update cascade
on delete restrict
);
登录后复制

原始数据:
mysql> select * from student;
+--------+----------+---------+-----------+
| stu_id | stu_name | stu_tel | stu_score |
+--------+----------+---------+-----------+
|      1 | a        |     150 |        60 |
+--------+----------+---------+-----------+
1 row in set (0.00 sec)
登录后复制
mysql> select * from student1;
+----+-------------+
| id | stu_address |
+----+-------------+
|  1 | china       |
+----+-------------+
1 row in set (0.00 sec)
登录后复制

更新student数据

mysql> update student set stu_id=3 where stu_id=1;
Query OK, 1 row affected (0.09 sec)
Rows matched: 1  Changed: 1  Warnings: 0
登录后复制

表student数据被更改了:
mysql> select * from student;
+--------+----------+---------+-----------+
| stu_id | stu_name | stu_tel | stu_score |
+--------+----------+---------+-----------+
|      3 | a        |     150 |        60 |
+--------+----------+---------+-----------+
1 row in set (0.00 sec)
登录后复制

表student1数据跟着被更改:
mysql> select * from student1;
+----+-------------+
| id | stu_address |
+----+-------------+
|  3 | china       |
+----+-------------+
1 row in set (0.00 sec)
登录后复制
此时不能删除delete表student中stu_id=3的数据,因为参照动作on delete restrict;


相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号