According to the answer situation of the employee's answer activity, the error rate of the questions is counted. The database has the employee's answer sheet employee's question
employee_question
And standard answer sheet
question_info
, you can see that both the standard answer and the answer situation are strings separated by commas
data:image/s3,"s3://crabby-images/72804/7280480e8cf22e874625d1f59866589f6d3c0511" alt=""
employee_question
data:image/s3,"s3://crabby-images/ccc7d/ccc7d5d57675394b6c096d57d9368341070b4130" alt=""
question_info
SELECT s.id + 1 as 'Title number', COUNT(*) as 'Participation times', COUNT(if(e.answer != s.answer, 1, null)) as 'Error times', CONCAT(ROUND(COUNT(if(e.answer != s.answer, 1, null))/COUNT(*)*100,1),'','%') as 'error rate' FROM ( SELECT help_topic_id as id, SUBSTRING_INDEX(SUBSTRING_INDEX(answer,',',help_topic_id+1),',',-1) AS answer FROM mysql.help_topic,(SELECT * FROM employee_question GROUP BY employee_num,question_id) a WHERE help_topic_id < LENGTH(answer) - LENGTH(REPLACE(answer, ',', ''))+1 AND question_id = 2 )e LEFT JOIN ( SELECT help_topic_id as id, SUBSTRING_INDEX(SUBSTRING_INDEX(standard_answer,',',help_topic_id+1),',',-1) AS answer FROM mysql.help_topic,question_info WHERE help_topic_id < LENGTH(standard_answer) - LENGTH(REPLACE(standard_answer, ',', ''))+1 AND id = 2 )s ON e.id = s.id GROUP BY s.id ORDER BY ROUND(COUNT(if(e.answer != s.answer, 1, null))/COUNT(*)*100,1) DESC
Effect achieved
data:image/s3,"s3://crabby-images/cc155/cc155bd024586d74b06a0e8f5435d0a5d7b741dd" alt=""
results of enforcement
Here is a summary of the knowledge points involved in sql
LENGTH(str)
parameter | explain |
---|---|
str | Character string |
REPLACE(str,substring,replacement)
parameter | explain |
---|---|
str | Character string |
substring | Characters specified in search string |
replacement | Replaced characters |
LENGTH(`standard_answer`)-LENGTH(REPLACE(`standard_answer`, ',', ''))+1 #Count the number of questions
SUBSTRING_INDEX(str,delim,count)
parameter | explain |
---|---|
str | Character string |
delim | Segmentation symbol |
count | Number of intercepting separators, with the symbol intercepting from the back to the front |
SUBSTRING_INDEX('www.baidu.com', '.', 2) //www.baidu SUBSTRING_INDEX('www.baidu.com', '.', -1) //com
Help topic is a self-contained table with increasing fields in mysql database, which can reach 585 at most. With the help topic ID of this table, the answer of cyclic interception is realized, and the number of cyclic interception is limited by where condition
SELECT help_topic_id as id, SUBSTRING_INDEX(SUBSTRING_INDEX(standard_answer,',',help_topic_id+1),',',-1) AS answer FROM mysql.help_topic,question_info WHERE help_topic_id < LENGTH(standard_answer) - LENGTH(REPLACE(standard_answer, ',', ''))+1 AND id = 2
data:image/s3,"s3://crabby-images/2867f/2867fbf6569d3f68ca209a0ee962a65fe3a40b1b" alt=""
Split standard answer