- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有两个表 sms_contacts 和 sms_twoway_chat。联系人表使用 id 作为 PK,contact_type 用于 3 种 psooible 类型的联系人(0,1 和 2)sms_twoway_chat 保存两个联系人之间的所有聊天。
我需要 contact_type 0 的所有联系人,无论他们是否有聊天我只需要 contact_type 1 和 2 且已收到回复的联系人我需要未读 (is_read = 0) 和最近的聊天回复 (date_time desc ) 位于顶部
我所做的是在顶部显示 Null,例如聊天表中没有任何记录的类型 0 的联系人显示在顶部,而他们应该在最后
CREATE TABLE IF NOT EXISTS `sms_contacts` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`user_id` int(11) DEFAULT NULL,
`contacts_name` varchar(50) DEFAULT NULL,
`contacts_phone` varchar(11) DEFAULT NULL,
`date_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
`date_time_unix` bigint(20) DEFAULT NULL,
`contact_type` int(1) DEFAULT '0' COMMENT '0=>contact 1=>group , 2=>instant msg',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=19 ;
CREATE TABLE IF NOT EXISTS `sms_twoway_chat` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`inbound_id` varchar(50) DEFAULT NULL,
`sender_id` int(11) DEFAULT NULL,
`receiver_id` int(11) DEFAULT NULL,
`is_read` int(1) DEFAULT '0',
`msg_body` text,
`date_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
`date_time_unix` bigint(20) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=89 ;
这是我尝试过的
SELECT a.*
FROM ( SELECT c.id,c.`contacts_name` FROM sms_contacts c
LEFT JOIN sms_twoway_chat tc ON c.id = tc.`receiver_id`
WHERE user_id = 1 AND c.contact_type = 0
ORDER BY -tc.`is_read`, tc.date_time DESC
) a
UNION
SELECT b.*
FROM ( SELECT c.id,c.`contacts_name` FROM sms_contacts c
INNER JOIN sms_twoway_chat tc ON c.id = tc.`receiver_id`
WHERE user_id = 1 AND c.contact_type IN(1,2)
ORDER BY -tc.`is_read`,tc.date_time DESC
) b;
What about this as a solution ??
SELECT *
FROM (
SELECT c.id AS i, 1 AS dt
FROM sms_contacts c
WHERE user_id = 1 AND c.contact_type = 0
) t1
LEFT JOIN
(SELECT *
FROM (
SELECT DISTINCT sender_id AS i, MAX(date_time) AS dt
FROM sms_twoway_chat
WHERE `inbound_id` <> "" AND `receiver_id` =1
GROUP BY sender_id
ORDER BY MAX(date_time) DESC, sender_id
)t3 )t2
ON t1.i = t2.i
ORDER BY t2.dt DESC
最佳答案
这可能对某人有帮助
SELECT *
FROM (
SELECT c.id AS i, 1 AS dt, c.`contacts_name`
FROM sms_contacts c
WHERE user_id = 1 AND c.contact_type = 0
) t1
LEFT JOIN
(SELECT *
FROM (
SELECT DISTINCT sender_id AS i, MAX(date_time) AS dt, 2 AS contacts_name
FROM sms_twoway_chat
WHERE `inbound_id` <> "" AND `receiver_id` =1
GROUP BY sender_id
ORDER BY MAX(date_time) DESC, sender_id
)t3 )t2
ON t1.i = t2.i
ORDER BY t2.dt DESC LIMIT 0,100
关于mysql - 用于聊天的复杂 Mysql 查询,按 desc 排序,最后留下 NULL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42078369/
目前,我在单击我的正文时打开一个新选项卡,但它将焦点更改为子窗口。但我想通过留下窗口来做到这一点,这样弹出窗口就不会被阻止,并且我可以将焦点放在当前窗口上。 以下代码当前正在运行 /** * For
我有一个带有线性渐变的 css 背景图像。 CSS 代码: .footer-about { display: flex; align-items: center; justif
在服务中包含以下代码(假设在快速端点上): async function (res, req, next) { const fetch = require('node-fetch'); awa
我正在使用 IImageList 和 SHGetFileInfo 为任何给定路径提取巨型图标。一旦我有了它,然后我使用 DrawIconEx 将 HICON 渲染到 HBITMAP 中,最终使用 GD
我有图表并计算了网络密度,现在我应该只保留具有最大权重的分支(网络密度的前 10%,例如 200 中权重最大的 20 个分支)。我找不到该怎么做? 最佳答案 这个问题有点令人困惑,因此,如果稍后出现更
我一直在尝试使用 jquery 创建一种效果,当您将鼠标移到一个 div 上时,整个 body 都会移动,并沿着它经过的点留下一条轨迹。我创建了一个可以使整个 body 移动的功能,但我找不到离开轨迹
我想在桌面上显示放大和缩小图标(控件),而仅在移动设备上浏览时显示 gps 图标。我正在使用这个 css https://unpkg.com/leaflet@1.1.0/dist/leaflet.cs
相关代码(索引为数组大小): typedef struct elemento { unsigned long linha; unsigned long coluna; doub
我有一个 div,因此当我单击时,它会切换为展开或缩回。它在所有浏览器上都运行良好,尽管有一点让我很感兴趣。在谷歌浏览器上,当它缩回时,它会在运动中留下细线。 www.rezoluz.com/logi
每当我的应用程序尝试通过调用 CreateDIBSection() 或使用 LR_CREATEDIBSECTION 标志调用 LoadImage() 来创建 DIB 部分时,它似乎都会成功返回。它返回
我想在 Protractor 测试中脱离 Selenium 控制流。 以下是我迄今为止遇到的步骤和问题: 1。逐个测试禁用它 我的第一个想法是使用 SELENIUM_PROMISE_MANAGER 以
我正在构建一个部署在 CentOS 7.2 上的 ASP.Net Core (netcore 1.1) 应用程序。 我有一个通过 System.Diagnostics.Process 调用外部进程(也
我正在为我的网站创建一个聊天小部件。用户将能够输入纯文本 - 没有 html。 为了消除 HTML 标记并允许用户使用“”,我正在接受他们的输入并在用户屏幕的输入上使用 strip_tags() 和输
我是一名优秀的程序员,十分优秀!