如下所示:
LOCATE(substr,str)
返回子串substr在字符串str第一個出現(xiàn)的位置,如果substr不是在str里面,返回0.
mysql> select LOCATE('bar', 'foobarbar'); -> 4 mysql> select LOCATE('xbar', 'foobar'); -> 0
補充:mysql中類似indexOf的方法LOCATE()
LOCATE(substr, str), LOCATE(substr, str, pos)
第一個語法返回substr在字符串str的第一個出現(xiàn)的位置。
第二個語法返回字符串substr在字符串str,從pos處開始的第一次出現(xiàn)的位置。如果substr不在str中,則返回值為0
問題:
有多個科目,一個科目下多個多選題,每個題四種答案(ABCD),統(tǒng)計每個科目的每道題選擇ABCD的個數(shù)
SELECT
sum(
CASE
WHEN (LOCATE('A', 選項名) > 0) THEN
1
ELSE
0
END
) AS A,
sum(
CASE
WHEN (LOCATE('B', 選項名) > 0) THEN
1
ELSE
0
END
) AS B,
sum(
CASE
WHEN (LOCATE('C', 選項名) > 0) THEN
1
ELSE
0
END
) AS C,
sum(
CASE
WHEN (LOCATE('D', 選項名) > 0) THEN
1
ELSE
0
END
) AS D
FROM
表名
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- MySQL null的一些易錯點
- MySQL SHOW STATUS語句的使用
- MySQL查詢緩存的小知識
- Mysql技術(shù)內(nèi)幕之InnoDB鎖的深入講解
- MySQL 主從同步,事務(wù)回滾的實現(xiàn)原理
- MySQL 有關(guān)MHA搭建與切換的幾個錯誤log匯總