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. MYSQL 根據兩個字段值查詢 但兩個值的位置可能是互換的,這個怎么查?2. 求救一下,用新版的phpstudy,數據庫過段時間會消失是什么情況?3. mysql replace 死鎖4. mysql - C#連接數據庫時一直這一句出問題int i = cmd.ExecuteNonQuery();5. javascript - 微信網頁開發從菜單進入頁面后,按返回鍵沒有關閉瀏覽器而是刷新當前頁面,求解決?6. extra沒有加載出來7. android - 安卓做前端,PHP做后臺服務器 有什么需要注意的?8. python - 數據與循環次數對應不上9. php傳對應的id值為什么傳不了啊有木有大神會的看我下方截圖10. mysql - ubuntu開啟3306端口失敗,有什么辦法可以解決?
