您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

使用注解进行ORM映射介绍

2024/2/28 17:28:32发布18次查看
近两年来有更多的项目对一些比较稳定的实体类使用了注解进行orm映射,这样使得编程更加简洁、简单。其实使用注解进行orm映射和使用xml进行映射没有太多的操作流程上的变化,主要步骤为:导包、编写带注解的实体类、编写核心配置文件、编写测试类。
项目工程代码已经上传到github:  工程名:hibernateuseannotation
整个工程项目结构如下图:
一、导包笔者使用的是mysql数据库,因此导入数据包如下图:
二、编写实体类用于映射的注解基本都在javax.persistence.*包中定义,我常用到的主要是如下四个:
   @entity注释将此类标记为实体。
  @table注释指定要保留此实体的数据的表名。 如果不使用@table注释,hibernate将使用类名作为表名称bydefault。
   @id注释标记此实体的标识符。
   @column注释指定此属性或字段的列的详细信息。如果未指定@column注释,则属性名称将用作列名称bydefault。
 1 package com.rocky.domain; 2  3 import javax.persistence.entity; 4 import javax.persistence.id; 5 import javax.persistence.table; 6  7 @entity 8 @table(name = tb_user) 9 public class user10 {11     @id12     private integer uid;13     private string uname;14     private integer uage;15     public user()16     {17         super();18     }19     @override20     public string tostring()21     {22         return user [uid= + uid + , uname= + uname + , uage= + uage + ];23     }24     public integer getuid()25     {26         return uid;27     }28     public void setuid(integer uid)29     {30         this.uid = uid;31     }32     public string getuname()33     {34         return uname;35     }36     public void setuname(string uname)37     {38         this.uname = uname;39     }40     public integer getuage()41     {42         return uage;43     }44     public void setuage(integer uage)45     {46         this.uage = uage;47     }48 }
三、编写核心配置文件使用注解的配置文件和xml映射的配置文件基本大同小异,但是在引入外部映射时使用的属性是class而非resource属性。
 1 <?xml version='1.0' encoding='utf-8'?> 2 <!doctype hibernate-configuration public 3 "-//hibernate/hibernate configuration dtd 3.0//en" 4 "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> 5  6 <hibernate-configuration> 7     <session-factory> 8  9         <!--指定数据库的参数 -->10         <property name="hibernate.dialect">org.hibernate.dialect.mysqldialect</property>11         <property name="hibernate.connection.driver_class">com.mysql.jdbc.driver</property>12         <property name="hibernate.connection.url">jdbc:mysql://192.168.100.100:3306/test</property>13         <property name="hibernate.connection.username">root</property>14         <property name="hibernate.connection.password">1</property>15         16         <!--指定hibernate是否显式sql语句及其格式化 -->17         <property name="hibernate.show_sql">true</property>18         <property name="hibernate.format_sql">true</property>19         20         <!--指定表的生成方式-即是否由hibernate自动创建表,其取值为:create-drop、21 create、validate、update-->22         <property name="hibernate.hbm2ddl.auto">update</property>23         24         <!--引入 orm配置文件 -->25         <mapping class="com.rocky.domain.user"/>26     </session-factory>27 28 </hibernate-configuration>
四、编写测试类 1 package com.rocky.testdriver; 2  3 import org.hibernate.session; 4 import org.hibernate.sessionfactory; 5 import org.hibernate.transaction; 6 import org.hibernate.cfg.configuration; 7  8 import com.rocky.domain.user; 9 10 public class testdriver11 {12 13     public static void main(string[] args)14     {15         // 加载配置文件16         configuration cfg = new configuration();17         cfg.configure();18         // 创建会话工厂19         sessionfactory factory = cfg.buildsessionfactory();20         // 获取非线程绑定会话21         session session = factory.opensession();22         // 开启事务23         transaction tx = session.begintransaction();24         // 创建user对象25         user user = new user();26         user.setuid(1);27         user.setuname(rocky);28         user.setuage(28);29 30         // 将数据插入数据库31         session.save(user);32 33         // 提交事务34         tx.commit();35         // 关闭会话36         session.close();37     }38 39 }
以上就是使用注解进行orm映射介绍的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product