Hibernate映射文件配置

首先,应用的数据库是mysql数据库;

 

对象关系的映射是用一个XML文档来说明的。映射文档可以使用工具来生成,如XDoclet,Middlegen和AndroMDA等。

下面从一个映射的例子开始讲解映射元素,映射文件的代码如下。

   1. <?xml version="1.0"?>  
   2. <!--  
   3. 所有的XML映射文件都需要定义如下所示的DOCTYPE。  
   4. Hibernate会先在它的类路径(classptah)中搜索DTD文件。  
   5.   
   6. -->  
   7. <!DOCTYPE hibernate-mapping PUBLIC  
   8. "-//Hibernate/Hibernate Mapping DTD 3.0//EN"  
   9. "http://hibernate.sourceforge.net/hibernate-mapping- 3.0.dtd">  
  10.   
  11. <!--  
  12. hibernate- mapping有几个可选的属性:  
  13. schema属性指明了这个映射的表所在的schema名称。  
  14. default-cascade属性指定了默认的级联风格 可取值有 none、 save、update。  
  15. auto-import属性默认让我们在查询语言中可以使用非全限定名的类名 可取值有 true、false。  
  16. package属性指定一个包前缀。  
  17. -->  
  18.   
  19. <hibernate-mapping schema="schemaName" default-cascade="none"  
  20. auto-import="true" package="test">  
  21.   
  22. <!-- 用class元素来定义一个持久化类 -->  
  23. <class name="People" table="person">  
  24. <!-- id 元素定义了属性到数据库表主键字段的映射。-->  
  25. <id name="id">  
  26. <!-- 用来为该持久化类的实例生成唯一的标识 -->  
  27. <generator class="native"/>  
  28. </id>  
  29. <!-- discriminator 识别器 是一种定义继承关系的映射方法-->  
  30.   
  31. <discriminator column="subclass" type="character"/>  
  32. <!-- property 元素为类声明了一个持久化的,JavaBean风格的属性-->  
  33. <property name="name" type="string">  
  34. <column name="name" length="64" not-null="true" />  
  35. </property>  
  36.   
  37. <property name="sex"  
  38. not-null="true"  
  39. update="false"/>  
  40.   
  41. <!-- 多对一映射关系-->  
  42. <many-to-one name="friend"  
  43. column="friend_id"  
  44. update="false"/>  
  45.   
  46. <!-- 设置关联关系-->  
  47.   
  48. <set name="friends" inverse="true" order-by="id">  
  49. <key column="friend_id"/>  
  50. <! —一对多映射-->  
  51. <one-to-many class="Cat"/>  
  52. </set>  
  53. </class>  
  54. </hibernate- mapping>  

  组件应用的方法

  组件有两种类型,即组件(component)和动态组件(dynamic-component)。在配置文件中,component元素为 子对象的元素与父类对应表的字段建立起映射关系。然后组件可以声明它们自己的属性、组件或者集合。component元素的定义如下所示:

   1. <component name="propertyName" class="className" insert="true|false"  
   2. upate="true|false" access="field|property|ClassName">  
   3.   
   4. <property ...../>  
   5. <many- to-one .... />  
   6. ........  
   7. </component>  

 
   在这段代码中,name是指属性名,class是类的名字,insert指的是被映射的字段是否出现在SQL的INSERT语句中,upate指出被映射 的字段是否出现在SQL的UPDATE语句中,access指出访问属性的策略。

  Hiebernate的基本配置

   Hibernate的数据库连接信息是从配置文件中加载的。Hibernate的配置文件有两种形式:一种是XML格式的文件,一种是 properties属性文件。properties形式的配置文件默认文件名是hibernate.properties,一个properties形 式的配置文件内容如下所示:

   1. #指定数据库使用的驱动类  
   2. hibernate.connection.driver_class = com.mysql.jdbc.Driver r  
   3.   
   4. # 指定数据库连接串  
   5. hibernate.connection.url = jdbc:mysql://localhost:3306/db  
   6.   
   7.   
   8. # 指定数据库连接的用户名  
   9. hibernate.connection.username = user  
  10.   
  11. # 指定数据库连接的密码  
  12. hibernate.connection.password = password  
  13.   
  14. # 指定数据库使用的方言  
  15. hibernate.dialect = net.sf.hibernate.dialect.MySQLDialect  
  16.   
  17. # 指定是否打印SQL语句  
  18. hibernate.show_sql=true  

  在配置文件中包含了一系列属性的配置,Hibernate将根据这些属性来连接数据库。

   在XML格式的配置文件中,除了基本的Hibernate配置信息,还可以指定具体的持久化类的映射文件,这可以避免将持久化类的配置文件硬编码在程序 中。XML格式的配置文件的默认文件名为hibernate.cfg.xml,一个XML配置文件的示例如下所示:

# <?xml version='1.0' encoding='UTF-8'?>  
#   
# <!DOCTYPE hibernate-configuration PUBLIC  
# "-//Hibernate/Hibernate Configuration DTD 3.0//EN"  
# "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">  
#   
# <hibernate- configuration>  
# <session-factory>  
# <!-- 显示执行的SQL语句-->  
# <property name="show_sql">true</property>  
#   
# <!-- 连接字符串-->  
# <property name="connection.url">jdbc:mysql://localhost:3306/数据库名字</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="dialect">org.hibernate.dialect.MySQLDialect</property>  
#   
# <!-- 映射文件 -->  
# <mapping resource="com/stuman/domain/Admin.hbm.xml" />  
#   
# <!-- 映射文件-->  
# <mapping resource="com/stuman/domain/Student.hbm.xml" />  
#   
# </session- factory>  
# </hibernate-configuration> 

  properties形式的配置文件和XML格式的配置文件可以同时使用。当同时使用两种类型的配置文件时,XML配置文件中的设置会覆盖 properties配置文件的相同的属性。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
图像识别技术在病虫害检测中的应用是一个快速发展的领域,它结合了计算机视觉和机器学习算法来自动识别和分类植物上的病虫害。以下是这一技术的一些关键步骤和组成部分: 1. **数据收集**:首先需要收集大量的植物图像数据,这些数据包括健康植物的图像以及受不同病虫害影响的植物图像。 2. **图像预处理**:对收集到的图像进行处理,以提高后续分析的准确性。这可能包括调整亮度、对比度、去噪、裁剪、缩放等。 3. **特征提取**:从图像中提取有助于识别病虫害的特征。这些特征可能包括颜色、纹理、形状、边缘等。 4. **模型训练**:使用机器学习算法(如支持向量机、随机森林、卷积神经网络等)来训练模型。训练过程中,算法会学习如何根据提取的特征来识别不同的病虫害。 5. **模型验证和测试**:在独立的测试集上验证模型的性能,以确保其准确性和泛化能力。 6. **部署和应用**:将训练好的模型部署到实际的病虫害检测系统中,可以是移动应用、网页服务或集成到智能农业设备中。 7. **实时监测**:在实际应用中,系统可以实时接收植物图像,并快速给出病虫害的检测结果。 8. **持续学习**:随着时间的推移,系统可以不断学习新的病虫害样本,以提高其识别能力。 9. **用户界面**:为了方便用户使用,通常会有一个用户友好的界面,显示检测结果,并提供进一步的指导或建议。 这项技术的优势在于它可以快速、准确地识别出病虫害,甚至在早期阶段就能发现问题,从而及时采取措施。此外,它还可以减少对化学农药的依赖,支持可持续农业发展。随着技术的不断进步,图像识别在病虫害检测中的应用将越来越广泛。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值