hibernate关联查询问题

现在有两个表。用户表s_user对应实体类SUser和用户在线表s_online对应实体类SO
nline,我要通过s_user的主键userid对s_online的主键userid进行关联查询,

其中这个s_user已经跟另外两个表进行关联查询,我就照样画葫芦加上相同的标记,然后启动tomcat的时候报错broken column mapping for: sOnline.id of: com.cn.model.SUser。

然后我再去SOnline查看sOnline属性什么情况,原来是加了一堆注解,,是一个复合主键,,我不清楚什么是复合主键,,,反正现在就是想知道怎么通过注解用s_user的userid字段查出SOnline对应的userid字段,,求帮忙

 @ManyToOne
    @JoinColumn(name = "groupid", insertable = false, updatable = false)
    public SUsergroup getUsergroup() {
        return usergroup;
    }

    public void setUsergroup(SUsergroup usergroup) {
        this.usergroup = usergroup;
    }

    @ManyToOne
    @JoinColumn(name = "rateid", insertable = false, updatable = false)
    public SRate getsRate() {
        return sRate;
    }

    public void setsRate(SRate sRate) {
        this.sRate = sRate;
    }
    SOnline复合主键部分代码
    private SOnlineId id;

    @EmbeddedId
    @AttributeOverrides({
            @AttributeOverride(name = "userid", column = @Column(name = "userid", nullable = false, length = 16)),
            @AttributeOverride(name = "acctstart", column = @Column(name = "acctstart", nullable = false, length = 29)),
            @AttributeOverride(name = "acctid", column = @Column(name = "acctid", nullable = false, length = 32)) })
    public SOnlineId getId() {
        return this.id;
    }

    public void setId(SOnlineId id) {
        this.id = id;
    }

1个回答

复合主键是这样 比如两个字段合起来是主键 比如你一个字段值为1 另外字段也为1 那么其他数据就不能出现1 1的

u013771353
无限超频 不过,问题还是没解决,,现在要怎么通过userid,查到sonline里复合主键之中的userid?
接近 4 年之前 回复
u013771353
无限超频 这样啊,,我以前就是在想两个字段组合起来不会出现一样的情况,就拼在一起组成一个新字段当主键了,,原来还有这个概念。
接近 4 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问