基于Hibernate实现CRUD

这段代码展示了如何在Java中使用Hibernate框架进行基本的数据操作,包括保存、更新、查询和删除Person对象。通过配置文件加载SessionFactory,然后在测试方法中打开Session,开始事务,执行CRUD操作,并提交事务来确保数据持久化。
摘要由CSDN通过智能技术生成

java实现代码:

public class PersonTest {
	private static SessionFactory sessionFactory;
	static{
		Configuration configuration = new Configuration();
		//加载配置文件
		configuration.configure();
		//采用了工厂模式创建sessionFactory,
		//该类是hibernate中比较重要的一个类
		sessionFactory = configuration.buildSessionFactory();
	}
	
	@Test
	public void testSavePerson(){
 
		Session session = sessionFactory.openSession();
		//hibernate中默认事务不是自动提交的,
		//所以要先创建时候之后的修改操作才会生效
		Transaction transaction = session.beginTransaction();
		Person person = new Person();
		//由于在映射文件中已经说明主键的产生方式是hibernate内部产生,所以在程序中不用设置主键
		person.setPname("aa");
		person.setPsex("男");
		session.save(person);
		//提交事务
		transaction.commit();
		session.close();
	}
	/**
	 * 1、必须从数据库中提取出数据再进行修改
	 * 2、session.get方法创建的对象利用的是默认的构造函数
	 */
	@Test
	public void testUpdatePerson(){
		Session session = sessionFactory.openSession();
		Transaction transaction = session.beginTransaction();
		/**
		 * 1、先把修改的那行提取出来
		 * 说明:
		 * 		Serializable是String和包装类的共同的父类   
		 */
		Person person = (Person)session.get(Person.class,1L);
		//将性别该为不想
		person.setPsex("不详");
		session.update(person);
		transaction.commit();
		session.close();
	}
	
	@Test
	public void testQuery(){
		Session session = sessionFactory.openSession();
		List<Person> personList = session.createQuery("from Person").list();
		System.out.println(personList.size());
	}
 
	@Test
	public void testDelete(){
		Session session = sessionFactory.openSession();
		Transaction transaction = session.beginTransaction();
		Person person = (Person)session.get(Person.class, 1L);
		session.delete(person);
		transaction.commit();
		session.close();
	}
}

 

好的,以下是基于 Hibernate 框架创建 Student 类实现 CRUD: 1. 首先创建一个 Student 类,包含 id、name 和 age 三个属性,并在类上添加 `@Entity` 注解,用于将该类映射为数据库表。 ```java @Entity public class Student { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private int id; private String name; private int age; // 构造方法、getter 和 setter 方法省略 } ``` 2. 在 `hibernate.cfg.xml` 配置文件中配置数据库连接信息和 Hibernate 相关属性。 ```xml <hibernate-configuration> <session-factory> <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property> <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/testdb</property> <property name="hibernate.connection.username">root</property> <property name="hibernate.connection.password">password</property> <property name="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property> <property name="hibernate.show_sql">true</property> <property name="hibernate.hbm2ddl.auto">update</property> </session-factory> </hibernate-configuration> ``` 3. 创建一个 DAO(数据访问对象)类,用于对 Student 对象进行 CRUD 操作。在该类中通过 `SessionFactory` 获取 `Session` 对象,然后通过 `Session` 对象进行数据库操作。 ```java public class StudentDAO { private final SessionFactory sessionFactory; public StudentDAO(SessionFactory sessionFactory) { this.sessionFactory = sessionFactory; } public void save(Student student) { Session session = sessionFactory.openSession(); Transaction transaction = null; try { transaction = session.beginTransaction(); session.save(student); transaction.commit(); } catch (Exception e) { if (transaction != null) { transaction.rollback(); } e.printStackTrace(); } finally { session.close(); } } public Student get(int id) { Session session = sessionFactory.openSession(); Student student = null; try { student = session.get(Student.class, id); } catch (Exception e) { e.printStackTrace(); } finally { session.close(); } return student; } public void update(Student student) { Session session = sessionFactory.openSession(); Transaction transaction = null; try { transaction = session.beginTransaction(); session.update(student); transaction.commit(); } catch (Exception e) { if (transaction != null) { transaction.rollback(); } e.printStackTrace(); } finally { session.close(); } } public void delete(int id) { Session session = sessionFactory.openSession(); Transaction transaction = null; try { transaction = session.beginTransaction(); Student student = session.get(Student.class, id); session.delete(student); transaction.commit(); } catch (Exception e) { if (transaction != null) { transaction.rollback(); } e.printStackTrace(); } finally { session.close(); } } } ``` 4. 在应用程序中使用 StudentDAO 类进行 CRUD 操作。 ```java public class Application { public static void main(String[] args) { Configuration configuration = new Configuration().configure(); SessionFactory sessionFactory = configuration.buildSessionFactory(); StudentDAO studentDAO = new StudentDAO(sessionFactory); // 创建 Student 对象并保存到数据库 Student student = new Student("Tom", 18); studentDAO.save(student); // 根据 id 获取 Student 对象并更新其 age 属性 student = studentDAO.get(1); student.setAge(19); studentDAO.update(student); // 根据 id 删除 Student 对象 studentDAO.delete(1); } } ``` 以上就是使用 Hibernate 框架创建 Student 类实现 CRUD 的过程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值