20160506-hibernate入门
public static void query(String name){
Session s=null;
try{
s=HibernateUntils.getSession();
String hql="from User as user where user.username=?";//from Object,查找的是对象
Query query=s.createQuery(hql);
query.setString(0, name);
List<User> list=query.list();
for(User user:list){
System.out.println(user.getBirthday());
}
}finally{
if(s!=null){
s.close();
}
}
}
/**
* 确定查询结果只有一条时
* @param name
*/
public static void uniqueQuery(String name){
Session s=null;
try{
s=HibernateUntils.getSession();
String hql="from User as user where user.username=?";//from Object,查找的是对象
Query query=s.createQuery(hql);
query.setString(0, name);
User u=(User) query.uniqueResult();
System.out.println(u.getBirthday());
}finally{
if(s!=null){
s.close();
}
}
}
/**
* 分页查询
* @param name
*/
public static void queryPage(String name){
Session s=null;
try{
s=HibernateUntils.getSession();
String hql="from User as user where user.username=:name";//from Object,查找的是对象
Query query=s.createQuery(hql);
query.setString("name", name);
query.setFirstResult(0);//第一条记录从哪一条开始去
query.setMaxResults(10);//取多少条
List<User> list=query.list();
for(User user:list){
System.out.println(user.getBirthday());
}
}finally{
if(s!=null){
s.close();
}
}
}
/**
* 条件查询
* @param name
*/
public static void cri(String name){
Session s=null;
try{
s=HibernateUntils.getSession();
Criteria c=s.createCriteria(User.class);
c.add(Restrictions.eq("username", name));//加入约束条件
List<User> list=c.list();
for(User user:list){
System.out.println(user.getBirthday());
}
}finally{
if(s!=null){
s.close();
}
}
}
小练习:
package com.dzq.domain; import java.io.Serializable;
import java.util.Date; public class User implements Serializable{
private int id;
private String username;
private String password;
private String mobile;
private Date regdate; public int getId() {
return id;
} public void setId(int id) {
this.id = id;
} public String getUsername() {
return username;
} public void setUsername(String username) {
this.username = username;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
} public String getMobile() {
return mobile;
} public void setMobile(String mobile) {
this.mobile = mobile;
} public Date getRegdate() {
return regdate;
} public void setRegdate(Date regdate) {
this.regdate = regdate;
} }
UserDao.java 接口
package com.dzq.dao;
import com.dzq.domain.User;
public interface UserDao {
/**
* 添加用户
*
* @param user
*/
void addUser(User user);
/**
* 修改用户
*
* @param user
*/
void updateUser(User user);
/**
* 删除用户
*
* @param user
*/
void deleteUser(User user);
/**
* 根据id查找用户
*
* @param id
*/
User findUserByID(int id);
/**
* 根据id删除用户
*
* @param id
*/
void deleteUserByID(int id);
/**
* 根据用户名查找用户
* @param username
*/
User findUserByUN(String username);
}
User.hbm.xml 实体配置
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.dzq.domain"> <class name="User" table="user">
<id name="id" column="id">
<generator class="native" />
</id>
<property name="username" column="username" />
<property name="password" column="password" />
<property name="mobile" column="mobile" />
<property name="regdate" column="regdate"/>
</class> </hibernate-mapping>
hibernate.cfg.xml 全局配置文件
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> <hibernate-configuration>
<session-factory>
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql:///test1</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password"></property>
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="hibernate.show_sql">true</property>
<mapping resource="com/dzq/domain/User.hbm.xml"/>
</session-factory> </hibernate-configuration>
HibernateUtils.java 工具类
package com.dzq.utils; import java.io.Serializable; import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration; public class HibernateUntils {
private static SessionFactory sessionFactory; private HibernateUntils() { } static {
Configuration cfg = new Configuration();
cfg.configure();//如果不是hibernate.cfg.xml这个文件名,需要加上文件名
sessionFactory = cfg.buildSessionFactory();
}
public static SessionFactory getSessionFactory(){
return sessionFactory;
}
public static Session getSession(){
return sessionFactory.openSession();
} /**
* 添加
* @param entity
*/
public static void add(Object entity) {
Session s = null;
Transaction tx = null;
try {
s = HibernateUntils.getSession();
tx = s.beginTransaction();
s.save(entity);
tx.commit();
} catch (Exception e) {
if (tx != null)
tx.rollback();
throw new RuntimeException(e);
} finally {
if (s != null) {
s.close();
}
}
}
/**
* 修改
* @param entity
*/
public static void update(Object entity) {
Session s = null;
Transaction tx = null;
try {
s = HibernateUntils.getSession();
tx = s.beginTransaction();
s.update(entity);
tx.commit();
} catch (Exception e) {
if (tx != null)
tx.rollback();
throw new RuntimeException(e);
} finally {
if (s != null) {
s.close();
}
}
} /**
* 删除
* @param entity
*/
public static void delete(Object entity) {
Session s = null;
Transaction tx = null;
try {
s = HibernateUntils.getSession();
tx = s.beginTransaction();
s.delete(entity);
tx.commit();
} catch (Exception e) {
if (tx != null)
tx.rollback();
throw new RuntimeException(e);
} finally {
if (s != null) {
s.close();
}
}
} /**
* 根据主键id查询
* @param clazz
* @param id
* @return
*/
public static Object get(Class clazz,Serializable id) {
Session s = null;
try {
s = HibernateUntils.getSession();
Object obj=s.get(clazz, id);
return obj;
} finally {
if (s != null) {
s.close();
}
}
}
}
UserDaoImpl.java 接口实现
package com.dzq.dao.impl; import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction; import com.dzq.dao.UserDao;
import com.dzq.domain.User;
import com.dzq.utils.HibernateUntils; public class UserDaoImpl implements UserDao { @Override
public void addUser(User user) {
HibernateUntils.add(user);
} @Override
public void updateUser(User user) {
HibernateUntils.update(user);
} @Override
public void deleteUser(User user) {
HibernateUntils.delete(user);
} @Override
public User findUserByID(int id) {
return (User) HibernateUntils.get(User.class, id);
} @Override
public void deleteUserByID(int id) {
Session s = null;
Transaction tx = null;
try {
s = HibernateUntils.getSession();
tx = s.beginTransaction();
String hql="delete User user where user.id=:id";
Query query=s.createQuery(hql);
query.setInteger("id", id);
query.executeUpdate();
tx.commit();
} catch (Exception e) {
if (tx != null)
tx.rollback();
throw new RuntimeException(e);
} finally {
if (s != null) {
s.close();
}
}
} @Override
public User findUserByUN(String username) {
Session s=null;
try{
s=HibernateUntils.getSession();
String hql="from User as user where user.username=:username";//from Object,查找的是对象
Query query=s.createQuery(hql);
query.setString("username", username);
User user=(User) query.uniqueResult();
return user;
}finally{
if(s!=null){
s.close();
}
}
} }
ProjectTest.java 下面为junit测试
package com.dzq.test; import java.util.Date; import org.junit.Test; import com.dzq.dao.impl.UserDaoImpl;
import com.dzq.domain.User; public class ProjectTest {
@Test
public void testAdd() {
UserDaoImpl dao = new UserDaoImpl();
User user = new User();
user.setUsername("xiaodu");
user.setPassword("hello");
user.setRegdate(new Date());
user.setMobile("15820090820");
dao.addUser(user);
} @Test
public void testUpdate() {
UserDaoImpl dao = new UserDaoImpl();
User user = new User();
user = dao.findUserByID(2);
user.setUsername("xiaohong");
dao.updateUser(user);
} @Test
public void testDelete(){
UserDaoImpl dao = new UserDaoImpl();
User user = new User();
user = dao.findUserByID(3);
dao.deleteUser(user);
}
@Test
public void testFindUser(){
UserDaoImpl dao = new UserDaoImpl();
User user = new User();
user=dao.findUserByUN("xiaohong");
System.out.println(user.getRegdate());
}
@Test
public void testDeleteByID(){
UserDaoImpl dao = new UserDaoImpl();
dao.deleteUserByID(2);
} }
20160506-hibernate入门的更多相关文章
- 三大框架之hibernate入门
hibernate入门 1.orm hibernate是一个经典的开源的orm[数据访问中间件]框架 ORM( Object Relation Mapping)对象关 ...
- Hibernate入门案例及增删改查
一.Hibernate入门案例剖析: ①创建实体类Student 并重写toString方法 public class Student { private Integer sid; private I ...
- Hibernate入门案例 增删改
一.Hibernate入门案例剖析: ①创建实体类Student 并重写toString方法 public class Student { private Integer sid; private I ...
- Hibernate入门6.Hibernate检索方式
Hibernate入门6.Hibernate检索方式 20131128 代码下载 链接: http://pan.baidu.com/s/1Ccuup 密码: vqlv Hibernate的整体框架已经 ...
- Hibernate入门5持久化对象关系和批量处理技术
Hibernate入门5持久化对象关系和批量处理技术 20131128 代码下载 链接: http://pan.baidu.com/s/1Ccuup 密码: vqlv 前言: 前面学习了Hiberna ...
- Hibernate入门4.核心技能
Hibernate入门4.核心技能 20131128 代码下载 链接: http://pan.baidu.com/s/1Ccuup 密码: vqlv 前言: 前面学习了Hibernate3的基本知识, ...
- Hibernate入门3.配置映射文件深入
Hibernate入门3.配置映射文件深入 2013.11.27 前言: 之前的两节是在Java项目中如何使用hibernate,并且通过一个简单地项目实践,期间有很多的错误,一般都是因为配置包的问题 ...
- 简单的Hibernate入门简介
其实Hibernate本身是个独立的框架,它不需要任何web server或application server的支持.然而,大多数的Hibernate入门介绍都加入了很多非Hibernate的东西, ...
- Hibernate入门(1)-第一个Hibernate程序
Hibernate入门(1)-第一个Hibernate程序 Hibernate是最著名的ORM工具之一,本系列文章主要学习Hibernate的用法,不涉及Hibernate的原理.本文介绍第一个Hib ...
- hibernate入门之person表
下面的hibernate入门person表指的是:根据mysql数据库中的test表和其中的元素-->建立映射表==>进而创建持久化类的顺序来操作了,下面为步骤 1.配置MySQL驱动程序 ...
随机推荐
- U盘安装CentOS 6.5注意事项
这两天新到一批机器,需要安装系统.买的机器没有光驱,只能使用U盘或者网络安装.为了方便,我使用UltraISO对U盘进行刻录制作了启动盘.一切都是那么顺利,安装完成了,没出现什么问题(毕竟 ...
- Codeforces Round #225 (Div. 2)
比赛时候只做出AB,E题一眼看过去似乎线段树能搞,但是写完过不了样例,才发现看错题了,然后比赛就没啥时间了~~整体状况还是很糟糕,A,B题实在出得太慢,然后持续到现在还没出过C题...不能更弱%> ...
- Android uiautomator实例使用
转载自:http://blog.csdn.net/huiguixian/article/details/22398193 Android测试工具中,Monkey Runner只要简单几个指令即可,但他 ...
- 问题-Tbutton(sender) 与 (sender as Tbutton) 等价吗?
问题:Tbutton(sender) 与 (sender as Tbutton) 等价吗? 答: 1. Sender As TButton时delphi做类型检查. 比如: var frm:TFo ...
- CALayer精讲
前言 CALayer包含在QuartzCore框架中,这是一个跨平台的框架,既可以用在iOS中又可以用在Mac OS X中.后面要学Core Animation就应该先学好Layer(层). 我们看一 ...
- ECSHOP在线手册布局参考图--通用活动页 group_list.dwt等
A.购物车 1,设置方法 程序自动读取购物车的商品数量 2,代码相关 cart.lbi 中 {insert_scripts files='transport.js'} <div clas ...
- ABAP ALV 颜色设置(行,列,单元格)
BCALV_EDIT_03 http://blog.sina.com.cn/s/blog_a87b19300102who3.html 关于ALV表格颜色,这种需求在项目中会经常用到. 列颜色 列的颜色 ...
- 在创建窗口句柄之前,不能在控件上调用 Invoke 或 BeginInvoke。
本文转载:http://blog.csdn.net/playing9c/article/details/7471918 http://blog.csdn.net/beelinkerlidejun/ar ...
- python 闭包(closure)
闭包的定义: 闭包就是一个函数,这个函数可以记住封闭作用域里的值,而不管封闭作用域是否还在内存中. 来一个例子: def happy_add(a): print 'id(a): %x' % id(a) ...
- Android在MediaMuxer和MediaCodec用例 - audio+video
在Android多媒体类,MediaMuxer和MediaCodec这是一个相对年轻,他们是JB 4.1和JB 4.3据介绍. 前者被用来产生一个混合的音频和视频的多媒体文件.的缺点是,现在可以只支持 ...