首页 > 开发 > MySQL > 正文

聊天软件中获取通话记录的sql的怎么写

2017-09-08 09:08:51  来源:网友分享

用户 表
create table user(
id int,
name varchar,
headerPicUrl varchar,
age int
);

通话记录表
create table record_list (
id int,
call_id int,//主叫
be_call_id int,//被叫
record_create_time date,//通话创建时间,
record_time date //通话时长
);

怎么查询得到一个用户的通话记录 如果该用户是主叫,则得到被叫人的id,name,headerPicUrl,age,record_create_time,record_time;
如果该用户是被叫,也得到相同的信息id,name,headerPicUrl,age,record_create_time,record_time;

学生党求各位大神教导!

解决方案

如果自己没理解错的话,这个问题应该有一个前提:record_list表的call_id 和 be_call_id与user表的id是外键关系。
不是大神,但思考了一下,觉得可以这样写:

SELECT u.*,       r.record_create_time,       r.record_time  FROM record_list r  JOIN user        u ON r.be_call_id = u.id WHERE r.call_id = 1 UNIONSELECT u.*       r.record_create_time,       r.record_time  FROM record_list r  JOIN user        u ON r.call_id = u.id WHERE r.be_call_id = 1;

这个UNION关键字是SQLServer中有的,应该mysql也会有对应的关键字。希望对你有帮助吧。