正在构建一个线程消息系统,我有下表
conversations_inbox
id
R_id
S_id
message
read
post_time
conv_id
conversation_outbox
id
R_id
S_id
message
read
post_time
conv_id
conversation_meta
id
sender_id
reciever_id
datetime
conversations_inbox
和 conversation_outbox
有一个外键 conv_id
,用于跟踪两个用户之间的消息传递线程
当我处理消息收件箱时,我遇到了障碍,我尝试按 sender_id(S_id)
对收件箱中的消息进行分组,而不是将用户收到的每条新消息显示为新行。框中发送给用户的消息将分组在发送该消息的用户下,并显示来自该用户的最新消息。
我已经尝试过
function get_user_conversations($user_id) {
//Load Models
$this->load->model('conversation_model');
//Load helper
$this->load->helper('date');
//database query
$q = $this->db->select('R_id,message,post_time,read,conv_id')
->from('conversations_inbox')
->where('R_id',$user_id)
->group_by('S_id')
->order_by('post_time','desc')
->get();
$conversations = $q->result();
return $conversations;
}
但它只为每个发件人 ID 返回一行数据 如果有人能指出我正确的方向,我将非常感激
最佳答案
首先我要声明的是,在此之前我从未听说过 codeigniter...
我认为这是因为你在 group_by
之后调用 ->order_by('post_time','desc')
,尝试切换这两个,在它们同时排序不分组是这样的想法...
关于php - 线程消息系统,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7408887/