繁体   English   中英

来自PHP的MySQL查询

[英]MySQL query from PHP

我需要从PHP进行以下查询:

set @row:=-1;
SELECT * FROM `tablename`
INNER JOIN ( 
    SELECT `id` FROM ( 
        SELECT @row:=@row+1 AS rownum, `id` FROM ( 
            SELECT id FROM `tablename` ORDER BY `id` DESC 
        ) 
            AS sorted 
    ) as ranked WHERE rownum % 14 = 0 
) AS subset ON subset.id = `tablename`.id LIMIT 24;

在PHPMyAdmin中工作正常,但是“ set @ row = -1;”出现错误。 :(

提前致谢!

您可能试图在单个mysqli_query语句中使用这些语句。 这些是多个语句; 您需要在使用PHP代码时分别查询它们。

但是,您也可以使用CROSS JOIN将这两个查询转换为单个查询:

SELECT * FROM `tablename`
INNER JOIN ( 
    SELECT `id` FROM ( 
        SELECT @row:=@row+1 AS rownum, `id` FROM ( 
            SELECT id FROM `tablename` ORDER BY `id` DESC 
        ) AS sorted 
        CROSS JOIN (SELECT @row := -1) AS user_init_vars 
  /* shifted SET statement to the above line (remove the comment before using) */
    ) as ranked WHERE rownum % 14 = 0 
) AS subset ON subset.id = `tablename`.id LIMIT 24;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM