这是我工作遇到的问题,现在自己设计一个简化的类似场景,现实中这样的数据表设计可能有很多不合理的地方。
首先看表结构:
+--------+--------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+--------------+------+-----+---------+-------+
| id | varchar(38) | NO | PRI | NULL | |
| name | varchar(255) | YES | | NULL | |
| course | varchar(300) | YES | | NULL | |
+--------+--------------+------+-----+---------+-------+
这里只是记录学生的ID,名字,还有选课的科目,科目有很多,在没有关联表的情况下,这么多科目只保存在一个字段中,用逗号隔开。
再看一些数据:
+--------------------------------------+--------+--------------------------------+
| id | name | course |
+--------------------------------------+--------+--------------------------------+
| 32268995-f33d-11e4-a31d-089e0140e076 | 张三 | Math,English,Chinese |
| 3d670ef2-f33d-11e4-a31d-089e0140e076 | 李四 | Math,English,Chinese,Algorithm |
| 475d51a6-f33d-11e4-a31d-089e0140e076 | 李五 | Math,English,Algorithm |
| 547fdea0-f33d-11e4-a31d-089e0140e076 | 王小明 | Math,English,Japanese |
| 656a247a-f33d-11e4-a31d-089e0140e076 | 曹达华 | Chesses |
+--------------------------------------+--------+--------------------------------+
那么如何查找到选择了Math课程的学生?