免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1383 | 回复: 4
打印 上一主题 下一主题

一个SQL语句问题,比较难 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-03-29 14:32 |只看该作者 |倒序浏览
$sql="SELECT author, subject FROM pw_threads WHERE tid=$tid LIMIT 1";

$sql="SELECT content FROM pw_tmsgs WHERE tid=$tid LIMIT 1";

$sql="SELECT author, subject, content FROM pw_posts WHERE tid=$tid ORDER BY pid limit 0,20";

三句合成一句。有办法?

论坛徽章:
0
2 [报告]
发表于 2007-03-29 14:54 |只看该作者
干嘛要合成一句呢?三句不是很好吗?

论坛徽章:
0
3 [报告]
发表于 2007-03-29 14:57 |只看该作者
select a.author, b.subject, b.content , c.author as cauthor, c.subject as bsubject, c.content as cccntent from pw_threads as a left join pw_tmsgs as b using($tid) left join pw_posts as c using($tid) ORDER BY pid limit 0,20


没测试...........

论坛徽章:
1
技术图书徽章
日期:2013-12-05 23:25:45
4 [报告]
发表于 2007-03-29 15:32 |只看该作者
原帖由 115300111 于 2007-3-29 14:32 发表
$sql="SELECT author, subject FROM pw_threads WHERE tid=$tid LIMIT 1";

$sql="SELECT content FROM pw_tmsgs WHERE tid=$tid LIMIT 1";

$sql="SELECT author, subject, content FROM pw_posts WHERE tid=$tid ORDER BY pid limit 0,20";


可以合成,但是下面的合成方法,只是从合成的角度来考虑的,并没有考虑效率的问题。

1. 读取出来的信息,是否有主键呢?我们假设为post_id
2. sql1、sql2合成,很好做:
  1. $sql = "SELECT author, subject, content  FROM pw_threads WHERE tid=$tid LIMIT 1";
复制代码

3. 2和sql3合成
  1. $sql = "SELECT author, subject, content  FROM pw_threads WHERE
  2. post_id = ( SELECT post_id FROM pw_threads WHERE tid=$tid LIMIT 1 )
  3. OR
  4. post_id IN ( SELECT post_id FROM pw_posts WHERE tid=$tid ORDER BY pid limit 0,20 )
  5. ORDER BY pid
  6. ";
复制代码

论坛徽章:
0
5 [报告]
发表于 2007-03-29 16:49 |只看该作者
这么说来。。。不合并为好。。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP