求教~做游戏数据库不知道怎么做,有点问题,请高手帮忙看下 20
不知道背包表怎么和玩家表连接,药品和装备在另一张表里createtablebag(nidintprimarykey,--编号,主键playeridint,--所属人,外键...
不知道背包表怎么和玩家表连接,药品和装备在另一张表里
create table bag(
nid int primary key,--编号,主键
playerid int,--所属人,外键,来自于player表
leechdomid int,--药品编号,外键,来自于leechdom表
equipid int,--装备编号,外键,来自于equip表
constraint fk_playerid_bag foreign key (playerid) references player(pid),--创建所属人外键
constraint fk_leechdom foreign key (leechdomid) references leechdom(nid),--创建药品外键
constraint fk_equipid foreign key (equipid) references equip(nid)--创建装备外键
)
主要是想把背包和任务联结,但是我这种联结的话,一个背包只能存一件装备和药品……
哦,不好意思,打错了,是人物,背包和人物相联接不是任务……
也就是让一个背包存放多件药品和装备 展开
create table bag(
nid int primary key,--编号,主键
playerid int,--所属人,外键,来自于player表
leechdomid int,--药品编号,外键,来自于leechdom表
equipid int,--装备编号,外键,来自于equip表
constraint fk_playerid_bag foreign key (playerid) references player(pid),--创建所属人外键
constraint fk_leechdom foreign key (leechdomid) references leechdom(nid),--创建药品外键
constraint fk_equipid foreign key (equipid) references equip(nid)--创建装备外键
)
主要是想把背包和任务联结,但是我这种联结的话,一个背包只能存一件装备和药品……
哦,不好意思,打错了,是人物,背包和人物相联接不是任务……
也就是让一个背包存放多件药品和装备 展开
1个回答
展开全部
有想法,佩服!
你想要一个背包能对应多种装备或药品?是不是一种装备或药品也对应不同的背包?
那最好把装备、药品和背包设为一个主键组,这样装备和药品既是主键也是外键,然后再设一个任务外键,就能与任务联结了,不知道这样是不是楼主要求的
但是如果从你建的表来看,如果所属人这个字段只是由背包编号字段决定,那这个表以后随着数据不断增加就会产生很大冗余,也会有冲突(比如添加新信息,有背包,但包里无东西的情况,就会产生信息插入错误)这种情况最好还是把背包、装备、药品单独分出来新建一个表
那相对来说就更简单了,建议设两个表:背包表bag(nid,playerid) PK:nid,FK:playerid; 及包内详细信息表in_bag(nid,leechdomid,equipid) PK:(nid,leechdomid,equipid) , FK:leechdomid,equipid,解释的话还是我上面说的那些
你想要一个背包能对应多种装备或药品?是不是一种装备或药品也对应不同的背包?
那最好把装备、药品和背包设为一个主键组,这样装备和药品既是主键也是外键,然后再设一个任务外键,就能与任务联结了,不知道这样是不是楼主要求的
但是如果从你建的表来看,如果所属人这个字段只是由背包编号字段决定,那这个表以后随着数据不断增加就会产生很大冗余,也会有冲突(比如添加新信息,有背包,但包里无东西的情况,就会产生信息插入错误)这种情况最好还是把背包、装备、药品单独分出来新建一个表
那相对来说就更简单了,建议设两个表:背包表bag(nid,playerid) PK:nid,FK:playerid; 及包内详细信息表in_bag(nid,leechdomid,equipid) PK:(nid,leechdomid,equipid) , FK:leechdomid,equipid,解释的话还是我上面说的那些
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询