mysql set类型字段问题
PHP中文网
PHP中文网 2017-04-17 15:23:20
[MySQL讨论组]

mysql设计的时候遇到一个多选项问题,搜索了一番似乎使用SET类型比较方便实现。

虽然弄明白了SET字段的存储及查询方法,但无奈能搜到的资料有限,还是有两个问题找不到头绪。

假设字段名为 flag ,SET的预设值有 A,B,C,D,E,F,G六个。

  1. 因为SET的预设值可能会增多,那么怎么能自动读出 SET的所有的预设值呢?

  2. 对于查询含有某个或者某几个值的时候可以使用:

    SELECT * FROM table WHERE FIND_IN_SET('A',flay);
    SELECT * FROM table WHERE FIND_IN_SET('A,C',flay); 类似的进行查询。
    
    但如果想要查询哪些包含一个选项(只有A或者B或者C……),哪些包含多个选项该怎么查询呢(AC,BCD什么的)?
PHP中文网
PHP中文网

认证0级讲师

全部回复(2)
怪我咯
  1. 这个确实比较恶心,方法有二,但都不怎么好

    • desc table_name set_column_name

    • information_schema里面去select
      这两种方法的可编程性都较差。如果我来搞的话,我可能会再创建一张表来存选项列表

  2. 貌似也没啥好办法,可以用select char_length(set_column_name) from table_name;来看字符数,间接的搞定

PHP中文网
CREATE TABLE `table` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `value` char(1) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

以这种结构来存储会比较灵活。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号