怎么从主查询中选择计数到子查询中

本教程将介绍如何从主查询中选择计数到子查询中的处理方法,这篇教程是从别的地方看到的,然后加了一些国外程序员的疑问与解答,希望能对你有所帮助,好了,下面开始学习吧。

怎么从主查询中选择计数到子查询中 教程 第1张

问题描述

我想将主查询中选择的记录数放入子查询中

我当前尝试执行的查询是:

SELECT cat_id,category_name,seo_name,(SELECT count(category_name) FROM ccs_coupons WHERE (category_name LIKE category_name OR website_name LIKE category_name OR description LIKE LIKE category_name OR url_desc LIKE category_name )) FROM  `ccs_coupons` WHERE  category_name like 'a%' GROUP BY category_name ORDER BY category_name ASC LIMIT $page,$config 

推荐答案

你可以只使用两个表之间的连接而不是相关子查询:

SELECT c.id,
  u.display_name, 
  c.comments_count 
FROM users u
LEFT JOIN
(
  SELECT COUNT(*) comments_count, author_id
  FROM cms_comments 
  GROUP BY author_id
) c
ON c.author_id = u.id
WHERE c.comments_count > 150; 

编辑,根据你的更新,你应该仍然可以使用这样的东西:

SELECT c1.cat_id,
  c1.category_name,
  c1.seo_name,
  c2.CountCategoryName
FROM  `ccs_coupons` c1
LEFT JOIN
(
  SELECT count(category_name) CountCategoryName, category_name,
 website_name, description, url_desc
FROM ccs_coupons 
  GROUP BY category_name
) c2
  on c2.category_name LIKE c1.category_name 
  or c2.website_name LIKE c1.category_name 
  or c2.description LIKE c1.category_name 
  or c2.url_desc LIKE c1.category_name
WHERE  c1.category_name like 'a%' 
ORDER BY c1.category_name ASC 
LIMIT $page,$config;

甚至使用:

SELECT c1.cat_id,
  c1.category_name,
  c1.seo_name,
  count(c2.category_name)
FROM  `ccs_coupons` c1
INNER JOIN ccs_coupons c2
  on c2.category_name LIKE c1.category_name 
  or c2.website_name LIKE c1.category_name 
  or c2.description LIKE c1.category_name 
  or c2.url_desc LIKE c1.category_name
WHERE  c1.category_name like 'a%' 
GROUP BY c1.category_name
ORDER BY c1.category_name ASC 
LIMIT $page,$config;

好了关于怎么从主查询中选择计数到子查询中的教程就到这里就结束了,希望趣模板源码网找到的这篇技术文章能帮助到大家,更多技术教程可以在站内搜索。