This is the original table like
data:image/s3,"s3://crabby-images/da6ee/da6ee7f4b9da2011c5e92c381959dac6aeda544f" alt=""
Expected effect is like that of
data:image/s3,"s3://crabby-images/27feb/27feb60e142214a0afbacd35a488e3697b515939" alt=""
But I actually is this way to find the
data:image/s3,"s3://crabby-images/fd569/fd569de0854b8aca80d67e59a5f6ebaa9286192d" alt=""
This is built predicate sentence: SET NAMES utf8mb4;
The SET FOREIGN_KEY_CHECKS=0;
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
- Table structure for t_user
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
DROP TABLE IF the EXISTS ` t_user `;
The CREATE TABLE ` t_user ` (
` id ` int (11), NOT NULL AUTO_INCREMENT,
` name ` varchar (20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
` age ` int (5) the NULL DEFAULT NULL,
` hobby ` varchar (20) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
PRIMARY KEY (` id `) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT CHARACTER SET==4 utf8 COLLATE=utf8_general_ci ROW_FORMAT=Compact;
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
- Records of t_user
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
INSERT INTO ` t_user ` VALUES (1, 'zhang SAN, 18,' read ');
INSERT INTO ` t_user ` VALUES (2, 'zhang SAN, 18,' game ');
INSERT INTO ` t_user ` VALUES (3, 'zhang SAN, 18,' writing code ');
INSERT INTO ` t_user ` VALUES (4, 'Cathy', 20, 'eat');
INSERT INTO ` t_user ` VALUES (5, 'Cathy', 20, 'sleep');
INSERT INTO ` t_user ` VALUES (6, 'Cathy', 20, 'play doug);
This is the query: set @ name='Cathy';
SELECT
GROUP_CONCAT (DISTINCT
CONCAT (
'(select hobby from (select @ rownum:=@ + 1 AS rownum, rownum t_user. *
The FROM (SELECT @ rownum:=0) r, t_user where name="' @ the name, '") t where t.r ownum='
T.r ownum,
') AS ',
CONCAT (' hobby 'rownum)
)
) INTO @ SQL
The FROM (SELECT @ rownum:=@ + 1 AS rownum, rownum t_user. *
The FROM (SELECT @ rownum:=0) r, t_user where name=@ name) t;
SET @ SQL=CONCAT (' the select distinct name, age, '@ SQL,' the from t_user where name="' @ the name, '"');
PREPARE STMT FROM @ SQL;
The EXECUTE STMT.
DEALLOCATE PREPARE STMT.
CodePudding user response:
Interestingly I split the SQL statements;data:image/s3,"s3://crabby-images/33dae/33dae6262cd5e45b4a62bd783ac6fa8cf8e9009a" alt=""
data:image/s3,"s3://crabby-images/fc599/fc59974414f783dddcf0925ca3f61693ebbf46f3" alt=""
data:image/s3,"s3://crabby-images/5e0fa/5e0fa39d976da5bf4bf7a68bef81ea390408e544" alt=""
But once combined to the second three data can't the
data:image/s3,"s3://crabby-images/006cd/006cd337d0653acbbf048d60be290ade5adf365e" alt=""
Ask bosses for what he did that is associated with mysql version,
CodePudding user response:
Each user variable @ rownum new name, don't repeat the use of a variable