java注解一对多@OneToMany

原创 2016年06月01日 16:39:03
package com.po.configSubT;

import java.util.Date;
import java.util.List;
import java.util.Set;

import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.OneToMany;
import javax.persistence.Table;

import org.springframework.format.annotation.DateTimeFormat;

import com.fasterxml.jackson.annotation.JsonFormat;


@Entity
@Table(name = "config_tv_channel")
public class ConfigTvChannelNew {
    private Integer id;
    private String channel;
    private Integer updateBy;
    private Date updateTime;
    private java.util.List configTvSchedules;

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

    @Column(name = "channel")
    public String getChannel() {
        return channel;
    }

    @Column(name = "update_by")
    public Integer getUpdateBy() {
        return updateBy;
    }

    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @JsonFormat(pattern = "yyyy年MM月dd日,HH:mm:ss", timezone = "GMT+8")
    @Column(name = "update_time")
    public Date getUpdateTime() {
        return updateTime;
    }

    @OneToMany(cascade = { CascadeType.REFRESH,
            CascadeType.PERSIST,
            CascadeType.MERGE,
            CascadeType.REMOVE }
            ,mappedBy = "configTvChannel")
    public java.util.List getConfigTvSchedules() {
        return configTvSchedules;
    }

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

    public void setConfigTvSchedules(
            java.util.List configTvSchedules) {
        this.configTvSchedules = configTvSchedules;
    }

    public void setChannel(String channel) {
        this.channel = channel;
    }

    public void setUpdateBy(Integer updateBy) {
        this.updateBy = updateBy;
    }

    public void setUpdateTime(Date updateTime) {
        this.updateTime = updateTime;
    }

    public ConfigTvChannelNew() {
    }

}


第二个类
-----------------------------------------------------------------------------
package com.po.configSubT;


import java.util.Date;

import javax.persistence.*;

import org.hibernate.annotations.Cascade;
import org.hibernate.annotations.LazyToOne;
import org.hibernate.annotations.LazyToOneOption;
import org.springframework.format.annotation.DateTimeFormat;

import com.fasterxml.jackson.annotation.JsonFormat;

@Entity
@Table(name = "config_tv_schedule")
public class ConfigTvScheduleNew {
    private Integer id;
    private String tvProgram;
    private Date beginTime;
    private Date endTime;
    private ConfigTvChannelNew configTvChannel;

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

    @Column(name = "tv_program")
    public String getTvProgram() {
        return tvProgram;
    }

    @DateTimeFormat(pattern = "HH:mm")
    @JsonFormat(pattern = "HH:mm", timezone = "GMT+8")
    @Column(name = "beginTime")
    public Date getBeginTime() {
        return beginTime;
    }

    @DateTimeFormat(pattern = "HH:mm")
    @JsonFormat(pattern = "HH:mm", timezone = "GMT+8")
    @Column(name = "endTime")
    public Date getEndTime() {
        return endTime;
    }

    @ManyToOne(cascade = {CascadeType.MERGE,
             CascadeType.REFRESH }
     )
//该表的外键字段名字就是tv_channel_id,关联上一个表的id字段
    @JoinColumn(name = "tv_channel_id")
    public ConfigTvChannelNew getConfigTvChannel() {
        return configTvChannel;
    }

    public void setConfigTvChannel(ConfigTvChannelNew configTvChannel) {
        this.configTvChannel = configTvChannel;
    }

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

    public void setTvProgram(String tvProgram) {
        this.tvProgram = tvProgram;
    }

    public void setBeginTime(Date beginTime) {
        this.beginTime = beginTime;
    }

    public void setEndTime(Date endTime) {
        this.endTime = endTime;
    }

    @Override
    public String toString() {
        return "ConfigTvSchedule [id=" + id + ", tvProgram=" + tvProgram
                + ", beginTime=" + beginTime + ", endTime=" + endTime
                + ", configTvChannel=" + configTvChannel + "]";
    }

}
--------------Dao层调用-----------------------------------
package com.dao.config;

import java.util.ArrayList;
import java.util.List;

import javax.jms.Session;

import org.hibernate.Query;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;

import com.common.BaseDao;
import com.dto.ConfigTvDto;
import com.po.config.ConfigTvChannel;
import com.po.configSubT.ConfigTvChannelNew;
import com.po.configSubT.ConfigTvScheduleNew;

@Repository
@Transactional
public class ConfigTvDao extends BaseDao {

    @SuppressWarnings("unchecked")
    public List get() {
        List resList = new ArrayList();
        String hql = "from ConfigTvChannelNew ";
        Query query = getCurrentSession().createQuery(hql);
        List  list = (List)query.list();
        for (int i = 0; i < list.size(); i++) {
            ConfigTvChannelNew conDto = new ConfigTvChannelNew();
            ConfigTvChannel con = new ConfigTvChannel();
            ConfigTvChannelNew conCh = (ConfigTvChannelNew) (list.get(i));
            conDto.setId(conCh.getId());
            conDto.setChannel(conCh.getChannel());
            conDto.setUpdateBy(conCh.getUpdateBy());
            conDto.setUpdateTime(conCh.getUpdateTime());
            ArrayList configTvScheduleList = new ArrayList();
            for (int j = 0; j < conCh.getConfigTvSchedules().size(); j++) {
                ConfigTvScheduleNew conSc = new ConfigTvScheduleNew();
                conSc.setId(conCh.getConfigTvSchedules().get(j).getId());
                conSc.setTvProgram(conCh.getConfigTvSchedules().get(j).getTvProgram());
                conSc.setBeginTime(conCh.getConfigTvSchedules().get(j).getBeginTime());
                conSc.setEndTime(conCh.getConfigTvSchedules().get(j).getEndTime());
                configTvScheduleList.add(conSc);
                conSc=null;
            }
            conDto.setConfigTvSchedules(configTvScheduleList);
            resList.add(conDto);
        }
        return resList;

    }

}

——————–结果————————-

[{“id”:1,”channel”:”东方卫视”,”updateBy”:8888,”updateTime”:”2016年05月19日,12:26:19”,”configTvSchedules”:[{“id”:14,”tvProgram”:”12321”,”beginTime”:”19:00”,”endTime”:”19:00”,”configTvChannel”:null}]},{“id”:2,”channel”:”江苏卫视”,”updateBy”:123,”updateTime”:”2016年04月19日,13:13:07”,”configTvSchedules”:[]},{“id”:3,”channel”:”浙江卫视”,”updateBy”:123,”updateTime”:”2016年04月19日,13:14:45”,”configTvSchedules”:[]},{“id”:4,”channel”:”安徽卫视”,”updateBy”:888,”updateTime”:”2016年04月21日,13:04:38”,”configTvSchedules”:[]},{“id”:5,”channel”:”北京卫视”,”updateBy”:123,”updateTime”:”2016年04月19日,13:15:54”,”configTvSchedules”:[]},{“id”:6,”channel”:”天津卫视”,”updateBy”:123,”updateTime”:”2016年04月19日,13:16:11”,”configTvSchedules”:[]},{“id”:8,”channel”:”重庆卫视”,”updateBy”:111,”updateTime”:”2016年04月19日,13:17:04”,”configTvSchedules”:[]},{“id”:9,”channel”:”延边卫视111”,”updateBy”:8888,”updateTime”:”2016年05月19日,12:32:31”,”configTvSchedules”:[]},{“id”:12,”channel”:”sss”,”updateBy”:8888,”updateTime”:”2016年05月19日,13:09:53”,”configTvSchedules”:[{“id”:17,”tvProgram”:”111111”,”beginTime”:”19:00”,”endTime”:”19:00”,”configTvChannel”:null},{“id”:18,”tvProgram”:”111111”,”beginTime”:”19:00”,”endTime”:”19:00”,”configTvChannel”:null}]},{“id”:13,”channel”:”wqsdw”,”updateBy”:8888,”updateTime”:”2016年05月19日,13:46:15”,”configTvSchedules”:[]}]

这里写代码片

这里写图片描述

版权声明:本文为博主原创文章,未经博主允许不得转载。

Hibernate关系映射(四)一对多单向关联@OneToMany Annotation方式

本篇介绍一对多单向关联,实例还是和Hibernate关系映射(三)多对一单向关联中的例子一样,一个车主(Owner)可以有多辆车,一辆车(Car)只能有一个车主,下面是表结构: 表结构和多对一的...
  • MurcielagoAN
  • MurcielagoAN
  • 2015年02月27日 15:03
  • 2739

Hibernate 注解:一、多对多中set集合按指定字段排序

最简单的方法是在配置文件中设置,利用配置文件中的order-by 属性来处理 ...
  • sunshine_love
  • sunshine_love
  • 2013年01月09日 18:59
  • 3371

Hibernate基础之九:多对多,单/双向关联 @ManyToOne @OneToMany

1.组件映射,一个类中包含另一个 组件上@Eembeded 2.多对一,单向关联 “多的”聚合“一的”1个实例, Group--User user的getGroup上加@ManyToOne ...
  • bestcxx
  • bestcxx
  • 2016年06月27日 10:40
  • 801

hibernate 注解方式配置OneToMany(一对多)连接查询(非外键)

场景描述: - 2张表,班级表class_a,对应实体ClassBean,字段:id, name, location . - 学生表student, 对应实体Student,字段:id, cl...
  • PKWind
  • PKWind
  • 2015年11月10日 11:32
  • 5138

MyBatis框架基于Annotation注解的一对多关联映射

代码: mybatis-config.xml ...
  • linhaiyun_ytdx
  • linhaiyun_ytdx
  • 2017年04月01日 20:43
  • 2174

JPA 一对多 OneToMany 注解

Cascade 级联操作 CascadeType. PERSIST 级联持久化 ( 保存 ) 操作 CascadeType. MERGE 级联更新 ( 合并 ) 操作 CascadeTyp...
  • xxfigo
  • xxfigo
  • 2017年06月27日 13:30
  • 2450

@ManyToOne注解 与 @OneToMany

@ManyToOne注解的这端,是多端 1.在注释@ManyToOne(cascade=CascadeType.REFRESH,optional=true)中将属性optional设置为true...
  • kang649882
  • kang649882
  • 2015年04月25日 13:52
  • 624

hibernate(八)注解基础、注解映射表、注解多表操作多对一和一对多

注解基础、注解映射表、注解多表操作多对一和一对多
  • qi325
  • qi325
  • 2017年08月16日 13:53
  • 600

双向一对多(多对一)@OneToMany或@ManyToOne的用法

例如我们用一个例子来开启JPA的一对多和多对一的学习。   比如你去当当网上买书籍,当当网就给你一个订单。   通过上面的业务活动描述你可以分析得出:一个订单可以包含一个或多个订单项.那么我们...
  • Fasure_Smile
  • Fasure_Smile
  • 2016年11月07日 16:41
  • 1797

Java - @OneToMany注解的mappedBy属性有什么作用?

@OneToMany用来配置一对多关联映射,但通常情况下,一对多关联映射都由多的一方来维护关联关系,例如学生和班级,应该在学生类中添加班级属性来维持学生和班级的关联关系(在数据库中是由学生表中的外键班...
  • chimomo
  • chimomo
  • 2017年11月08日 10:01
  • 209
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:java注解一对多@OneToMany
举报原因:
原因补充:

(最多只允许输入30个字)