使用实体管理器查询日期

时间:2014-12-02 13:31:06

标签: java mysql hibernate date jpa

Backgound:我使用JPA(hibernate impl)+ spring 我有两个表,第一个是ok,它有一个主键,它甚至可以用于java.Util.Date字段。另一个在主键中有3个参数(这是我第一次使用它):

PRIMARY KEY (`id_room`,`id_hotel`,`day`),

完整架构:

CREATE TABLE `hotels` (
  `id_room` int(11) NOT NULL DEFAULT '0',
  `id_hotel` int(11) NOT NULL DEFAULT '0',
  `day` date NOT NULL,
  PRIMARY KEY (`id_room`,`id_hotel`,`day`),
  KEY `id_hotel` (`id_hotel`,`day`),
  KEY `day` (`day`),
  KEY `day-hotel` (`day`,`id_hotel`),
  KEY `hotel` (`id_hotel`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

所以我在我的实体中添加了代码:

@Entity @IdClass(HotelId.class)
@Table(name="hotels")
public class Hotels implements Serializable {
    private static final Long serialVersionUID = 1L;

    @Id
    @Column(name="id_room")
    private int roomId;
    @Id
    @Column(name="id_hotel")
    private int hotelId;
    @Id
    @Temporal(TemporalType.DATE)
    private Date day;
....

HotelId.class

public class HotelId implements Serializable {
    private int roomId;
    private int hotelId;
    private Date day;

    public HotelId() {
    }

    public HotelId(int roomId, int hotelId, Date day) {
        this.roomId = roomId;
        this.hotelId = hotelId;
        this.day = day;
    }

    public int getRoomId() {
        return roomId;
    }

    public int getHotelId() {
        return hotelId;
    }

    public Date getDay() {
        return day;
    }
}

这个实体我坚持了很长时间:

我今天几乎整天都在为这个问题而度过。 我有数据库,格式为日期列(yyyy-mm-dd)。 我在项目中也有java.util.Date日期字段的实体类。 现在我试图做出选择:

TypedQuery query = em.createQuery("Select h FROM Hotels h where h.roomId=:roomId and h.hotelId=:hotelId and h.day=:day", Hotels.class);
query.setParameter("roomId", roomId);
query.setParameter("hotelId", hotelId);
query.setParameter("day", date);

它说没有数据

现在我将日期字段从java.util.Date更改为String并更改我的查询:

TypedQuery query = em.createQuery("Select h FROM Hotels h where h.roomId=:roomId and h.hotelId=:hotelId and h.day=:day", Hotels.class);
query.setParameter("roomId", roomId);
query.setParameter("hotelId", hotelId);
query.setParameter("day", new SimpleDateFormat("yyyy-mm-dd").format(date));

找到数据。

问题是如何将日期(java.util.Date)发送到MySql DB并获取信息?

更新

它也不起作用

@Entity 
    @Table(name="hotels")
    public class Hotels implements Serializable {
        private static final Long serialVersionUID = 1L;

        @Id
        private int id;
        @Column(name="id_room")
        private int roomId;

        @Column(name="id_hotel")
        private int hotelId;

        private java.sql.Date day;
        ....
    }

查询:

    java.sql.Date sqlDate = new java.sql.Date(day.getTime());
    TypedQuery query = em.createQuery("Select h FROM Hotels h where h.roomId=:roomId and h.hotelId=:hotelId and h.day=:day", Hotels.class);
query.setParameter("roomId", roomId);
query.setParameter("hotelId", hotelId);
            query.setParameter("day", sqlDate);

1 个答案:

答案 0 :(得分:0)

如果您使用的是Java日期,则您的命名参数日设置为带有时间戳的日期。因此,为了确认这一点,启用hibernate日志来打印sql参数值

log4j.logger.org.hibernate.type =微量

参考:How to print a query string with parameter values when using Hibernate

您可以尝试使用以下查询: “选择h FROM Hotels h,其中h.roomId =:roomId和h.hotelId =:hotelId和h.day = DATE_FORMAT(:day,format)”

如果酒店表中有数百万条记录,使用DATE_FORMAT函数的缺点会在记录检索中出现性能损失。

因此,在java级别转换为字符串并在命名参数中设置相同是更好的选择。