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


用户 表
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;

学生党求各位大神教导!

java app mysql

milkman 12 years, 1 month ago

如果自己没理解错的话,这个问题应该有一个前提: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
 UNION
SELECT 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也会有对应的关键字。希望对你有帮助吧。

iskapa answered 12 years, 1 month ago

Your Answer