@NotFound(action=NotFoundAction.IGNORE)

引用
转载:http://blog.sina.com.cn/s/blog_7a8f609501014j34.html


使用hibernate 注解配置实体类的关联关系,在many-to-one,one-to-one关联中,一边引用自另一边的属性,如果属性值为某某的数据在数据库不存在了,hibernate默认会抛出异常。解决此问题,加上如下注解就可以了: 
@NotFound(action=NotFoundAction.IGNORE),意思是找不到引用的外键数据时忽略,NotFound默认是exception 
下面贴出hibernate 注解的实例代码 
view plaincopy to clipboardprint? 
@Entity 
@Table(name = "ICT_COMPUTER_LOCATION")  
public class IctComputerLocation {  
    private static final long serialVersionUID = 1L;  

    private Integer id;  
     
    private String idcNum;  

    private Integer ictBaseId;  

     
    private IctBase ictBase;  

    @Id 
    @GeneratedValue(strategy = GenerationType.AUTO)  
    @Column(name = "ID")  
    public Integer getId() {  
        return id;  
    }  

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

    @Column(name = "IDC_NUM")  
    public String getIdcNum() {  
        return idcNum;  
    }  

    public void setIdcNum(String idcNum) {  
        this.idcNum = idcNum;  
    }  

    @Column(name = "ICT_BASE_ID")  
    public Integer getIctBaseId() {  
        return ictBaseId;  
    }  

    public void setIctBaseId(Integer ictBaseId) {  
        this.ictBaseId = ictBaseId;  
    }  

    @ManyToOne(fetch = FetchType.LAZY)  
    @JoinColumn(name = "ICT_BASE_ID", referencedColumnName = "ID", unique = false, nullable = false, insertable = false, updatable = false)  
    @NotFound(action=NotFoundAction.IGNORE)  
    public IctBase getIctBase() {  
        return ictBase;  
    }  

    public void setIctBase(IctBase ictBase) {  
        this.ictBase = ictBase;  
    } 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/hardwin/archive/2009/07/08/4330779.aspx 



对象A一对多对象B,现在要查询对象A,条件中包含对象B的属性,但对象A的属性B可能为Null,这时候怎么写条件? 
比如对象A是用户: 
Java code 
@Entity 
@Table(name = "base_staff") 
public class User { 
@Id 
@GeneratedValue 
@Column(name = "id") 
private int id; 
@Column(name = "name") 
private String name; 
@Column(name = "logname") 
private String logname; 
@Column(name = "logpass") 
private String logpass; 
@ManyToOne 
@JoinColumn(name = "gender") 
@NotFound(action=NotFoundAction.IGNORE) 
private Gender gender; 
@Column(name = "birthdate") 
private Date birthdate; 
@ManyToOne 
@JoinColumn(name = "user_status") 
@NotFound(action=NotFoundAction.IGNORE) 
private UserStatus status; 
@Column(name = "note") 
private String note; 
@ManyToMany(fetch = FetchType.EAGER) 
@JoinTable(name = "sys_user_role", 
joinColumns = { @JoinColumn(name = "user_id") }, 
inverseJoinColumns = { @JoinColumn(name = "role_id") }) 
@NotFound(action=NotFoundAction.IGNORE) 
private Set roles; 
…… 

对象B是性别: 
Java code 
@Entity 
@Table(name = "code_gender") 
public class Gender { 
@Id 
@Column(name = "id") 
private int id; 
@Column(name = "name") 
private String name; 

UserDao: 
Java code 
Query query = session.createQuery("from User u" + 
" where u.name like :key" + 
" or u.gender.name like :key" + 
" or u.logname like :key" + 
" or u.status.name like :key" + 
" or u.note like :key" + 
" order by u.id"); 
query.setParameter("key", "%" + key + "%"); 
query.setFirstResult(offset); 
query.setMaxResults(size); 
List list = query.list(); 
这种情况查询不到User的gender为null的数据。想要得到那些数据应该怎么些HQL呢?
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在你提供的代码中,`@Mappings` 是 MapStruct 框架提供的注解,用于定义字段之间的映射关系。`@Mappings` 注解内部可以包含多个 `@Mapping` 注解,每个 `@Mapping` 注解用于指定一个字段的映射关系。 具体来说,你的代码中定义了两个方法:`toEntity()` 和 `toDTO()`。这两个方法分别用于将 DTO(Data Transfer Object)对象转换为实体对象和将实体对象转换为 DTO 对象。 在 `toEntity()` 方法上,通过 `@Mapping` 注解指定了三个字段的映射关系: - `source = "channel.id"` 表示将 DTO 对象中的 `channel.id` 字段的值映射到实体对象的 `channelId` 字段。 - `source = "createBy.id"` 表示将 DTO 对象中的 `createBy.id` 字段的值映射到实体对象的 `createBy` 字段。 - `source = "updateBy.id"` 表示将 DTO 对象中的 `updateBy.id` 字段的值映射到实体对象的 `updateBy` 字段。 类似地,在 `toDTO()` 方法上,通过 `@Mapping` 注解指定了三个字段的映射关系: - `source = "channelId"` 表示将实体对象中的 `channelId` 字段的值映射到 DTO 对象的 `channel.id` 字段。 - `source = "createBy"` 表示将实体对象中的 `createBy` 字段的值映射到 DTO 对象的 `createBy.id` 字段。 - `source = "updateBy"` 表示将实体对象中的 `updateBy` 字段的值映射到 DTO 对象的 `updateBy.id` 字段。 通过使用这些 `@Mapping` 注解,你可以定义实体对象和 DTO 对象之间的字段映射关系,以便在转换过程中进行数据的复制和转换。这样可以简化对象之间的转换操作,提高开发效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值