Hibernate的数据操作(4.*以上版本)

Hibernate的基本数据操作 适用于4.* 。。sessionFactory的创建区别

public class NewsTest {
	private Session session = null;
	private SessionFactory sf = null;
	private Transaction ts = null;
	
	@Before
	public void init() {
		Configuration config = new Configuration();
		config.configure();
		ServiceRegistry sr = new StandardServiceRegistryBuilder().applySettings(config.getProperties()).build();
		sf = config.buildSessionFactory(sr);
		session = sf.openSession();
		ts = session.beginTransaction();

	}

	@After
	public void destroy() {
		ts.commit();
		session.close();
		sf.close();
	}

	@Test
	public void testGet() {
		News news = (News) session.get(News.class, 21);
		System.out.println(news);

	}
	@Test
	public void testSave(){
		News news = new News();
		news.setId(10);
		news.setContent("撒");
		news.setTitle("标题");
		news.setCreateDate(new Date());
		session.save(news);
	}
	@Test
	public void testHQL(){
//		String sql = "select new News(n.id, n.title) from News n order by n.id desc";
		String sql = "select  n.id, n.title from News n order by n.id desc";
		Query query = session.createQuery(sql);
		//query.setString("order", "'desc'");
		//query.setInteger(0, 43);
//		query.setParameter(1, 42);//org.hibernate.QueryParameterException: Position beyond number of declared ordinal parameters. Remember that ordinal parameters are 1-based! Position: 2
		
//		Criteria criteria = session.createCriteria(News.class);
//		criteria.add(Restrictions.eq("id", 1));
		
//		SQLQuery sqlQuery = session.createSQLQuery(queryString);
//		sqlQuery.addEntity(News.class);
		
		List<News> list = query.list();
		System.out.println(list);
		
//		List<Object[]> list = query.list();
//		for(Object[] news:list){
//			for(Object o : news){
//				System.out.println(o);
//			}
//		}
	}
	
	@Test
	public void testQueryPage(){
		//分页查询
		String sql = "from News ";
		Query query = session.createQuery(sql);
		int page = 2;
		int rows = 2;
		query.setFirstResult((page-1)*rows);//起始行
		query.setMaxResults(rows);//最大行数
		List<News> list = query.list();
		System.out.println(list);
	}
	@Test
	public void testManyToOne(){
		//数据操作
		Factory factory1 = new Factory("三星2");
		Factory factory2 = new Factory("谷歌");
		Product product1 = new Product("note3",1230,factory1);
		Product product2 = new Product("galaxy",2300,factory1);
		Product product3 = new Product("glass",1340,factory2);
		
		//如果工厂与产品保存顺序相反,则结束之后执行update操作
		session.save(factory1);
		session.save(factory2);
		session.save(product1);
		session.save(product2);
		session.save(product3);
	}
	
	@Test
	public void testGetManyToOne(){
		//多对一的关联操作
		Product product = (Product)session.get(Product.class, 4);
		System.out.println("Product name : "+product.getName());
		//懒加载,用到才查询
		System.out.println("Factory Name : "+product.getFactory().getName());
	}
	@Test
	public void testGetOneToMany(){
		//一对多的关联操作
		Factory factory = (Factory)session.get(Factory.class, 2);
		System.out.println("Product name : "+factory.getName());
		System.out.println("Product count : "+factory.getProducts().size());
	}
	@Test
	public void testDeleteOneToManyCascade(){
		Factory factory = (Factory)session.get(Factory.class, 6);
		session.delete(factory);
	}

}

  

posted @ 2016-01-23 11:22  WhyToHow  阅读(246)  评论(0编辑  收藏  举报