MySQL性别表字段

Sar*_*med 2 mysql

如果我想在表格中创建性别字段,如何确保我的数据库不接受除"M"或"F"之外的任何值?

 $sqlCommand = "CREATE TABLE members (
             id int(11) NOT NULL auto_increment,
             ... 
             ...
             ...
             ...
             gender
             )";
Run Code Online (Sandbox Code Playgroud)

谢谢

ype*_*eᵀᴹ 10

没有触发器,没有枚举或其他deamonic活动.

您可以使用a FOREIGN KEY到只有2行的引用表:

CREATE TABLE Gender_Ref 
(   gender CHAR(1) NOT NULL,
    PRIMARY KEY (gender)
) ENGINE = InnoDB ;

INSERT INTO Gender_Ref (gender)
    VALUES
        ('F'), ('M')  ;

CREATE TABLE members 
(   id int(11) NOT NULL auto_increment,
     ... 
     ...
    gender CHAR(1) NOT NULL,
    PRIMARY KEY (id),
    FOREIGN KEY gender
        REFERENCES Gender_Ref (gender)
) ENGINE = InnoDB ;
Run Code Online (Sandbox Code Playgroud)

"锁定"引用表也是一个很好的建议,因此应用程序代码只具有读访问权限.(这通常适用于大多数参考表,如果你有一个Admin应用程序,你当然也可以为它提供写入访问权限).


Rol*_*man 5

如评论中指出的那样,您可以这样使用ENUM:

gender ENUM('F','M') NOT NULL
Run Code Online (Sandbox Code Playgroud)

但是,你必须要小心,因为它仍然会接受空字符串(虽然你会得到一个警告):

mysql> create table t (g enum('M','F') not null);
Query OK, 0 rows affected (0.12 sec)

mysql> insert into t values ('M');
Query OK, 1 row affected (0.00 sec)

mysql> insert into t values ('');
Query OK, 1 row affected, 1 warning (0.00 sec)

mysql> show warnings;
+---------+------+----------------------------------------+
| Level   | Code | Message                                |
+---------+------+----------------------------------------+
| Warning | 1265 | Data truncated for column 'g' at row 1 |
+---------+------+----------------------------------------+
1 row in set (0.00 sec)

mysql> select * from t;
+---+
| g |
+---+
| M |
|   |
+---+
2 rows in set (0.00 sec)
Run Code Online (Sandbox Code Playgroud)

为确保不会发生这种情况,您可以考虑将sql_mode(http://dev.mysql.com/doc/refman/5.5/en/server-sql-mode.html)设置为更具限制性的值:

mysql> set sql_mode = strict_all_tables;
Query OK, 0 rows affected (0.00 sec)

mysql> insert into t values ('');
ERROR 1265 (01000): Data truncated for column 'g' at row 1
Run Code Online (Sandbox Code Playgroud)

但是,您应该调查这是否适合您.许多现有的应用程序(wordpress等)不喜欢搞乱sql_mode,所以如果你的代码是这些系统的插件,你想避免设置它.

您可以选择设置sql_mode服务器范围或会话范围; 第一个选项会更强大,但需要以非默认方式配置MySQL,并且可能会影响其他应用程序.在打开连接后立即在会话级别进行设置应该可以正常工作,但会使应用程序代码混乱.选择你的毒药.

ypercube建议使用外键也很好,并且比ENUM更容易移植到其他RDBMS.但是,您必须确保您的表都由InnoDB引擎管理.这越来越成为标准,所以这不是一个糟糕的选择.

(如果你真的很偏执,你应该确保应用程序只有对性别参考表的读访问权限)