php – 使用应用程序代码强制执行NOT NULL是错误的吗?

前端之家收集整理的这篇文章主要介绍了php – 使用应用程序代码强制执行NOT NULL是错误的吗?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我的MySQL数据库中有大约6个表,比如

@R_301_198@> describe Quiz;
+--------------+-------------+------+-----+---------+----------------+
| Field        | Type        | Null | Key | Default | Extra          |
+--------------+-------------+------+-----+---------+----------------+
| quiz_id      | int(11)     | NO   | PRI | NULL    | auto_increment |
| name         | varchar(25) | YES  |     | NULL    |                |
| category     | varchar(20) | YES  |     | NULL    |                |
| is_published | tinyint(1)  | YES  |     | 0       |                |
| open_count   | int(11)     | YES  |     | 0       |                |
| finish_count | int(11)     | YES  |     | 0       |                |
+--------------+-------------+------+-----+---------+----------------+

在所有6个表中,在编写CREATE TABLE时…我没有对每个属性强制执行NOT NULL(如上所示),但它们应该是NOT NULL.

将使用我的PHP代码在这些表中插入行.所以在插入之前我可以确保它们都不是NULL.

我想知道,如果使用应用程序代码强制执行NOT NULL可能存在缺陷,而不是@R_301_198@?

最佳答案
除了在代码中执行它之外,我可以给你两个理由在数据库中强制执行它.

>如果您的PHP代码中出现错误,您的数据将不会损坏.如果您只是检查数据库中的返回代码,您会立即注意到该错误.
>如果有人决定在数据库中手动更新数据,他们将无法错误地将字段保留为应用程序代码无法处理的NULL.

原文链接:https://www.f2er.com/mysql/434093.html

猜你在找的MySQL相关文章