昨天我们进行了hibernate的配置,并且进行了根据ID查询对应数据的操作,今天我们来看看hibernate中的几个配置文件,里面到底有什么东东。
一、hibernate.cfg.xml
<hibernate-configuration> <session-factory> <property name="dialect"> org.hibernate.dialect.MySQLDialect </property> <property name="connection.url"> jdbc:mysql://127.0.0.1:3306/superktv </property> <property name="connection.username">root</property> <property name="connection.password">root</property> <property name="connection.driver_class"> com.mysql.jdbc.Driver </property> <property name="myeclipse.connection.profile">mysql</property> <mapping resource="com/pxy/dao/Author.hbm.xml" /> </session-factory> </hibernate-configuration>
这里面应该没有什么不好懂的吧,就注意一点,<mapping>标签的路径不要引用错了,每次引用完后,记得按住Ctrl键,再把鼠标移动到resource的值上去,如果双引号里的内容变成了超链接,那说明没问题。当然,如果你是通过DBBrowser生成的文件,那肯定不会引用错误。
二、Author.hbm.xml
<hibernate-mapping> <class name="com.pxy.entity.Author" table="author" catalog="blogdb"> <id name="id" type="java.lang.Integer"> <column name="id" /> <generator class="native" /> </id> <property name="username" type="java.lang.String"> <column name="username" length="20" not-null="true" /> </property> <property name="password" type="java.lang.String"> <column name="password" length="10" not-null="true" /> </property> <property name="email" type="java.lang.String"> <column name="email" length="20" /> </property> <property name="address" type="java.lang.String"> <column name="address" length="20" /> </property> <property name="phone" type="java.lang.String"> <column name="phone" length="20" /> </property> </class> </hibernate-mapping>
class标签的name表示对应的实体类,table表示对应的数据表,catalog表示对应的数据库。
- id标签:表示主键。
- generator标签:主键的生成策略。
- property标签:表示实体类的属性。
- column标签:表示对应表中的字段。
对于单个对象的操作,我们上次已经用过了load方法,除此之外,常用的还有以下四个:
get()方法,save()方法,update()方法,delete()方法
从名字就应该可以猜出对应的用法吧,这儿就不在一一演示了,各位看官自行解决吧·
最后简单说一下load()和get()的区别:
load()方法是延时加载,调用时只返回一个代理对象(只包含ID),并且如果没有该ID对应的数据会抛ObjectNotFoundException异常。
get()方法是实时加载,调用后就返回ID对应的记录,如果数据不存在则返回null对象。
为了测试一下效果,我们在hibernate的配置文件中加<propertyname="show_sql">true</property>和<property name="format_sql">true</property>。
注意看下面两段代码及结果的区别。
至于查不存在的数据,大伙就自己试试吧。今天的就打到这儿吧。下一篇我们来了解稍微高深那么一点点的知识吧。
本文出自 “软件思维” 博客,请务必保留此出处http://softi.blog.51cto.com/13093971/1957387