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