TOFREE007
TOFREE007
采纳率0%
2016-05-11 01:44

MYSQL中多对多关系的数据查询处理,请大神指点

用户表
create table user(
uid int primary key auto_increment,
uname varchar(30),
uaddress varchar(15))
订单表
create table orders(
oid int primary key auto_increment,
uid int not null,
address varchar(70));
商品表
create table product(
pid int primary key auto_increment,
pname varchar(20) not null,
pcount int not null,
price float not null)
中间表
create table op(
opid int primary key auto_increment,
oid int ,
pid int ,
opcount int not null,
opdelete set('n','y')
,constraint fk_oid foreign key (oid) references orders(oid) on update cascade
,constraint fk_pid foreign key (pid) references product(pid) on update cascade
);
我使用的是hibernate中HQL多表查询
select o.oid, p.pname, op.opcount, p.pid from Orders as o, OP as op, Product as p, User as u where o.uid=u.uid and op.oid=o.oid and op.pid=p.pid and u.uid=001;
关系是user表跟orders表是一对多,orders表跟product表是多对多。
我数据库中user uid=001,oid=1000,它对应的pid有多个1000001,1000002,1000003
我现在做出来的查询结果是
每一次for循环,oid记录只输出一个pid的数据;我现在有3个pid,需要循环3次才可以输出来。
但是我实际需要的效果是 同一个oid一条记录就可以将它所对应的所有商品都遍历出来。

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

1条回答

  • silehaixianghuirenj 殇婆婆 5年前

    create table orders(
    oid int primary key auto_increment,
    uid int not null,
    address varchar(70));
    商品表
    create table product(
    pid int primary key auto_increment,
    pname varchar(20) not null,
    pcount int not null,
    price float not null)
    中间表
    create table op(
    opid int primary key auto_increment,
    oid int ,
    pid int ,
    opcount int not null,
    opdelete set('n','y')

    点赞 评论 复制链接分享

为你推荐