mysql set类型字段问题
问题描述
mysql设计的时候遇到一个多选项问题,搜索了一番似乎使用SET类型比较方便实现。
虽然弄明白了SET字段的存储及查询方法,但无奈能搜到的资料有限,还是有两个问题找不到头绪。
假设字段名为 flag ,SET的预设值有 A,B,C,D,E,F,G六个。
因为SET的预设值可能会增多,那么怎么能自动读出 SET的所有的预设值呢?
对于查询含有某个或者某几个值的时候可以使用:
SELECT * FROM table WHERE FIND_IN_SET(’A’,flay);SELECT * FROM table WHERE FIND_IN_SET(’A,C’,flay); 类似的进行查询。但如果想要查询哪些包含一个选项(只有A或者B或者C……),哪些包含多个选项该怎么查询呢(AC,BCD什么的)?
问题解答
回答1:这个确实比较恶心,方法有二,但都不怎么好
desc table_name set_column_name
到information_schema里面去select这两种方法的可编程性都较差。如果我来搞的话,我可能会再创建一张表来存选项列表
貌似也没啥好办法,可以用select char_length(set_column_name) from table_name;来看字符数,间接的搞定
回答2:CREATE TABLE `table` ( `id` int(11) NOT NULL AUTO_INCREMENT, `value` char(1) NOT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;
以这种结构来存储会比较灵活。
相关文章:
1. angular.js - Angularjs中点击事件传递参数 给class更换样式。2. html5 - 手机连接电脑在谷歌上调试app,出现如下的情况3. 下一个页面的三角在上面一个页面会出现,在缩放的时候会遮住文字。4. android - mac平台运行快捷键咋按5. weex - Android 原生Vue.js 使用 justify-content: flex-end; 不起作用6. javascript - swiper.js嵌套了swiper 初始设置不能向下一个滑动 结束后重新初始7. 为什么span的color非要内联样式才起作用?8. mysql 能不能创建一个 有列级函数 的联合视图?9. javascript - vue-cli热更新的问题【webpack配置】10. python - Django ManyToManyField 字段数据在 admin后台 显示不正确,这是怎么回事?

网公网安备