- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 centos 6 机器上使用 MySQL 5.6(mysql Ver 14.14 Distrib 5.6.44,用于使用 EditLine 包装器的 Linux (i686))
我有一个包含多个内部联接的查询。我已经确定,当使用带有 SQL_CALC_FOUND_ROWS 的 ORDER BY 子句时,不会返回任何数据。查询对消息说“确定”,我有一个查询持续时间,但没有返回任何内容。
如果我删除“SQL_CALC_FOUND_ROWS”,那么我会得到我的行。在 MySQL Workbench 中,我可以看到持续时间,但在“获取”时间下它甚至不会尝试获取。
查询是:
SELECT SQL_CALC_FOUND_ROWS
l.id AS licensee_id,
l.agency_id,
l.licensee_fname,
l.licensee_name,
l.licensee_lname,
l.licensee_email,
licensee_certs.cert_number,
agency.agency_name,
licensee_cert_types.cert_name,
licensee_certs.cert_issue_date AS approval_timestamp,
licensee_certs.cert_issue_date AS issue_timestamp,
licensee_certs.cert_expiration_date AS expire_timestamp,
licensee_certs.cert_status AS licensee_status,
licensee_certs.cert_status,
(licensee_certs.cert_expiration_date - UNIX_TIMESTAMP()) AS days_remaining,
h_cache.acquired AS total_hours,
h_cache.pending AS pending_hours,
CONCAT(IFNULL(licensee_cert_types.cert_name, ''),
' ',
IFNULL(licensee_certs.cert_number, ''),
' ',
IFNULL(licensee_certs.cert_status, ''),
' ',
IFNULL(l.licensee_fname, ''),
' ',
IFNULL(l.licensee_lname, ''),
' ',
IFNULL(l.licensee_email, ''),
' ',
IFNULL(agency.agency_name, ''),
' ',
IFNULL(agency.agency_abbr, '')) AS search
FROM
licensee AS l
LEFT JOIN
licensee_certs ON l.id = licensee_certs.licensee_id
AND licensee_certs.agency_id = l.agency_id
LEFT JOIN
agency ON agency.id = l.agency_id
LEFT JOIN
licensee_cert_hour_cache AS h_cache ON h_cache.licensee_id = l.id
AND h_cache.agency_id = l.agency_id
AND h_cache.licensee_cert_type_id = licensee_certs.cert_type
INNER JOIN
licensee_cert_types ON licensee_certs.cert_type = licensee_cert_types.id
GROUP BY licensee_certs.id
ORDER BY l.licensee_fname ASC
limit 5
如果到那时我删除订单,我将获得 5 行。或者,如果我删除“SQL_CALC_FOUND_ROWS”,我会得到 5 行。
为什么我不能同时进行 order by 和 SQL calc?
我认为同样重要的是要注意这个确切的查询在 MySQL 5.5 上工作得很好。我升级到 5.6.44 并出现此行为。
在我们的生产服务器上,运行 5.6.42 - 我们没有遇到此查询的问题。
更新:它似乎是上面提到的这个特定查询。如果我使用 SQL_CALC + ORDER BY 运行不同的查询,我会得到我的结果,即:
SELECT SQL_CALC_FOUND_ROWS
p.*,
a.agency_name,
(SELECT
COUNT(*)
FROM
providership_notes
WHERE
providership_notes.provider_id = p.id) AS note_count,
(SELECT
`user_id`
FROM
`user_entity_relations`
WHERE
`instance_id` = p.id
AND `entity_type_id` = 2
LIMIT 1) AS `user_id`,
CONCAT(IFNULL(providership_name, ''),
' ',
IFNULL(providership_abbr, ''),
' ',
IFNULL(agency_name, ''),
' ',
IFNULL(providership_state, '')) AS search
FROM
providership AS p
LEFT JOIN
agency_providership_relations AS r ON r.providership_id = p.id
AND `r`.`status` = 'approved'
LEFT JOIN
agency AS a ON r.agency_id = a.id
GROUP BY p.id
ORDER BY providership_name ASC
LIMIT 0 , 10```
最佳答案
所以...不好意思说我的硬盘空间不足了。我有 ~5mB 的空闲空间,这允许所有其他查询工作,但这个查询。
我清理了一些空间,然后像魔术一样一切正常。
关于MySQL - ORDER BY 子句导致 SQL_CALC_FOUND_ROWS 选择不返回数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56030156/
$query->select('SQL_CALC_FOUND_ROWS i.title,i.fulltext,i.shorttext'); $query->from('#__items
我们开始使用基于语句的复制,发现它破坏了 SQL_CALC_FOUND_ROWS 和 FOUND_ROWS(),我正在寻找解决方法。 2007 年错误报告中的评论建议使用 SELECT SQL_CAL
所以我执行查询: SELECT SQL_CALC_FOUND_ROWS * FROM table l LIMIT 10, 20; 从表中返回 20 行,表中共有 553 行 然后我立即执行SELECT
我正在处理使用 SQL_CALC_FOUND_ROWS() 的分页代码,但是当我将每页的结果限制为小于总结果的数字时,“SELECT FOUND_ROWS() as total”将返回每页的元素数,并
如何获取特定查询的总行数并将查询结果限制为 10 行。例如。我有一个名为样本的表。它有 400 行。在运行像 where name = "%Sam%"这样的查询时,它返回 213 行。现在我只取前 1
我使用嵌套的 MySQL 查询来获取用户帖子,当我将 SQL_CALC_FOUND_ROWS 放入子查询时,MySQL 返回错误:Incorrect usage/placement of 'SQL_C
我发现 MySQL 返回一个 Incorrect usage/placement of 'SQL_CALC_FOUND_ROWS' 如果我将 SQL_CALC_FOUND_ROWS 放入子查询中会出错
所以我有一个表,其中有超过 500 万行。当我使用 SQL_CALC_FOUND_ROWS 时,查询永远挂起。当我把它拿出来时,查询在一秒钟内执行,限制为 25。我的问题是出于分页原因,是否有替代方法
我目前正在摸索如何使用准备好的语句实现 SQL_CALC_FOUND_ROWS。 我正在编写一个分页类,显然我想向查询添加 LIMIT,但也想知道总行数是多少。 这是相关类(class)的示例。 $q
我想删除此查询返回的记录: SELECT SQL_CALC_FOUND_ROWS tag, COUNT( tag ) AS count FROM _tags GROUP BY tag HAVING c
我正在做一个简单的 MySQL 查询来计算查询返回的行数,而没有 LIMIT 子句的影响。我将 Active Records 与 Codeigniter PHP 框架结合使用。 问题:使用SQL_CA
我正在尝试从数据库进行分页,到目前为止我发现如果您想使用限制,您应该使用 SQL_CALC_FOUND_ROWS。 但是,在 Java 中,我在理解如何调用它时遇到了一些问题。 我可以在一个 prep
我有一个查询,它获取一个结果,对其进行限制,然后对有限的结果进行排序。像这样的东西: (SELECT SQL_CALC_FOUND_ROWS * FROM table ... ORDER BY sc
我在 MySQL、InnoDB 中使用 SQL_CALC_FOUND_ROWS 时遇到一些问题。首先让我展示一个简单的数据库架构来解释正在发生的事情...... Database Schema 媒体表
我正在使用名为 feedwordpress 的 WordPress 插件为了在 WordPress 上运行一个类似行星的网站(参见 here )。 这个插件很棒,除了一件事之外 - 它每周左右都会占用
根据这个答案:here The use of SQL_CALC_FOUND_ROWS is not subject to race conditions. The result of the SELE
我在 centos 6 机器上使用 MySQL 5.6(mysql Ver 14.14 Distrib 5.6.44,用于使用 EditLine 包装器的 Linux (i686)) 我有一个包含多个
我正在尝试为查询全文索引表的结果添加分页。这是查询: 普通查询 SELECT *,MATCH(title) AGAINST ("+samsung +galaxy +s3" IN BOOLEAN MOD
我在使用 MYSQL 时遇到问题。 SQL_CALC_FOUND_ROWS 和 FOUND_ROWS() 工作不正常。 问题: 第一次总返回1 第二次总数返回正确的3,500 名 MYSQL版本: m
这是我所知道的一种方式。请建议任何其他??? SELECT SQL_CALC_FOUND_ROWS * FROM Table; SELECT FOUND_ROWS(); 最佳答案 你可以使用(它会更快
我是一名优秀的程序员,十分优秀!