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

Vin*_*arg 5 php mysql

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

mysql> 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       |                |
+--------------+-------------+------+-----+---------+----------------+
Run Code Online (Sandbox Code Playgroud)

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

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

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

Joa*_*son 8

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

  • 如果您的PHP代码中出现错误,您的数据将不会损坏.如果您只是检查数据库中的返回代码,您会立即注意到该错误.

  • 如果有人决定在数据库中手动更新数据,他们将无法错误地将字段保留为应用程序代码无法处理的NULL.