java多对多的存储_spring 多对多的保存



user和authority两表通过中间表user_authority来实现关联,user_authority表如下:

f78363d681bc6271a7fac9d4eaf54785.png

在spring的domain的关联代码如下:

/**

*/

@ManyToMany(fetch = FetchType.LAZY)

@JoinTable(catalog = "xmgl", name = "user_authority", joinColumns = { @JoinColumn(name = "User_ID", referencedColumnName = "ID", nullable = false, updatable = false) }, inverseJoinColumns = { @JoinColumn(name = "Authority_ID", referencedColumnName = "ID", nullable = false, updatable = false) })

@XmlElement(name = "", namespace = "")

java.util.Set authorities;

在jsp页面怎么将权限传到后来呢?通过先将数据保存到user中的另一个字符串的对象,如下所示:

:

${current.CName}

我先将数据保存到user的userName中,然后通过userName传到后台的service层,而service层实现保存的方法如下:

/*

* 保存新增的用户权限

*/

public void saveAuthority(User user)

{

String str = user.getUserName();

String[] arrayStr = str.split(",");

int id=user.getId();

User user2=userDAO.findUserByPrimaryKey(id);

Set authorities=authorityDAO.findAllAuthoritys();

Set sets=user.getAuthorities();

for(int i=0;i

String auth=arrayStr[i];

int authorityId=Integer.parseInt(auth);

for(Authority authority:authorities)

{

if(authority.getId()==authorityId)

{

sets.add(authority);

}

}

user2.setAuthorities(sets);

userDAO.store(user2);

userDAO.flush();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值