ホームページ  >  記事  >  Java  >  Hibernate を使用して個人データ テーブルに対する操作を実装する

Hibernate を使用して個人データ テーブルに対する操作を実装する

零下一度
零下一度オリジナル
2017-07-26 16:39:091459ブラウズ

Hibernate は、名前が示すように、データベース内の情報をオブジェクトを通じて操作できる ORM (Object Relational Mapping) が中心的なアイデアであり、開発者はデータベースの SQL ステートメントにあまり慣れていないと言われています。これは、開発者がデータベースを操作するために SQL ステートメントに精通している必要がなく、SQL ステートメントを自動的に生成し、自動的に実行することにも役立ちます。

休止状態を使用すると、開発者は完全にオブジェクト指向の考え方を使用してデータベースを操作できるため、次のデモには SQL ステートメントが 1 つも含まれていません。

この記事では、Hibernate を使用して、個人データ テーブルに対する単純な基本的な追加、削除、変更、クエリ操作を実装します。

準備

環境: win7+eclipse

ツールキット: ダウンロード可能な休止状態パッケージ。この例では、バージョン 4 が使用されます。この例では、mysql が使用されます。プログラム構造図

pojo層エンティティクラス

package demo.pojo;
public class Person {private Integer id;private String name;private String gender;private Integer age;public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getGender() {return gender;}public void setGender(String gender) {this.gender = gender;}public Integer getAge() {return age;}public void setAge(Integer age) {this.age = age;}@Overridepublic String toString() {return "Person [id=" + id + ", name=" + name + ", gender=" + gender + ", age=" + age + "]";}}

コア設定ファイルhibernate.cfg.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- 以下四行分别为:数据库驱动类、Drivermanager获取连接的参数URL、用户名、密码  -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://127.0.0.1/web?characterEcoding=utf-8</property>
<property name="connection.username">root</property>
<property name="connection.password">123456</property>
<!-- 设置方言,hibernate会根据数据库的类型相应生成SQL语句 -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 控制台显示生成的sql语句,默认为false -->
<property name="show_sql">true</property>
<!-- 映射配置源文件的位置 -->
<mapping resource="demo/pojo/Person.hbm.xml"/>
</session-factory>
</hibernate-configuration>

マッピングファイルperson.hbm.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<!-- name是实体类全名,table为数据表名 -->
<class name="demo.pojo.Person" table="Person">
<id name="id" column="id">
<!-- 主键生成方式,native是让hibernate自动识别 -->
<generator class="native"></generator>
</id>
<!--

注:

0.nameの値は属性名ですエンティティ クラスでは、列はデータ テーブルのフィールド名です。

1. エンティティ クラスの属性名が対応するデータ テーブルのフィールド名と同じ場合、次の列は省略でき、Hibernate は自動的に一致します。例: 年齢

2 逆に、エンティティクラスの属性名と対応するデータテーブルのフィールド名が異なる場合は、以下の性別と性別を両方記述する必要があります

--> 操作方法

<property name="name" column="name"></property>
<property name="gender" column="sex"></property>
<property name="age"></property>
</class>
</hibernate-mapping>

テストクラス Testperson
package demo.util;
import org.hibernate.Session;import org.hibernate.SessionFactory;import org.hibernate.cfg.Configuration;import org.hibernate.service.ServiceRegistry;import org.hibernate.service.ServiceRegistryBuilder;
public class HibernateSessionFactory {private static SessionFactory factory;private static ThreadLocal<Session> thread = new ThreadLocal<Session>();private static String path = "hibernate.cfg.xml";private static Configuration config = new Configuration();static {config.configure(path);ServiceRegistry service = new ServiceRegistryBuilder()//定义一个服务注册机.applySettings(config.getProperties()).buildServiceRegistry();factory = config.buildSessionFactory(service);//创建Session工厂类}/** * 从hibernate的session工厂类里创建一个session * @return * */public static Session getSession() {Session session = thread.get();if(session == null || !session.isOpen()) {session = factory.openSession();thread.set(session);}return session;}public static void closeSession() {Session session = thread.get();if(session != null && session.isOpen()) {session.close();thread.set(null);}}}


以上がHibernate を使用して個人データ テーブルに対する操作を実装するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。