mysql 查询 :有一张好友表,UserId,FriendId,这两个人是好友 ,还有一个用户表,UserId和FriendId都是

mysql 查询 :有一张好友表,UserId,FriendId,这两个人是好友 ,还有一个用户表,UserId和FriendId都是,第1张

SELECT UserId,FriendId,sex FROM t_user WHERE (UserId,FriendId) NOT IN (SELECT a.UserId,a.FriendId FROM t_user a,t_friend b WHERE a.UserId=b.UserId AND a.FriendId =b.FriendId)

思路:

1用户发送好友申请之后 把申请储存到申请数据表中,状态为 未验证

2 当用户登录时,查询申请表中是否有uid和被申请人id相同的,如果同意,更改状态,并把数据插入到对应的好友数据表否则,删除申请数据表中数据

3,当一方删除好友时,从被删除人中删除删除人的好友

4 创建分组名称字段,字段设定好值,让用户选择,或者让用户自定

5 当查询时候列出数据表信息

附:MySQL数据表 共两个

#以上步骤是对数据库的 *** 作,你可以<aclass="inner-link decor-unline"href="/search?word=实例化&fr=qb_search_exp&ie=gbk"target="_blank" rel="nofollow" data-word="2">实例化</a>,

#好友表

<a class="inner-link decor-unline"href="/search?word=mysql_query&fr=qb_search_exp&ie=gbk"target="_blank" rel="nofollow" data-word="0">mysql_query</a>("CREATE TABLE `t_friend` (

`id` int(11) NOT NULL auto_increment COMMENT '自增id',

`uid` int(11) NOT NULL COMMENT '用户id',

`fid` int(11) NOT NULL COMMENT '好友uid,用,分割,可以有多个',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8

#申请表

CREATE TABLE `t_shenqing` (

`id` int(11) NOT NULL auto_increment COMMENT '自增id',

`uid` int(11) NOT NULL COMMENT '被申请用户id userid',

`sid` int(11) NOT NULL COMMENT '好友申请人id',

`text` varchar(255) NOT NULL COMMENT '附言',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8

")

每一次用户请求 *** 作,就会对数据库进行一次查询或更新,


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/8350643.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-15
下一篇2023-04-15

发表评论

登录后才能评论

评论列表(0条)

    保存