- 浏览: 277848 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
zhuzhuhenzhencheng:
密码是什么啊
Ext表格(Grid)上面的悬浮提示 -
鹿惊_:
确实如雪中送炭般温暖!
Ext扩展整理后吐血奉献 -
ortega1_2_3:
该版本貌似有bug,当sockIOPool的自平衡线程self ...
Java MemCached Window简单实现 -
q6952592:
好。解决了我的兼容模式下出现的问题。
Ext表格(Grid)上面的悬浮提示 -
fei33423:
请参考 fei33423的文章 java中直接调用groovy ...
Groovy应用(Java与Groovy间相互调用)
Category.java代码:
package com.jlee06.QL; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.Table; /** * @author JLee * 板块 */ @Entity @Table(name="Category") public class Category { private int id ; private String name ; @Id @GeneratedValue(strategy=GenerationType.AUTO) public int getId() { return id; } public void setId(int id) { this.id = id; } @Column(name="name") public String getName() { return name; } public void setName(String name) { this.name = name; } }
Msg.java代码:
package com.jlee06.QL; 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.JoinColumn; import javax.persistence.ManyToOne; import javax.persistence.Table; @Entity @Table(name="Msg") public class Msg { private int id ; private String cont ; private Topic topic ; @Id @GeneratedValue(strategy=GenerationType.AUTO) public int getId() { return id; } public void setId(int id) { this.id = id; } @Column(name="cont" , length=500) public String getCont() { return cont; } public void setCont(String cont) { this.cont = cont; } @ManyToOne(fetch=FetchType.LAZY) @JoinColumn(name="topicId") public Topic getTopic() { return topic; } public void setTopic(Topic topic) { this.topic = topic; } }
Topic.java代码:
package com.jlee06.QL; import java.util.Date; 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.JoinColumn; import javax.persistence.ManyToOne; import javax.persistence.NamedQueries; import javax.persistence.NamedQuery; import javax.persistence.Table; import javax.persistence.Temporal; import javax.persistence.TemporalType; /** * @author JLee * 主题 */ @Entity @Table(name="topic") @NamedQueries({ @NamedQuery(name="Topic.selectTopic" , query="from Topic t where t.id = :id ") , @NamedQuery(name="Topic.conditionTopic" , query="from Topic t where t.title like :title ") }) //hibernate3.3.2尚未支持 //@NamedNativeQueries({ // @NamedNativeQuery(name="native_sql_page" , query="select * from topic limit 2,5") //}) public class Topic { private int id ; private String title ; private Date createDate ; public Date getCreateDate() { return createDate; } @Column(name="createDate") @Temporal(TemporalType.DATE) public void setCreateDate(Date createDate) { this.createDate = createDate; } private Category category ; @Id @GeneratedValue(strategy=GenerationType.AUTO) public int getId() { return id; } public void setId(int id) { this.id = id; } @Column(name="title" , length=32) public String getTitle() { return title; } public void setTitle(String title) { this.title = title; } @ManyToOne(fetch=FetchType.LAZY) @JoinColumn(name="categoryId") public Category getCategory() { return category; } public void setCategory(Category category) { this.category = category; } }
MsgInfo.java代码:
package com.jlee06.QL; /** * VO Value Object * @author JLee * 查询使用的 值对象 */ public class MsgInfo { private int id ; private String cont ; private String topicName ; private String categoryName ; public MsgInfo(int id, String cont, String topicName, String categoryName) { super(); this.id = id; this.cont = cont; this.topicName = topicName; this.categoryName = categoryName; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getCont() { return cont; } public void setCont(String cont) { this.cont = cont; } public String getTopicName() { return topicName; } public void setTopicName(String topicName) { this.topicName = topicName; } public String getCategoryName() { return categoryName; } public void setCategoryName(String categoryName) { this.categoryName = categoryName; } }
DataBase.java代码:
package com.jlee06.QL; import java.util.Date; import java.util.List; import org.hibernate.Query; import org.hibernate.SQLQuery; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.cfg.AnnotationConfiguration; import org.hibernate.tool.hbm2ddl.SchemaExport; import org.junit.AfterClass; import org.junit.BeforeClass; import org.junit.Test; public class DataBase { private static SessionFactory sf ; @BeforeClass public static void beforeClass(){ sf = new AnnotationConfiguration().configure().buildSessionFactory() ; } //@AfterClass //public void afterClass(){ // sf.close() ; //} @Test public void testSave() { Session session = sf.getCurrentSession() ; session.beginTransaction(); for(int i=0; i<10; i++) { Category c = new Category(); c.setName("c" + i); session.save(c); } for(int i=0; i<10; i++) { Category c = new Category(); c.setId(1); Topic t = new Topic(); t.setCategory(c); t.setTitle("t" + i); t.setCreateDate(new Date()); session.save(t); } for(int i=0; i<10; i++) { Topic t = new Topic(); t.setId(1); Msg m = new Msg(); m.setCont("m" + i); m.setTopic(t); session.save(m); } session.getTransaction().commit(); } /** * HQL面向对象查询语句 * SQL语句 * select category0_.id as id0_, category0_.name as name0_ from Category category0_ */ @Test public void testHQL_01(){ Session session = sf.openSession() ; session.beginTransaction() ; Query q = session.createQuery("from Category") ; List<Category> categorys = (List<Category>)q.list() ; for(Category c : categorys){ System.out.println(c.getName()); } session.getTransaction().commit() ; session.close() ; } /** * 设置 Where 条件语句 * SQL 语句 * select category0_.id as id0_, category0_.name as name0_ from Category category0_ where category0_.name>'c5' */ @Test public void testHQL_02(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Category c where c.name > 'c5' ") ; List<Category> categorys = (List<Category>)q.list() ; for(Category c : categorys){ System.out.println(c.getName()); } session.getTransaction().commit() ; } /** * 使用 order by 排序语句 * SQL 语句 * select category0_.id as id0_, category0_.name as name0_ from Category category0_ order by category0_.name desc */ @Test public void testHQL_03(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Category c order by c.name desc ") ; List<Category> categorys = (List<Category>)q.list() ; for(Category c : categorys){ System.out.println(c.getName()); } session.getTransaction().commit() ; } /** * 使用 distinct * SQL语句 * select distinct category0_.id as id0_, category0_.name as name0_ from Category category0_ order by category0_.name desc */ @Test public void testHQL_04(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("select distinct c from Category c order by c.name desc ") ; List<Category> categorys = (List<Category>)q.list() ; for(Category c : categorys){ System.out.println(c.getName()); } session.getTransaction().commit() ; } /** * 在SQL语句中设置参数1 * select category0_.id as id0_, category0_.name as name0_ from Category category0_ where category0_.id>? and category0_.id<? * 分开设置参数 */ @Test public void testHQL_05(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Category c where c.id > :min and c.id < :max ") ; q.setParameter("min", 2) ; q.setParameter("max", 5) ; List<Category> categorys = (List<Category>)q.list() ; for(Category c : categorys){ System.out.println(c.getId()+" "+c.getName()); } session.getTransaction().commit() ; } /** * 在SQL语句中设置参数2 * select category0_.id as id0_, category0_.name as name0_ from Category category0_ where category0_.id>? and category0_.id<? * 级联设置参数 */ @Test public void testHQL_06(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Category c where c.id > :min and c.id < :max ") .setInteger("min", 2) .setInteger("max", 5) ; List<Category> categorys = (List<Category>)q.list() ; for(Category c : categorys){ System.out.println(c.getId()+" "+c.getName()); } session.getTransaction().commit() ; } /** * 查询结果 进行 分页 * SQL语句(MySQL分页语句) * select category0_.id as id0_, category0_.name as name0_ from Category category0_ order by category0_.name desc limit ?, ? */ @Test public void testHQL_07(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Category c order by c.name desc ") ; q.setMaxResults(5) ; q.setFirstResult(3) ; List<Category> categorys = (List<Category>)q.list() ; for(Category c : categorys){ System.out.println(c.getId()+" "+c.getName()); } session.getTransaction().commit() ; } /** * 查询指定字段 * SQL 语句 * select category0_.id as col_0_0_, category0_.name as col_1_0_ from Category category0_ where category0_.id>? and category0_.id<? * 查询结果为 数组 * @return Object[] */ @Test public void testHQL_08(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("select c.id , c.name from Category c where c.id > :min and c.id < :max ") .setInteger("min", 2) .setInteger("max", 5) ; List<Object[]> categorys = (List<Object[]>)q.list() ; for(Object[] o : categorys){ System.out.println(o[0]+" "+o[1]); } session.getTransaction().commit() ; } /** * 两张表关联查询 * 设置 fetch type 为 lazy 后将不会有第二条SQL语句 * SQL语句: * 1.fetch=FetchType.LAZY * select topic0_.id as id2_, topic0_.categoryId as categoryId2_, topic0_.createDate as createDate2_, topic0_.title as title2_ from topic topic0_ where topic0_.categoryId=1 *2.fetch=FetchType.EAGER * select topic0_.id as id2_, topic0_.categoryId as categoryId2_, topic0_.createDate as createDate2_, topic0_.title as title2_ from topic topic0_ where topic0_.categoryId=1 * select category0_.id as id0_0_, category0_.name as name0_0_ from Category category0_ where category0_.id=? */ @Test public void testHQL_09(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Topic t where t.category .id = 1 ") ; List<Topic> topics = (List<Topic>)q.list() ; for(Topic t : topics){ System.out.println(t.getId()+" "+t.getTitle()); } session.getTransaction().commit() ; } /** * 多表关联查询 * fetch type * 1 LAZY SQL语句 * select msg0_.id as id1_, msg0_.cont as cont1_, msg0_.topicId as topicId1_ from Msg msg0_, topic topic1_ where msg0_.topicId=topic1_.id and topic1_.categoryId=1 * 2 EAGER SQL * select msg0_.id as id1_, msg0_.cont as cont1_, msg0_.topicId as topicId1_ from Msg msg0_, topic topic1_ where msg0_.topicId=topic1_.id and topic1_.categoryId=1 select topic0_.id as id2_1_, topic0_.categoryId as categoryId2_1_, topic0_.createDate as createDate2_1_, topic0_.title as title2_1_, category1_.id as id0_0_, category1_.name as name0_0_ from topic topic0_ left outer join Category category1_ on topic0_.categoryId=category1_.id where topic0_.id=? */ @Test public void testHQL_10(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Msg m where m.topic.category .id = 1 ") ; List<Msg> msgs = (List<Msg>)q.list() ; for(Msg m : msgs){ System.out.println(m.getId()+" "+m.getCont()); } session.getTransaction().commit() ; } /** * 自定义查询 赋予自定义的POJO * 使用自定义 Value Object * 临时对象VO一定要有 一个有参的构造方法 */ @Test public void testHQL_11(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("select new com.jlee06.QL.MsgInfo (m.id , m.cont , m.topic.title , m.topic.category.name ) from Msg m ") ; List<MsgInfo> msgInfos = (List<MsgInfo>)q.list() ; for(MsgInfo mi : msgInfos){ System.out.println(mi.getId()+" "+mi.getCategoryName()+" "+mi.getCont()+" "+mi.getTopicName()); } session.getTransaction().commit() ; } /** * 手动测试left right join * 为什么不能直接写Category名,而必须写t.category * 因为有可能存在多个成员变量(同一个类),需要指明用哪一个成员变量作为连接条件 */ @Test public void testHQL_12(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("select t.title , c.name from Topic t join t.category c ") ; List<Object[]> os = (List<Object[]>)q.list() ; for(Object[] o : os){ System.out.println(o[0]+" "+o[1]); } session.getTransaction().commit() ; } /** * 学习使用 uniqueResult * select msg0_.id as id1_, msg0_.cont as cont1_, msg0_.topicId as topicId1_ from Msg msg0_ where msg0_.id=? * 返回单独的唯一的结果 */ @Test public void testHQL_13(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Msg m where m= :msg ") ; Msg m = new Msg() ; m.setId(1) ; q.setParameter("msg", m) ; Msg mResult = (Msg)q.uniqueResult() ; System.out.println(mResult.getId()+" "+mResult.getCont()); session.getTransaction().commit() ; } /** * 集合函数 Count * SQL语句 * select count(*) as col_0_0_ from Msg msg0_ */ @Test public void testHQL_14(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("select count(*) from Msg m ") ; long count = (Long)q.uniqueResult() ; System.out.println(count); session.getTransaction().commit() ; } /** * 集合函数 max min avg sum * SQL语句 * select max(msg0_.id) as col_0_0_, min(msg0_.id) as col_1_0_, avg(msg0_.id) as col_2_0_, sum(msg0_.id) as col_3_0_ from Msg msg0_ */ @Test public void testHQL_15(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("select max(m.id) , min(m.id) , avg(m.id) , sum(m.id) from Msg m ") ; Object[] o = (Object[])q.uniqueResult() ; System.out.println(o[0] +" "+ o[1] +" "+ o[2] +" "+ o[3]); session.getTransaction().commit() ; } /** * between and * SQL语句 * select msg0_.id as id1_, msg0_.cont as cont1_, msg0_.topicId as topicId1_ from Msg msg0_ where msg0_.id between 3 and 8 */ @Test public void testHQL_16(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Msg m Where m.id between 3 and 8 ") ; for(Object o : q.list() ){ Msg m = (Msg)o ; System.out.println(m.getId()+" "+m.getCont()); } session.getTransaction().commit() ; } /** * in * SQL 语句 * select msg0_.id as id1_, msg0_.cont as cont1_, msg0_.topicId as topicId1_ from Msg msg0_ where msg0_.id in ( 3 , 4 , 5 , 6 ) */ @Test public void testHQL_17(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Msg m Where m.id in (3,4,5,6) ") ; for(Object o : q.list() ){ Msg m = (Msg)o ; System.out.println(m.getId()+" "+m.getCont()); } session.getTransaction().commit() ; } /** * is null 和 is not null * select msg0_.id as id1_, msg0_.cont as cont1_, msg0_.topicId as topicId1_ from Msg msg0_ where msg0_.cont is not null */ @Test public void testHQL_18(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Msg m Where m.cont is not null ") ; for(Object o : q.list() ){ Msg m = (Msg)o ; System.out.println(m.getId()+" "+m.getCont()); } session.getTransaction().commit() ; } /** * is empty * SQL 语句 * */ @Test public void testHQL_19(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Topic t where t.msgs is empty ") ; for(Object o : q.list() ){ Topic t = (Topic)o ; System.out.println(t.getId()+" "+t.getTitle()); } session.getTransaction().commit() ; } /** * like 的使用 *SQL语句 * select topic0_.id as id2_, topic0_.categoryId as categoryId2_, topic0_.createDate as createDate2_, topic0_.title as title2_ from topic topic0_ where topic0_.title like '%5' */ @Test public void testHQL_20(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Topic t where t.title like '%5' ") ; for(Object o : q.list() ){ Topic t = (Topic)o ; System.out.println(t.getId()+" "+t.getTitle()); } session.getTransaction().commit() ; } /** * 函数的使用1 * lower , upper , trim , concat , length * SQL语句 * select lower(topic0_.title) as col_0_0_, upper(topic0_.title) as col_1_0_, trim(topic0_.title) as col_2_0_, concat(topic0_.title, '*****') as col_3_0_, length(topic0_.title) as col_4_0_ from topic topic0_ */ @Test public void testHQL_21(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("select " + " lower(t.title) ," + " upper(t.title) ," + " trim(t.title) ," + " concat(t.title , '*****') , " + " length(t.title)" + " from Topic t ") ; for(Object os : q.list() ){ Object[] o = (Object[])os ; System.out.println(o[0] +" "+ o[1] +" "+ o[2] +" "+ o[3] +" "+ o[4]); } session.getTransaction().commit() ; } /** * 函数的使用2 * abs , sqrt , mod * SQL 语句 * select abs(topic0_.id) as col_0_0_, sqrt(topic0_.id) as col_1_0_, mod(topic0_.id, 2) as col_2_0_ from topic topic0_ */ @Test public void testHQL_22(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("select " + " abs(t.id) ," + " sqrt(t.id) ," + " mod(t.id , 2) " + " from Topic t ") ; for(Object os : q.list() ){ Object[] o = (Object[])os ; System.out.println(o[0] +" "+ o[1] +" "+ o[2] ); } session.getTransaction().commit() ; } /** * 时间函数的应用 * SQL 语句 * select current_date as col_0_0_, current_time as col_1_0_, current_timestamp as col_2_0_, topic0_.id as col_3_0_ from topic topic0_ */ @Test public void testHQL_24(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("select current_date , current_time , current_timestamp , t.id from Topic t ") ; for(Object os : q.list() ){ Object[] o = (Object[])os ; System.out.println(o[0] +" "+ o[1] +" "+ o[2] +" "+o[3]); } session.getTransaction().commit() ; } /** * 日期的比较 * SQL语句 * select topic0_.id as id2_, topic0_.categoryId as categoryId2_, topic0_.createDate as createDate2_, topic0_.title as title2_ from topic topic0_ where topic0_.createDate<? */ @Test public void testHQL_25(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Topic t Where t.createDate < :date ") ; q.setParameter("date", new Date()) ; for(Object o : q.list() ){ Topic t = (Topic)o ; System.out.println(t.getId()+" "+t.getCreateDate()); } session.getTransaction().commit() ; } /** * group by 语句 * SQL 语句 * select topic0_.title as col_0_0_, count(*) as col_1_0_ from topic topic0_ group by topic0_.title */ @Test public void testHQL_26(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("select t.title , count(*) from Topic t group by t.title ") ; for(Object o : q.list() ){ Object[] arr = (Object[])o ; System.out.println(arr[0]+" "+arr[1]); } session.getTransaction().commit() ; } /** * group by having 语句 * group by 里面出现的 字段 必须出现在 select 里面 * having 中的条件必须是 组合函数 * SQL 语句 * select topic0_.title as col_0_0_, count(*) as col_1_0_ from topic topic0_ group by topic0_.title having count(*)>0 */ @Test public void testHQL_27(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("select t.title , count(*) from Topic t group by t.title having count(*) > 0 ") ; for(Object o : q.list() ){ Object[] arr = (Object[])o ; System.out.println(arr[0]+" "+arr[1]); } session.getTransaction().commit() ; } /** * 子查询 * SQL 语句 * select topic0_.id as id2_, topic0_.categoryId as categoryId2_, topic0_.createDate as createDate2_, topic0_.title as title2_ from topic topic0_ where topic0_.id<( select avg(topic1_.id) from topic topic1_ ) */ @Test public void testHQL_28(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Topic t where t.id < (select avg(t.id) from Topic t ) ") ; for(Object o : q.list() ){ Topic t = (Topic)o ; System.out.println(t.getId() +" "+t.getCreateDate()); } session.getTransaction().commit() ; } /** * All 函数的使用 * SQL 语句 * select topic0_.id as id2_, topic0_.categoryId as categoryId2_, topic0_.createDate as createDate2_, topic0_.title as title2_ from topic topic0_ where topic0_.id<all ( select topic1_.id from topic topic1_ where mod(topic1_.id, 2)=0 ) */ @Test public void testHQL_29(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Topic t where t.id < ALL (select t.id from Topic t where mod(t.id , 2) = 0 ) ") ; for(Object o : q.list() ){ Topic t = (Topic)o ; System.out.println(t.getId() +" "+t.getCreateDate()); } session.getTransaction().commit() ; } /** * exists 和 not exists * 说明: 用 in 可以实现 exists 的功能 * 但是exists的效率高 * SQL 语句 * select topic0_.id as id2_, topic0_.categoryId as categoryId2_, topic0_.createDate as createDate2_, topic0_.title as title2_ from topic topic0_ where not (exists (select msg1_.id from Msg msg1_ where msg1_.topicId=topic0_.id)) */ @Test public void testHQL_30(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Topic t where not exists (select m.id from Msg m where m.topic.id = t.id ) ") ; // Query q = session.createQuery("from Topic t where exists (select m.id from Msg m where m.topic.id = t.id ) ") ; for(Object o : q.list() ){ Topic t = (Topic)o ; System.out.println(t.getId() +" "+t.getCreateDate()); } session.getTransaction().commit() ; } /** * update delete * SQL 语句 * update topic set title=upper(title) */ @Test public void testHQL_31(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("update Topic t set t.title = upper(t.title) ") ; q.executeUpdate() ; q = session.createQuery("from Topic "); for(Object o : q.list()){ Topic t = (Topic) o ; System.out.println(t.getTitle()); } session.createQuery("update Topic t set t.title = lower(t.title) ") .executeUpdate() ; session.getTransaction().commit() ; } /** * 命名查询 * 实现 按名字查找的自定义查询 * 在 Entity 上面自定义好 SQL 语句 * SQL 语句 * select topic0_.id as id2_, topic0_.categoryId as categoryId2_, topic0_.createDate as createDate2_, topic0_.title as title2_ from topic topic0_ where topic0_.id=? */ @Test public void testHQL_32(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; // Query q = session.getNamedQuery("Topic.selectTopic") ; // q.setParameter("id", 5) ; // Topic t = (Topic)q.uniqueResult() ; // System.out.println(t.getId()+" "+t.getCreateDate()); Query q = session.getNamedQuery("Topic.conditionTopic") ; q.setParameter("title", "%") ; for(Object o : q.list()){ Topic t = (Topic)o ; System.out.println(t.getId()+" "+t.getCreateDate()); } // Query q = session.getNamedQuery("native_sql_page") ; // for(Object o : q.list()){ // Topic t = (Topic)o ; // System.out.println(t.getId()+" "+t.getCreateDate()); // } session.getTransaction().commit() ; } /** * 原生SQL查询 * Hibernate使用SQL语句 * SQL语句 * select * from category limit 2, 6 */ @Test public void testHQL_33(){ Session session = sf.getCurrentSession() ; session.getTransaction().begin() ; SQLQuery q = session.createSQLQuery("select * from category limit 2,6").addEntity(Category.class); List<Category> categorys = (List<Category>)q.list() ; for(Category c : categorys){ System.out.println(c.getId()+" "+c.getName()); } session.getTransaction().commit() ; } /** * 实现数据分也显示 * SQL语句 * select topic0_.id as id2_, topic0_.categoryId as categoryId2_, topic0_.createDate as createDate2_, topic0_.title as title2_ from topic topic0_ where not (exists (select msg1_.id from Msg msg1_ where msg1_.topicId=topic0_.id)) limit ?, ? */ @Test public void testHQL_34(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; Query q = session.createQuery("from Topic t where not exists (select m.id from Msg m where m.topic.id = t.id ) ") ; // Query q = session.createQuery("from Topic t where exists (select m.id from Msg m where m.topic.id = t.id ) ") ; q.setFirstResult(10).setMaxResults(20) ; for(Object o : q.list() ){ Topic t = (Topic)o ; System.out.println(t.getId() +" "+t.getCreateDate()); } session.getTransaction().commit() ; } /** * 根据日期时间进行查询 * SQL语句: * select topic0_.id as id2_, topic0_.categoryId as categoryId2_, topic0_.createDate as createDate2_, topic0_.title as title2_ from topic topic0_ where topic0_.createDate=? limit ? */ @Test public void testHQL_35(){ Session session = sf.getCurrentSession() ; session.beginTransaction() ; /** * 这种方式适用于 datetime 和 date 的两种字段格式 */ String today = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()); Query q = session.createQuery("from Topic t where t.createDate = :today ") ; try { q.setDate("today", new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse(today)) ; } catch (ParseException e) { e.printStackTrace(); } /** * 这种方式适只用于 datetime 的字段格式 */ // Query q = session.createQuery("from Topic t where t.createDate between ? and ? ") ; // SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); // try { // q.setParameter(0, sdf.parse("2011-02-12 00:00:00")) ; // q.setParameter(1, sdf.parse("2011-02-12 23:59:59")); // } catch (Exception e) { // e.printStackTrace(); // } q.setFirstResult(0).setMaxResults(20) ; for(Object o : q.list() ){ Topic t = (Topic)o ; System.out.println(t.getId() +" "+t.getCreateDate()); } session.getTransaction().commit() ; } @Test public void testSchemaExport(){ new SchemaExport(new AnnotationConfiguration().configure()).create(false, true); } }
hibernate.cfg.xml文件:
<?xml version='1.0' encoding='utf-8'?> <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <session-factory> <!-- Database connection settings --> <property name="connection.driver_class">com.mysql.jdbc.Driver</property> <property name="connection.url">jdbc:mysql://localhost/hibernate</property> <property name="connection.username">root</property> <property name="connection.password">root</property> <!-- JDBC connection pool (use the built-in) --> <property name="connection.pool_size">100</property> <!-- SQL dialect --> <property name="dialect">org.hibernate.dialect.MySQLDialect</property> <!-- Enable Hibernate's automatic session context management --> <property name="current_session_context_class">thread</property> <!-- Disable the second-level cache --> <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property> <!-- Echo all executed SQL to stdout --> <property name="show_sql">true</property> <property name="format_sql">true</property> <!-- Drop and re-create the database schema on startup --> <!--<property name="hbm2ddl.auto">create</property>--> <mapping class="com.jlee06.QL.Category"/> <mapping class="com.jlee06.QL.Msg"/> <mapping class="com.jlee06.QL.Topic"/> </session-factory> </hibernate-configuration>
发表评论
-
关于Hibernate动态添加与修改
2011-02-18 21:39 1288定义实体 package com.jlee06.QL;imp ... -
搭建Hibernate Annotation工程
2011-02-17 00:29 1422首先从Hibernate官方网站 ... -
Hibernate对JPA的扩展
2011-02-17 00:21 4715Hibernate 3.1 提供了多种 ... -
数据库分页语句
2011-02-11 14:43 806Oracle 数据库分页 三层嵌套: select ... -
Hibernate 使用 Annotation 7(缓存的使用)
2011-02-11 09:03 1258Category.java代码: package com.j ... -
Hibernate 使用 Annotation 5(一对多双向关联)
2011-02-11 08:54 1235Group.java代码: package com.jlee ... -
Hibernate 使用 Annotation 4(一对多单向关联)
2011-02-11 08:50 1725Group.java代码: package com.jlee ... -
Hibernate 使用 Annotation 4(多对一单向关联)
2011-02-11 00:10 1649Group.java代码: package com.jlee ... -
Hibernate 使用 Annotation 3(联合主键)
2011-02-11 00:04 9073Hibernate Annotation 联合主键有三种写法 ... -
Hibernate 使用 Annotation 2(主键生成方式)
2011-02-10 23:47 1008hibernate.cfg.xml配置文件: <?xm ... -
Hibernate 注解概述
2011-02-10 23:34 1762Hibernate 注解 定义在 cla ... -
Hibernate 使用 Annotation 1(测试)
2011-02-10 23:33 835Hello World 程序 hibernate.cf ... -
HIbernate中SQLServer2000与2005的配置
2010-11-16 18:50 1007<?xml version='1.0' encoding ... -
Hibernate细粒度划分与复合主键
2010-11-12 22:55 794细粒度划分 Person.hbm.xml配置文件 < ...
相关推荐
在Java开发中,Hibernate与Annotation的结合使用极大地简化了数据持久化的复杂性,使得开发人员无需编写大量的SQL代码。下面将详细介绍Hibernate-Annotation所涉及到的知识点。 1. **Hibernate框架**: Hibernate是...
JPA的动态查询,可以直接在注解中编写HQL或JPQL查询语句。 六、事务管理注解 1. `@Transactional` 标记在方法上,表示该方法需要在数据库事务中执行。 七、缓存注解 1. `@Cacheable` 表示实体类或特定方法的...
《Hibernate-Annotation-3.4.0帮助文档》是一份详尽的指南,旨在帮助开发者理解和使用Hibernate ORM框架中的注解功能。Hibernate是Java领域中广泛使用的对象关系映射(ORM)工具,它极大地简化了数据库操作。在3.4.0...
Hibernate Annotation库是Java开发中用于简化对象关系映射(ORM)的一个重要组件,它使得开发者能够在Java类上直接使用注解来定义数据库映射,从而避免了传统的XML配置文件。这三个特定的jar包是Hibernate ORM框架中...
《Hibernate Annotations中文帮助文档》是针对Java开发人员的一份详细指南,主要讲解如何使用Hibernate ORM框架中的注解来实现数据库对象的映射。该文档涵盖了从基础到高级的各种概念,帮助开发者更高效地管理和操作...
通过这些课程,你可以系统地学习Hibernate Annotation,逐步掌握如何在实际项目中使用它来实现高效、灵活的数据存储和检索。在实践中不断探索和实践,将有助于你成为一名精通Hibernate的开发者。
【标题】:“Hibernate Annotation JAR” 【描述】:“Hibernate 3.3 Annotation JAR”指的是Hibernate框架的一个特定版本,即3.3版本中用于对象关系映射(ORM)的注解库。Hibernate是一个广泛使用的Java库,它允许...
本文档详细介绍了Hibernate_Annotation的相关知识点,包括实体Bean的基本定义、各种关联关系的映射方法以及查询语言的应用等。此外,还涉及了XML配置文件的使用和Hibernate工具的介绍,以及如何将Hibernate与Lucene...
Hibernate Criteria API提供了注解方式的查询,如`@NamedQuery`和`@NamedNativeQuery`,允许开发者定义预编译的查询语句,提高性能。 6. **优势** - 简洁性:注解使得ORM配置直接嵌入到Java代码中,减少XML配置...
总结来说,这个 "Spring Hibernate Annotation demo" 展示了如何在 Spring 框架中使用注解配置来管理依赖,以及如何利用 Hibernate 的注解进行数据持久化。同时,它还涉及到了 Flex 前端与后端的交互。通过学习这个 ...
- **JP-QL/HQL 查询映射**:通过 `@NamedQuery` 注解定义命名查询,使用 JP-QL 或 HQL 语言编写查询语句。 - **原生 SQL 查询映射**:使用 `@SQL` 注解来定义原生 SQL 查询,并通过 `@Result` 和 `@Results` 注解来...
本篇文章将围绕"hibernate-annotation3.4.0 + hibernate-distribution3.3.2 + slf4j-1.5.8.rar"这个压缩包中的内容,深入探讨这两个框架的使用及其版本间的差异,以及Slf4j日志框架的集成。 首先,Hibernate是Java...
根据给定文件的信息,本文将详细介绍Hibernate ORM(Object Relational Mapping)中关于不同类型的关联映射方式,并结合Annotation和XML两种配置方式来进行说明。 ### 一、一对一单向外键关联 在一对一单向外键...
Hibernate是Java领域中最知名的ORM框架之一,它允许开发者使用面向对象的编程方式来操作数据库,而无需编写繁琐的SQL语句。Hibernate通过映射对象到数据库表,实现了数据的透明访问。在"hibernate_annotation"这个...
在Java世界中,Hibernate是一个非常流行的ORM(对象关系映射)框架,它允许开发人员使用面向对象的编程方式来操作数据库,而无需直接编写SQL语句。这个标题暗示我们将讨论如何在项目中首次引入Hibernate,并使用注解...
Hibernate Annotation几种关联映射 一对一(One-To-One) 使用@OneToOne注解建立实体Bean之间的一对一关联。一对一关联有三种情况:(1).关联的实体都共享同样的主键,(2).其中一个实体通过外键关联到另一个实体的主键...
《使用Hibernate和XDoclet生成映射文件与SQL语句详解》 在Java开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。然而,为了实现对象与数据库表之间的映射,我们需要编写XML映射...
除了XML配置文件,还可以使用注解(Annotation)来管理查询语句。例如,可以直接在Entity类上使用`@NamedQuery`和`@NamedNativeQuery`注解来定义HQL和SQL查询,这种方式更具有代码内联性,但可能会增加实体类的复杂...
在这个特定的案例中,"Struts+Hibernate(annotation)"的组合被用来实现一个记事本功能,这涉及到前端交互、后端数据处理以及持久化层的设计。 Struts是一个基于MVC(Model-View-Controller)设计模式的开源框架,...
Hibernate则是一个强大的ORM框架,它允许开发者使用面向对象的方式来操作数据库,避免了繁琐的SQL语句编写。通过@Entity、@Table、@Id等注解,可以轻松地定义Java类与数据库表之间的映射关系。Hibernate支持懒加载、...