热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

问答系统三表联查问题

1、有三张数据表questions(id,user_id,content,time),answers(id,q_id,user_id,content,status,time),users(id,name,···)问题表,回答表和用户表。问题表的回答记录在answers表里,问题表和回答表的user信息...
1、 有三张数据表 questions(id,user_id,content,time),answers(id,q_id,user_id,content,status,time),users(id,name,···) 问题表,回答表和用户表。问题表的回答记录在answers表里,问题表和回答表的user信息在users表里面;

2、 现在需要得到:所有问题的内容和该问题的提问者的姓名+回答的人以及回答的内容,回答只需要最近一条回答,状态status为1 ;

3、 用CI框架写出查询的方法 join();

4、 或者写出sql,不一定是完全的sql,告诉思路也可以;

【另外】
主要问题是:不能完全得出提问者的姓名,和回答者的姓名。是不是数据表设计的有问题?
还有就是: 有更好的办法直接sql查询出结果不用再用程序对取出的结果进行处理才得到自己想要的数据?

回复内容:

1、 有三张数据表 questions(id,user_id,content,time),answers(id,q_id,user_id,content,status,time),users(id,name,···) 问题表,回答表和用户表。问题表的回答记录在answers表里,问题表和回答表的user信息在users表里面;

2、 现在需要得到:所有问题的内容和该问题的提问者的姓名+回答的人以及回答的内容,回答只需要最近一条回答,状态status为1 ;

3、 用CI框架写出查询的方法 join();

4、 或者写出sql,不一定是完全的sql,告诉思路也可以;

【另外】
主要问题是:不能完全得出提问者的姓名,和回答者的姓名。是不是数据表设计的有问题?
还有就是: 有更好的办法直接sql查询出结果不用再用程序对取出的结果进行处理才得到自己想要的数据?

SELECT tmpu.uname q_unames, q.content, q.`status`, a.content acontent, u.uname auname from u_questions q, (SELECT id,uname from u_users) tmpu, u_answers a LEFT JOIN u_users u ON u.id = a.user_id where tmpu.id = q.user_id ORDER BY a.create_time DESC LIMIT 1

还没有测试,你可以试试

推荐阅读
  • 利用Git GUI将本地项目同步至GitHub的方法
    GitHub作为开发者不可或缺的工具,不仅提供了丰富的开源项目资源,还极大地便利了个人项目的管理和版本控制。本文将详细介绍如何使用Git GUI工具将本地开发的项目上传至GitHub。 ... [详细]
  • 本文将详细探讨MySQL中较为特殊的三种数据类型:SQLTEXT、DATE以及SET,包括它们的基本用法、适用场景及一些高级特性。 ... [详细]
  • MyBatis入门指南:环境搭建与基础配置详解
    本文详细介绍了MyBatis的基础配置流程,包括在Maven项目中添加MyBatis依赖、IDEA中配置数据库连接、导入SQL脚本以及编写mybatis-config.xml配置文件等关键步骤。 ... [详细]
  • 本文基于最新版SQLite 3.33.0(发布于2020年8月20日),详细介绍如何使用ORDER BY语句进行数据排序,包括单列和多列排序的方法。 ... [详细]
  • 本文探讨了Android系统中联系人数据库的设计,特别是AbstractContactsProvider类的作用与实现。文章提供了对源代码的详细分析,并解释了该类如何支持跨数据库操作及事务处理。源代码可从官方Android网站下载。 ... [详细]
  • 本文详细介绍了PHP中的几种超全局变量,包括$GLOBAL、$_SERVER、$_POST、$_GET等,并探讨了AJAX的工作原理及其优缺点。通过具体示例,帮助读者更好地理解和应用这些技术。 ... [详细]
  • 本文详细介绍了在MyBatis框架中如何通过#和$两种方式来传递SQL查询参数。使用#方式可以提高执行效率,而使用$则有助于在复杂SQL语句中更好地查看日志。此外,文章还探讨了不同场景下的参数传递方法,包括实体对象、基本数据类型以及混合参数的使用。 ... [详细]
  • 本文通过一系列实验,探讨了Oracle 11g数据库中密码错误验证延迟特性对用户登录速度的影响。实验旨在验证当某个用户因输入错误密码而触发延迟时,是否会影响其他用户的正常登录速度。 ... [详细]
  • SQL查询与事务管理:深入解析
    本文详细介绍了SQL查询的基本结构和高级特性,包括选择、分组查询以及权限控制等内容,并探讨了事务管理中的并发控制策略,旨在为数据库管理员和开发人员提供实用指导。 ... [详细]
  • PHP 图形函数中实现汉字显示的方法
    本文详细介绍了如何在 PHP 的图形函数中正确显示汉字,包括具体的步骤和注意事项,适合初学者和有一定基础的开发者阅读。 ... [详细]
  • 2023年1月28日网络安全热点
    涵盖最新的网络安全动态,包括OpenSSH和WordPress的安全更新、VirtualBox提权漏洞、以及谷歌推出的新证书验证机制等内容。 ... [详细]
  • 本文由公众号【数智物语】(ID: decision_engine)发布,关注获取更多干货。文章探讨了从数据收集到清洗、建模及可视化的全过程,介绍了41款实用工具,旨在帮助数据科学家和分析师提升工作效率。 ... [详细]
  • 本文深入探讨了MySQL中的高级特性,包括索引机制、锁的使用及管理、以及如何利用慢查询日志优化性能。适合有一定MySQL基础的读者进一步提升技能。 ... [详细]
  • 将XML数据迁移至Oracle Autonomous Data Warehouse (ADW)
    随着Oracle ADW的推出,数据迁移至ADW成为业界关注的焦点。特别是XML和JSON这类结构化数据的迁移需求日益增长。本文将通过一个实际案例,探讨如何高效地将XML数据迁移至ADW。 ... [详细]
  • 在使用mybatis进行mapper.xml测试的时候发生必须为元素类型“mapper”声明属性“namespace”的错误项目目录结构UserMapper和UserMappe ... [详细]
author-avatar
艹尛鱈_695
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有