文章詳情頁
find_in_set - 請教 mysql查詢
瀏覽:123日期:2022-06-20 18:36:16
問題描述
mysql 表中字段option_tag 存儲的值格式(分號)為: 4:539;8:543;4:545;8:549通過 find_in_set() 可以查找到以逗號分隔的字符串。以分號分隔的 字符串 有什么函數直接能查詢到 option 含有 539的所有值?
問題解答
回答1:sql語句:SELECT * FROM tableWHERE locate(’:539;’, CONCAT(options_tag, ’;’)) > 0
用like的方法邏輯上不嚴謹,如4:2539這種情況也會被like匹配,但不是想要的結果。
從設計方案考慮,如果是復雜的數據類型,建議存成json格式,mysql高版本直接內置了json解析、查詢功能。
回答2:通過like或者正則即可。但是不建議將邏輯放在mysql中,造成數據庫引擎壓力過大,而且極度不安全。正確的做法應該是把整個字段的值取出來,作為字符串然后用語言比如php python nodejs之類的處理。
回答3:SELECT * FROM tableWHERE options_tag LIKE ’%539%’;
正如@小蟲哥哥 所說,這是設計缺陷,這看起來是一個一對多或者多對多的關系,不應該用一個字段存起來,不僅查詢效率低(在SQL里對字段進行運算有可能會使該字段的索引無法被使用),而且查詢起來也不靈活。
回答4:like 匹配
回答5:like :539
回答6:我說這是設計缺陷有人贊同嗎
回答7:like相似匹配
回答8:模糊查詢研究下
相關文章:
1. python - 能通過CAN控制一部普通的家用轎車嗎?2. centos7 編譯安裝 Python 3.5.1 失敗3. mysql - 分庫分表、分區、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處4. python - beautifulsoup獲取網頁內容的問題5. mysql優化 - 關于mysql分區6. c++ - 請問MySQL_Connection::isReadOnly 怎么解決?7. css3 - 微信前端頁面遇到的transition過渡動畫的bug8. 人工智能 - python 機器學習 醫療數據 怎么學9. Python爬蟲如何爬取span和span中間的內容并分別存入字典里?10. python - Django內使用filter過濾時間,只認年份不認月份是怎么回事?
排行榜
