Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/variables/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
MySQL PDO-使用变量完成请求的最佳方式是什么?_Mysql_Variables_Pdo_Sequence - Fatal编程技术网

MySQL PDO-使用变量完成请求的最佳方式是什么?

MySQL PDO-使用变量完成请求的最佳方式是什么?,mysql,variables,pdo,sequence,Mysql,Variables,Pdo,Sequence,用MySQL PDO完成这样一个请求的最佳方式是什么 它在MySQL工作台中运行良好 SET @sosa = 817595147; SET @sequence = (SELECT REPLACE(seq, '-', ',') FROM lignee WHERE sosa = @sosa); SELECT fullname_id, fullname FROM fullname WHERE FIND_IN_SET (fullname_id , @sequence) ORDER BY FIND_IN

用MySQL PDO完成这样一个请求的最佳方式是什么

它在MySQL工作台中运行良好

SET @sosa = 817595147;
SET @sequence = (SELECT REPLACE(seq, '-', ',') FROM lignee WHERE sosa = @sosa);

SELECT fullname_id, fullname
FROM fullname
WHERE FIND_IN_SET (fullname_id , @sequence)
ORDER BY FIND_IN_SET (fullname_id , @sequence) DESC
那么结果应该是:

14354   DAILLY Gertrude (1068-1119)
13880   DE BELLOY Blanche (-)
13375   DE HORNOY Auguste (1121-1179)
...
532 LEPINGLE Eugène Alexandre (1909-1981)
531 LEPINGLE Raymonde Marie Emilie (1939-)
332 LHUILLIER Michel Eugène Maurice (1962-)
注:

@sequence = '332-531-532-533-828-576-8471-10033-10389-10709-11503-11853-11959-12020-12070-12101-12135-12163-12185-12203-12264-12302-12355-12447-12603-12613-13019-13375-13880-14354'

提前谢谢。

有几种方法可以做到这一点

第一种方法是启动单独的查询来初始化变量。然而,我的首选方法是在联接中设置变量,如下所示

SELECT a.fullname_id, a.fullname
FROM fullname as a
JOIN (SELECT @sosa := 817595147 as sosa) as b
JOIN (SELECT @sequence := (SELECT REPLACE(seq, '-', ',') FROM lignee WHERE sosa = @sosa) as sequence) as c
WHERE FIND_IN_SET (fullname_id , @sequence)
ORDER BY FIND_IN_SET (fullname_id , @sequence) DESC

那很好!我也在考虑将查询分离,但是您只使用一个查询的方法更适合我,IMHO。非常感谢,没问题!祝你的项目好运