MySQL与PHP的基础与应用专题之数据完整性

目录
  • 概述
  • 数据完整性
    • 实体完整性
    • 域完整性
    • 参照完整性
    • 自定完整性
  • 唯一性
  • 外键
    • 创建主表&从表
  • 插入数据
  • 错误展示

概述

从今天开始, 小白我将带领大家一起来补充一下 数据库的知识.

数据完整性

数据完整性 (Data Integrity) 指存储在数据库 (Databse) 中的数据, 需要保证一致性和可靠性. 数据完整性可以防止数据库中存在不符合语义规定的数据和防止因错误信息的输入输出造成无效操作.

数据完整性包括:

  • 实体完整性: RDBMS 中一行代码表示一个实体. 实体完整性就是保住每一个实体都能被区别
  • 域完整性: 对列的输入的要求, 通过限制类的数据类型, 格式或值的范围来实现
  • 参照完整性: 主要是表与表之间的关系, 可以通过外键来实现
  • 自定义完整性: 借助存储过程和触发器实现

实体完整性

实体完整性 (Enity Integrity) 要求每张表都有唯一标识符, 每张表中的主键字段不能为空且不能重复.

例如:

  • id
  • 编号

域完整性

域完整性 (Domain Integrity) 是针对某一具体关系数据库约束条件. 域完整性能保证表中某些列不能输入无效的值.

例如:

  • 数据类型
  • 格式
  • 值域范围
  • 是否允许空值

举个例子, 当我们录入工资数据的时候, 工资的范围应该确保负数不会被录入.

参照完整性

参照完整性 (Referential Integrity) 指关联的两个表之间的约束. 参照完整性保证了表中每条记录外键的值必须是表中存在的.

自定完整性

自定义完整性是针对某一具体关系数据库的约束条件. 自定义完整性反映某一具体应用所涉及的数据必须满足语义要求.

唯一性

在 MySQL 中, 可以使用关键字UNIQUE实现字段的唯一性约束, 从而保证实体的完整性.

UNIQUE 的特性:

  • 使用 UNIQUE, 则表中两条数据的同一个字段不能有相同值
  • 一个表中可以有多个 UNIQUE 约束

PHP 代码实现:

<?php

# 创建连接
$conn = mysqli_connect("localhost", "root", "admin", "study");

# 查看是否连接成功
if ($conn) {
    echo "服务器连接成功!";
} else {
    echo mysqli_connect_error();
}

# SQL语句 (身份证带唯一性)
$SQL = "CREATE TABLE user_with_id (
    id INT(8) AUTO_INCREMENT PRIMARY KEY comment '主键id',
    username VARCHAR(255) NOT NULL comment '姓名',
    id_number varchar(255) UNIQUE NOT NULL comment '身份证号'
)";

# 执行SQL语句
$result = mysqli_query($conn, $SQL);

# 查看是否执行成功
if ($result) {
    echo "SQL语句执行成功!";
} else {
    echo mysqli_error($conn);
}

# 关闭连接
mysqli_close($conn);

?>

效果:

外键

外键 (Foreign KEY) 定义了表之间一致性, 用于强制参照完整性. 外键约束定义了对同一表或其他表的列的引用, 这些列具有 PRIMARY KEY 或 UNIQUE 约束.

创建主表 & 从表

<?php

# 创建连接
$conn = mysqli_connect("localhost", "root", "admin", "study");

# 查看是否连接成功
if ($conn) {
    echo "服务器连接成功!";
} else {
    echo mysqli_connect_error();
}

# SQL语句, 创建学生表
$SQL1 = "CREATE TABLE student (
    student_id INT(8) PRIMARY KEY COMMENT '学生id',
    student_name VARCHAR(255) NOT NULL COMMENT '学生姓名'
)";

# SQL语句, 创建成绩表
$SQL2 = "CREATE TABLE grade (
    id INT(8) AUTO_INCREMENT PRIMARY KEY COMMENT '主键id',
    student_id INT(8) NOT NULL COMMENT '学生id',
    course varchar(255) NOT NULL COMMENT '课程',
    grade INT(8) NOT NULL COMMENT '成绩',
    FOREIGN KEY (student_id) references student(student_id)
)";

# 执行SQL语句
$result = mysqli_query($conn, $SQL1);

# 查看是否执行成功
if ($result) {
    echo "SQL语句执行成功!";
} else {
    echo mysqli_error($conn);
}

# 执行SQL语句
$result = mysqli_query($conn, $SQL2);

# 查看是否执行成功
if ($result) {
    echo "SQL语句执行成功!";
} else {
    echo mysqli_error($conn);
}

# 关闭连接
mysqli_close($conn);

?>

效果:

插入数据

<?php

# 创建连接
$conn = mysqli_connect("localhost", "root", "admin", "study");

# 查看是否连接成功
if ($conn) {
    echo "服务器连接成功!";
} else {
    echo mysqli_connect_error();
}

# SQL语句, 向主表添加数据
$SQL1 = "INSERT INTO student
    (student_id, student_name)
    VALUES(1, '我是小白呀'),
    (2, '我是大白呀')";

# 执行SQL语句
$result = mysqli_query($conn, $SQL1);

# SQL语句, 向从表添加数据
$SQL2 = "INSERT INTO grade
    (student_id, course, grade)
    VALUES(1, '语文', 59),
    (2, '语文', 99)";

# 执行SQL语句
$result = mysqli_query($conn, $SQL2);

# 查看是否执行成功
if ($result) {
    echo "SQL语句执行成功!";
} else {
    echo mysqli_error($conn);
}

# 关闭连接
mysqli_close($conn);

?>

错误展示

<?php

# 创建连接
$conn = mysqli_connect("localhost", "root", "admin", "study");

# 查看是否连接成功
if ($conn) {
    echo "服务器连接成功!";
} else {
    echo mysqli_connect_error();
}

# SQL语句, 错误展示 (主表没有student_id=3)
$SQL = "INSERT INTO grade
    (student_id, course, grade)
    VALUES(3, '语文', 88)";

# 执行SQL语句
$result = mysqli_query($conn, $SQL);

# 查看是否执行成功
if ($result) {
    echo "SQL语句执行成功!";
} else {
    echo mysqli_error($conn);
}

# 关闭连接
mysqli_close($conn);

?>

报错:

服务器连接成功!
Fatal error: Uncaught mysqli_sql_exception: Cannot add or update a child row: a foreign key constraint fails (`study`.`grade`, CONSTRAINT `grade_ibfk_1` FOREIGN KEY (`student_id`) REFERENCES `student` (`student_id`)) in C:\Users\Windows\Desktop\数据库\外键错误.php:19
Stack trace:
#0 C:\Users\Windows\Desktop\数据库\外键错误.php(19): mysqli_query(Object(mysqli), 'INSERT INTO gra...')
#1 {main}
thrown in C:\Users\Windows\Desktop\数据库\外键错误.php on line 19
PHP Fatal error: Uncaught mysqli_sql_exception: Cannot add or update a child row: a foreign key constraint fails (`study`.`grade`, CONSTRAINT `grade_ibfk_1` FOREIGN KEY (`student_id`) REFERENCES `student` (`student_id`)) in C:\Users\Windows\Desktop\数据库\外键错误.php:19
Stack trace:
#0 C:\Users\Windows\Desktop\数据库\外键错误.php(19): mysqli_query(Object(mysqli), 'INSERT INTO gra...')
#1 {main}
thrown in C:\Users\Windows\Desktop\数据库\外键错误.php on line 19

到此这篇关于MySQL与PHP的基础与应用专题之数据完整性的文章就介绍到这了,更多相关MySQL 数据完整性内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 详解MySQL:数据完整性

    数据完整性分为:实体完整性,域完整性,参考完整性. 参考完整性: 参照完整性指的就是多表之间的设计,主要使用外键约束. 多表设计: 一对多.多对多.一对一设计 一:实体(行)完整性 实体完整性通过表的主键来实现. 使用主键来表示一条记录的唯一,且不为空 语法:primary key 主键分类: 逻辑主键:例如ID,不代表实际的业务意义,只是用来唯一标识一条记录(推荐) 业务主键:例如username,参与实际的业务逻辑. 特点:唯一,not null 自动增长:auto_increment 例如

  • 深入浅析MySQL从删库到跑路_高级(一)——数据完整性

    一.数据完整性简介 1.数据完整性简介 数据冗余是指数据库中存在一些重复的数据,数据完整性是指数据库中的数据能够正确反应实际情况. 数据完整性是指数据的可靠性和准确性,数据完整性类型有四种: A.实体完整性:实体的完整性强制表的标识符列或主键的完整性(通过唯一约束,主键约束或标识列属性). B.域完整性:限制类型(数据类型),格式(通过检查约束和规则),可能值范围(通过外键约束,检查约束,默认值定义,非空约束和规则). C.引用完整性:在删除和输入记录时,引用完整性保持表之间已定义的关系.引用完

  • MySQL与PHP的基础与应用专题之数据完整性

    目录 概述 数据完整性 实体完整性 域完整性 参照完整性 自定完整性 唯一性 外键 创建主表&从表 插入数据 错误展示 概述 从今天开始, 小白我将带领大家一起来补充一下 数据库的知识. 数据完整性 数据完整性 (Data Integrity) 指存储在数据库 (Databse) 中的数据, 需要保证一致性和可靠性. 数据完整性可以防止数据库中存在不符合语义规定的数据和防止因错误信息的输入输出造成无效操作. 数据完整性包括: 实体完整性: RDBMS 中一行代码表示一个实体. 实体完整性就是保住

  • MySQL与PHP的基础与应用专题之内置函数

    概述 从今天开始, 小白我将带领大家一起来补充一下 数据库的知识. MySQL 内置函数 MySQL 内置函数可以帮助我们更方便的处理表中的数据, 简化操作. 数学函数: 函数 描述 ABS() 取绝对值 SQRT() 取根号 MOD() 取模 FLOOR() 返回不大于的最大整数值 CELLING() 返回不小于的最小整数值 ROUND() 四舍五入 SIN() 取正弦 COS() 取余弦 字符串函数: 函数 描述 LENGTH() 取字符串长度 LOWER() 将字符串全部转为小写 UPPE

  • MySQL与PHP的基础与应用专题之数据查询

    目录 概述 条件查询 例1 例2 运算符IN 例1 例2 运算符Like 例1 例2 概述 从今天开始, 小白我将带领大家一起来补充一下 数据库的知识. 条件查询 我们可以使用关键词Where来指定条件, 用于插入, 修改删除或者查询数据. 运算符 描述 = 等于 <> 不等于 > 大于 < 小于 >= 大于等于 <= 小于等于 between and 小于等于 and 与, 表示左右两边的条件同时成立 or 或, 表示左右两边只要有一个条件成立 表记录: 例 1 从表

  • MySQL与PHP的基础与应用专题之增删改查

    概述 从今天开始, 小白我将带领大家一起来补充一下 数据库的知识. 添加数据 SQL 语句: # 插入单条数据 INSERT INTO 表名 (列名1, 列名2, -) VALUES (值1, 值2, -) # 插入多条数据 INSERT INTO 表名 (列名1, 列名2, -) VALUES (值1, 值2, -) PHP 代码实现: <?php # 创建连接 $conn = mysqli_connect("localhost", "root", &quo

  • MySQL与PHP的基础与应用专题之创建数据库表

    概述 从今天开始, 小白我将带领大家一起来补充一下 数据库的知识. MySQL 安装 下载地址: https://dev.mysql.com/downloads/windows/installer/ MySQL 命令行 打开 MySQL 命令行: 输入密码: 查看所有数据库: 数据库创建 SQL语句 CREATE DATABASE 数据名称 PHP 代码实现: <?php # 创建链接 $conn = mysqli_connect("localhost", "root&

  • MySQL与PHP的基础与应用专题之数据查询语句

    目录 概述 ORDERBY 例1 例2 LIMIT 例1 例2 GROUPBY 例1 例2 HAVING 例1 例2 GROUP_CONCAT 例1 例2 DISTINCT 例1 例2 概述 从今天开始, 小白我将带领大家一起来补充一下 数据库的知识. ORDER BY 在 SQL 中, 我们可以使用 ORDER BY 对查询结果进行一列或多列排序. SQL 语句: SELECT 列名1, 列名2 FROM 表名1, 表名2 ORDER BY 列名, 列名[ASC|DESC] 注意: ASC 表

  • MySQL与PHP的基础与应用专题之表连接

    概述 从今天开始, 小白我将带领大家一起来补充一下 数据库的知识. 表连接 表连接 (JOIN) 是在多个表之间通过连接条件. 使表之间发生关联, 进而能从多个表之间获取数据. 表连接语法: SELECT 表名1.列名, 表名2.列名 FROM 表1, 表2 WHERE 条件 表连接的几种方式: 内连接: join 或者 inner join 自连接: 同一张表内的连接 外连接: 左外连接, left join 右外连接, right join 全外连接, full join 数据 (table

  • MySQL与PHP的基础与应用专题之自连接

    概述 从今天开始, 小白我将带领大家一起来补充一下 数据库的知识. 自连接 自连接 (Self Join) 是一种特殊的表连接. 自连接指相互连接的表在物理上同为一张表, 但是逻辑上是多张表. 自连接通常用于表中的数据有层次结构, 如区域表, 菜单表, 商品分类表等. 格式: SELECT A.列名, B.列名 FROM 表A, 表B WHERE A.列名 = B.列名 数据: 例子: (过滤城市) <?php $conn = mysqli_connect("localhost"

  • MySQL与PHP的基础与应用专题之数据控制

    目录 概述 数据控制语言 MySQL权限体系 用户管理 创建用户 删除用户 修改密码 权限管理 查看权限 用户授权 撤销授权 刷新权限 注意事项 概述 从今天开始, 小白我将带领大家一起来补充一下 数据库的知识. 数据控制语言 数据控制语言 (Data Control Language) 是用来设置或更改数据库用户或角色权限的语句. 层级 描述 全局层级 适用于一个给定服务器中的所有数据库. 这些权限存储在 mysql.user 表中 数据库层级 适用于一个给定数据库中的所有目标. 这些权限存储

  • MySQL与PHP的基础与应用专题之索引

    概述 从今天开始, 小白我将带领大家一起来补充一下 数据库的知识. 索引 索引 (Index) 是一种特殊的数据结构, 类似于图书的目录. 索引能够极大的提升数据库的查询效率. 如果没有索引, 在查询数据时必须扫描表中的说有记录才能找出符合条件的记录, 这种全表扫描的查询效率非常低. 索引的种类 描述 普通索引 最基本的索引, 没有任何限制, 仅加速查询 唯一索引 索引列的值必须唯一, 但允许有空值 主键索引 一种特殊的唯一索引, 不允许有空值 复合索引 两个或多个列上的索引被称作符合索引 全文

随机推荐