Hibernate简单模板代码~

hibernate概念:

hibernate是一个开放源代码的对象关系映射框架,封装了JDBC的持久化框架,是用来操作数据库的。它把数据库中的表,转换成java类,通过xml文件来实现类和表之间的映射。这样的好处在于,可以用面对对象的思想来操作数据库~,它可以自动生成SQL语句,自动执行。

下面是我写的模板:

先生成一个Student类;

package cn.edu.hpu.entity;


//生成一个Student类
public class Student {
	private String code;
	private String name;
	
	public Student() {
		super();
		// TODO Auto-generated constructor stub
	}
	@Override
	public String toString() {
		return "Student [code=" + code + ", name=" + name + "]";
	}
	public Student(String code,String name) {
		super();
		this.code = code;
		this.name = name;
	}
	
	public String getCode() {
		return code;
	}
	public void setCode(String code) {
		this.code = code;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	


}

然后在建一个Student类映射的XML文件,名字叫:Student.hbm.xml:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<!-- package 后面接的是对应的类的包名 -->
<hibernate-mapping package="cn.edu.hpu.entity">

<!-- class对应的是java代码中的类,那么后面加的就是类名,然后table后面的是java代码对应过去数据库的那个表名 -->
	<class name="Student" table="t_student">
	<!-- id是生成一个主键,name后面的是java中的属性名 column是对应的是数据库中的名-->
		<id name="code" column="XH">
		<!-- 下面这个是主键的生成策略 -->
			<generator class="assigned"></generator>
		</id>
		<!-- 下面这个是一般的属性,一个属性对应数据库表中的一列 -->
		<property name="name" column="XM"></property>
	</class>
</hibernate-mapping>

下面才是hibernate的主配置文件叫:hibernate.cfg.xml )(这地方的名字似乎是不能变的,只是听老师这么说,但是为什么不变却忘了~),注意:最后要把上面这个Student的配置文件一起加进来,整个程序才会自己跑起来!

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
	<session-factory>
	<!-- 前四步其实就是数据库连接四要素,和JDBC连接数据库相似(可以说就是照着那个直接过来的) -->
		<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
		<property name="hibernate.connection.url">jdbc:mysql:///db_student</property>
		<property name="hibernate.connection.username">root</property>
		<property name="hibernate.connection.password">912117</property>
		<!-- 后面的四步才是hibernate的 -->
		<property name="show_sql">true</property>
		<property name="formal_sql">true</property>
		<property name="hibernate.hbm2ddl.auto">update</property>
		<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
		<!-- 这地方要把Student类的映射文件加载进来这个主配置文件里面,只有这样,Student类的映射文件才会生效! -->
	<mapping resource="cn/edu/hpu/entity/Student.hbm.xml"/>
	</session-factory>
</hibernate-configuration>

最后只需要在写一个Test类来测试一下就可以了

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import cn.edu.hpu.entity.Student;

public class Test {
	public static void main(String[] args) {
		Configuration cfg = new Configuration().configure();
		SessionFactory sf = cfg.buildSessionFactory();
		Session s = sf.openSession();
		Transaction tx = s.getTransaction();
		tx.begin();
		Student stu = new Student("13", "zs");
		s.save(stu);
		tx.commit();
		s.close();
		sf.close();
	}
}

以上代码均有自己学习时候所写,有错欢迎在评论区希望提出来~

猜你喜欢

转载自blog.csdn.net/qq_37823003/article/details/81913711
今日推荐