MySQL使用字串作為查詢條件

來源:互聯網
上載者:User

MySQL使用字串作為查詢條件

前言:今天在做MySQL的查詢時遇到一個問題,情景是這樣的,假如現在我的一張表裡面有一個欄位scode(表示商品編號),然後有一個字串儲存了多個商品編號,如“0001ME,0002BL”是一個字串,假如叫str,本來是打算使用in的方式,就是說想把str作為in的條件,如下where scode in “0001ME,0002BL”,但是沒有成功,然後就查閱MySQL的文檔,找各種函數,最後發現了instr這個函數,問題解決了,下面說一下結果過程

1.開始的時候一直在將字串str轉換為類似的in參數,如下

SELECT * FROM stocks_orderlist s where s.scode in ("0001ME","0002BL") LIMIT 10;

SELECT CONVERT(CONCAT("\'",REPLACE("0001ME,0002BL","\,","\'\,\'"),"\'"),CHAR);

SELECT * FROM stocks_orderlist s where s.scode in (CONVERT(CONCAT("\"",REPLACE("0001ME,0002BL","\,","\"\,\""),"\""),CHAR)) LIMIT 10;

雖然把str轉成了in所要的東西,但是後來想想,in的參數是一個列表集合,我及時把str轉換成了所謂的in參數的形式,但是肯定還是一個字串,於是又忙碌了半天,有點想放棄的感覺,但是回頭想想,肯定是自己沒有找到合適的辦法,於是就找到了instr函數

2.instr函數,看協助文檔的意思是找出substr在str中第一次出現問題,嘗試如下

SELECT INSTR("0001ME,0002BL","0003ME");
SELECT INSTR("0001ME,0002BL","0001ME");
SELECT INSTR("0001ME,0002BL","0002BL");
SELECT * FROM stocks_orderlist s where INSTR("0001ME,0002BL",s.scode);

總結:看起來很小的一個方法,假如不知道方法的時候卻很痛苦啊。

--------------------------------------分割線 --------------------------------------

Ubuntu 14.04下安裝MySQL

《MySQL權威指南(原書第2版)》清晰中文掃描版 PDF

Ubuntu 14.04 LTS 安裝 LNMP Nginx\PHP5 (PHP-FPM)\MySQL

Ubuntu 14.04下搭建MySQL主從伺服器

Ubuntu 12.04 LTS 構建高可用分布式 MySQL 叢集

Ubuntu 12.04下原始碼安裝MySQL5.6以及Python-MySQLdb

MySQL-5.5.38通用二進位安裝

--------------------------------------分割線 --------------------------------------

本文永久更新連結地址:

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.