文档章节

仿QQ消息列表页SQL

qii
 qii
发布于 2016/07/04 15:43
字数 585
阅读 214
收藏 0
点赞 0
评论 0

要做一个聊天功能,其中,有个列表页,跟QQ消息的一样。

先看表结构(MySQL):

message_id	int		短消息索引id
message_parent_id	int		回复短消息message_id	
from_member_id	int		短消息发送人		
to_member_id	varchar	短消息接收人	
message_title	varchar	短消息标题
message_body	varchar	短消息内容
message_open	tinyint	短消息打开状态	
message_state	tinyint	短消息状态,0为正常状态,1为发送人删除状态,2为接收人删除状态
from_member_name	varchar	发信息人用户名	
to_member_name	varchar	接收人用户名

先看需求:(箭头方向代表消息的发送方向)

消息列表  ==>  最后查询显示的消息
a->b  ==> a->b
a->b,b->a ==> b->a
a->b,b->a,a->c ==> b->a,a->c
a->b,b->a,a->c,c->a ==> b->a,c->a

第一个想法:a发出的消息+a收到的消息-重复的消息

问题:a发出去的消息,不一定是最后的消息,并且,不好排除重复的消息。

第二个想法:a接收的或者发出去的消息,按照对方来分组,并去最后一条消息

问题:对方可能是发出者或者接收者,group by不能实现。

第三个想法:在第二个想法的基础上,实现一个2人之间唯一的字段,用来分组。取用户id,组成字段,ab,ac,这样,就可以实现分组,后面的问题就解决了。

如果按照from to来组合,那么可能出现的组合就有2种,ab,ba,这两种是等价的。但对于group by来说,则是两种组合。

这里需要创造一个唯一的组合:

CASE WHEN m1.from_member_id = 1 THEN CONCAT( m1.from_member_id, m1.to_member_id ) ELSE CONCAT( m1.to_member_id, m1.from_member_id ) END id

这里1为当前用户的id。

完整SQL如下:

SELECT
	m2.*, CASE
WHEN m2.from_member_id = 1 THEN
	m2.to_member_name
ELSE
	m2.from_member_name
END show_name,
(
	SELECT
		member_avatar
	FROM
		az_member m3
	WHERE
		m3.member_id = (
			CASE
			WHEN m2.to_member_id = 1 THEN
				m2.from_member_id
			ELSE
				m2.to_member_id
			END
		)
) member_avatar
FROM
	az_message m2
WHERE
	m2.message_id IN (
		SELECT
			max(zt.message_id)
		FROM
			(
				SELECT
					m1.*, CASE
				WHEN m1.from_member_id = 1 THEN
					CONCAT(
						m1.from_member_id,
						m1.to_member_id
					)
				ELSE
					CONCAT(
						m1.to_member_id,
						m1.from_member_id
					)
				END id
				FROM
					az_message m1
				WHERE
					(
						m1.from_member_id = 1
						OR m1.to_member_id = 1
					)
				AND m1.message_type = 5
				AND m1.message_open = 0
			) zt
		GROUP BY
			id
	)

过程总结:

1.创造一个唯一的字段。

2.按照唯一字段分组,并取最大id

3.取最大id所在行记录

© 著作权归作者所有

共有 人打赏支持
qii

qii

粉丝 13
博文 77
码字总数 23520
作品 0
昆明
高级程序员
Android UI 特效大全

Android UI特效大全 总体传送门:http://git.oschina.net/bob4j/Android-UI 基本上项目中都有效果图可自行查看 , 并且有些项目中都有README.md 文件,使用前请先阅读以下。 1.弧形(圆形)菜单...

不正经啊不正经 ⋅ 2015/07/31 ⋅ 0

Wex5 3.3版本仿淘宝开发视频

第一讲 仿淘宝概述 第二讲 创建应用和首页开发 第三讲 分类页和列表页 第四讲 商品详细页和微信分享 第五讲 购物车页和搜索页 视频下载地址:http://wex5.com/cn/downloads/ QQ交流群:30057...

muyu ⋅ 2016/01/16 ⋅ 0

凡信 2.0 beta 发布-超仿微信的开源项目

凡信的第一个版本于2015年4月份发布,之后由于自己工作忙碌的原因,一直没有重大的更新内容。2016年1月份抽空做了一些更新。主要是加入了朋友圈和钱包这两块内容,以及对第一版的一些bug的修...

程开源 ⋅ 2016/02/16 ⋅ 15

凌晨一点写东东/QQ

仿QQ v0.0.1 微信小程序版 主要实现功能: 界面绘制(消息、联系人、聊天、动态界面) 可复用组件:搜索框、列表 嵌入情绪音乐播放器(请见上一篇文章) 界面截图: 消息界面 联系人界面 联系...

凌晨一点写东东 ⋅ 2016/10/24 ⋅ 0

盘点2014不容错过的UI源码

好的UI设计不仅是让软件变得有个性有品味,还要让软件的操作变得舒适、简单、自由、充分体现软件的定位和特点。有没有想要的效果还没有实现的,这里有现成的UI源码哦,需要的拿去。 QQ v4.7....

牵着蜗牛去西藏 ⋅ 2014/12/31 ⋅ 4

凡信(超仿微信Android版)开源了,内有源码下载

本项目的IM通信部分是基于 环信即时通讯云 的SDK开发的。对于个人开发者或者小企业来说,做IM用第三方的也是一种趋势吧,毕竟自己整一套可供运营使用的IM系统几乎是不切实际的(技术门槛和维...

极分享社区 ⋅ 2016/04/01 ⋅ 3

iOS码农聊天室--zychat

ZYChat (一) 是一个实战项目的聊天UI框架,针对高频次高速率刷新最近会话列表和实际对话页面做了缓冲优化,经过测试会话使用的性能和体验非常稳定。 (二) UI框架参考MVVM思想设计,并采用自身...

ZYVincent ⋅ 2016/01/04 ⋅ 1

Android UI框架(中)

唯美清新的switch按钮 优雅的switch状态按钮 通用的引导页和轮播器 仿微信图片选择器 快捷设置沉浸式状态栏 复杂表格布局 最全的开源集合 阻尼效果的界面 炫酷的纸飞机下拉刷新控件 仿ios水滴...

Moosphon ⋅ 2017/12/31 ⋅ 0

OpenCenter Beta3 发布,PHP 开源用户管理系统

让php开发人员只需专注业务模块的开发,从用户和后台管理中解放出来。 继上一个beta2版本之后,OC又在这周发布了beta3。 加入了单点登录; 在后台AdminConfigBuilder方面,新增了KeyChosen(...

陈一枭 ⋅ 2015/03/17 ⋅ 9

OpenCMF v1.4.0 正式版发布,积木式开发平台

经过历史2个月的研发,OpenCMF v1.4.0正式版发布! 项目介绍 OpenCMF是一套国内领先的互联网积木式云平台,追求简单、高效、卓越。可轻松实现支持多终端的WEB产品快速搭建、部署、上线。系统...

lyunweb ⋅ 2016/07/19 ⋅ 27

没有更多内容

加载失败,请刷新页面

加载更多

下一页

mysql5.7系列修改root默认密码

操作系统为centos7 64 1、修改 /etc/my.cnf,在 [mysqld] 小节下添加一行:skip-grant-tables=1 这一行配置让 mysqld 启动时不对密码进行验证 2、重启 mysqld 服务:systemctl restart mysql...

sskill ⋅ 11分钟前 ⋅ 0

Intellij IDEA神器常用技巧六-Debug详解

在调试代码的时候,你的项目得debug模式启动,也就是点那个绿色的甲虫启动服务器,然后,就可以在代码里面断点调试啦。下面不要在意,这个快捷键具体是啥,因为,这个keymap是可以自己配置的...

Mkeeper ⋅ 15分钟前 ⋅ 0

zip压缩工具、tar打包、打包并压缩

zip 支持压缩目录 1.在/tmp/目录下创建目录(study_zip)及文件 root@yolks1 study_zip]# !treetree 11└── 2 └── 3 └── test_zip.txt2 directories, 1 file 2.yum...

蛋黄Yolks ⋅ 17分钟前 ⋅ 0

聊聊HystrixThreadPool

序 本文主要研究一下HystrixThreadPool HystrixThreadPool hystrix-core-1.5.12-sources.jar!/com/netflix/hystrix/HystrixThreadPool.java /** * ThreadPool used to executed {@link Hys......

go4it ⋅ 36分钟前 ⋅ 0

容器之上传镜像到Docker hub

Docker hub在国内可以访问,首先要创建一个账号,这个后面会用到,我是用126邮箱注册的。 1. docker login List-1 Username不能使用你注册的邮箱,要用使用注册时用的username;要输入密码 ...

汉斯-冯-拉特 ⋅ 42分钟前 ⋅ 0

SpringBoot简单使用ehcache

1,SpringBoot版本 2.0.3.RELEASE ①,pom.xml <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.0.3.RELE......

暗中观察 ⋅ 43分钟前 ⋅ 0

监控各项服务

比如有三个服务, 为了减少故障时间,增加监控任务,使用linux的 crontab 实现. 步骤: 1,每个服务写一个ping接口 监控如下内容: 1,HouseServer 是否正常运行,所以需要增加一个ping的接口 ; http...

黄威 ⋅ 47分钟前 ⋅ 0

Spring源码解析(八)——实例创建(下)

前言 来到实例创建的最后一节,前面已经将一个实例通过不同方式(工厂方法、构造器注入、默认构造器)给创建出来了,下面我们要对创建出来的实例进行一些“加工”处理。 源码解读 回顾下之前...

MarvelCode ⋅ 47分钟前 ⋅ 0

nodejs __proto__跟prototype

前言 nodejs中完全没有class的这个概念,这点跟PHP,JAVA等面向对象的语言很不一样,没有class跟object的区分,那么nodejs是怎么样实现继承的呢? 对象 对象是由属性跟方法组成的一个东西,就...

Ai5tbb ⋅ 53分钟前 ⋅ 0

Ubuntu16.04 PHP7.0 不能用MYSQLi方式连接MySQL5.7数据库

Q: Ubuntu16.04 PHP7.0 不能用MYSQLi方式连接MySQL5.7数据库 A: 执行以下2条命令解决: apt-get install php-mysql service apache2 restart php -m 执行后会多以下4个模块: mysqli mysqlnd...

SamXIAO ⋅ 56分钟前 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部