一个用户表id name然后每一种第三方就新增一个表ex 微信id openid uid(主用户表id) .....
QQid openid uid
这样用户用不同的第三方就会有不同的账号 一个用户就拥有了多个账号了如何实现数据互通呢 比如微信登陆 可以绑定QQ 那么以后微信和QQ的信息就同步了
可以有几种方式:第一种,冗余字段用户表user : id name phone email .....第三方登录表login:id uid wxopenid qqopenid......创建的时候给''然后后面绑定的时候更新相关字段。第二种 拆表用户表:user : id name phone email .....第三方表:openid: id wx_openid qq_openid....关系表relationship:uid oid 这里的oid就是第三方表这样设计的目的是 不用join操作,因为数据多了以后join操作很耗时间,我们在代码逻辑层先根据当前登录的uid获取relationship的oid,然后再selectopenid表的相关数据。
不太建议都放在一个表的做法。。。
1、为啥不是用一张表,表里有个字段,类似 type,表示是哪种第三发登录呢。
2、用两个不同的第三方登录,的确就生成了两个账号了。这个时候如果再想把这两个账号合并,就比较复杂,牵涉到使用哪里数据了。当然也是可以这么做,大不了信息同时发到多个账号。
一般的思路,先有一个账号(账号来源可以使某种第三方登录,邮箱注册,手机注册)反正要有一个账号,然后呢登录以后绑定新的一个第三方账号。可以参数 SF 账号设置嘛, /user...
更新一下,一个表维护多个第三方登录 之 我的个人理解表字段 - oauth 表id // 可以自增type // 可以是 wx,qq,weibo 等等user_id ,//对应 user 表中的iddata ,// mysql-text 类型,里面是 json 格式或者可以用 php 的序列化格式,我是推荐 json 格式,对应不同的 type 想存就存什么,对于数据读取,存放都没什么差别。
可以有几种方式:
第一种,冗余字段
用户表user : id name phone email .....
第三方登录表login:id uid wxopenid qqopenid......
创建的时候给''然后后面绑定的时候更新相关字段。
第二种 拆表
用户表:user : id name phone email .....
第三方表:openid: id wx_openid qq_openid....
关系表relationship:uid oid 这里的oid就是第三方表
这样设计的目的是 不用join操作,因为数据多了以后join操作很耗时间,我们在代码逻辑层先根据当前登录的uid获取relationship的oid,然后再selectopenid表的相关数据。
不太建议都放在一个表的做法。。。
1、为啥不是用一张表,表里有个字段,类似 type,表示是哪种第三发登录呢。
2、用两个不同的第三方登录,的确就生成了两个账号了。这个时候如果再想把这两个账号合并,就比较复杂,牵涉到使用哪里数据了。当然也是可以这么做,大不了信息同时发到多个账号。
一般的思路,先有一个账号(账号来源可以使某种第三方登录,邮箱注册,手机注册)反正要有一个账号,然后呢登录以后绑定新的一个第三方账号。可以参数 SF 账号设置嘛, /user...
更新一下,一个表维护多个第三方登录 之 我的个人理解
表字段 - oauth 表
id // 可以自增
type // 可以是 wx,qq,weibo 等等
user_id ,//对应 user 表中的id
data ,// mysql-text 类型,里面是 json 格式或者可以用 php 的序列化格式,我是推荐 json 格式,对应不同的 type 想存就存什么,对于数据读取,存放都没什么差别。