搜索
首页数据库mysql教程IT忍者神龟之Hibernat持久化对象-数据表映射配置回顾

1.持久化对象POJO编写规则: 1) 有空参public构造器; 2) 提供标识属性,映射数据表主键; 3) 属性提供setter和getter方法; 4) 属性使用基本数据类型的包装类型。基本类型在数据库中不能区分null和0; 5) 不使用final修饰。如果使用final则无法生成代

1.持久化对象POJO编写规则:

1) 有空参public构造器;

2) 提供标识属性,映射数据表主键;

3) 属性提供setter和getter方法;

4) 属性使用基本数据类型的包装类型。基本类型在数据库中不能区分null和0;

5) 不使用final修饰。如果使用final则无法生成代理对象;当使用了final,load查询将如同get查询。

2.POJO的OID:

OID是持久化类与数据表主键对应的属性,用来唯一区分持久化对象。

自然主键:采用数据库中有意义的列的值作为主键(有意义)

代理主键:采用自动生成的流水号、UUID作为主键(无意义,推荐)

3.数据类型:

基本类型无法区分null和0,开发中POJO属性都使用包装类型。

4.持久化类配置POJO.hbm.xml:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 <code class="xml keyword">xml <code class="xml color1"> version<code class="xml plain">=<code class="xml string">"1.0" <code class="xml color1"> encoding<code class="xml plain">=<code class="xml string">"UTF-8"<code class="xml plain">?> <code class="xml plain">DOCTYPE <code class="xml plain"> hibernate-mapping PUBLIC <code class="xml spaces"> <code class="xml plain">"-//Hibernate/Hibernate Mapping DTD 3.0//EN" <code class="xml spaces"> <code class="xml plain">"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <code class="xml comments"><!-- package="POJO所在包" --> <code class="xml plain">hibernate-mapping <code class="xml color1"> package<code class="xml plain">=<code class="xml string">"cn.cvu.domain"<code class="xml plain">> <code class="xml spaces"> <code class="xml comments"><!-- name="POJO类" table="数据库中的表单" catalog="数据库,对应项目的hibernate核心配置文件中<property name=&#39;hibernate.connection.url&#39;>jdbc:mysql:///数据库</property> " --> <code class="xml spaces"> <code class="xml plain">class <code class="xml color1"> name<code class="xml plain">=<code class="xml string">"User" <code class="xml color1"> table<code class="xml plain">=<code class="xml string">"table_user" <code class="xml color1"> catalog<code class="xml plain">=<code class="xml string">"db_hibernate"<code class="xml plain">> <code class="xml spaces"> <code class="xml comments"><!-- name="POJO对应的属性" column="表单的主键 列" type="POJO属性的数据类型" --> <code class="xml spaces"> <code class="xml plain">id <code class="xml color1"> name<code class="xml plain">=<code class="xml string">"id" <code class="xml color1"> column<code class="xml plain">=<code class="xml string">"id" <code class="xml color1"> type<code class="xml plain">=<code class="xml string">"int"<code class="xml plain">> <code class="xml spaces"> <code class="xml comments"><!-- class="主键生成策略" --> <code class="xml spaces"> <code class="xml plain">generator <code class="xml color1"> class<code class="xml plain">=<code class="xml string">"native"<code class="xml plain">><code class="xml keyword">generator<code class="xml plain">> <code class="xml spaces"> <code class="xml comments"><!-- 常用策略:increment、identity、sequence、native、uuid、assigned --> <code class="xml spaces"> <code class="xml plain"><code class="xml keyword">id<code class="xml plain">> <code class="xml spaces"> <code class="xml comments"><!-- name="POJO中对应属性" colunm="表单中的 列" type="POJO数据类型" --> <code class="xml plain">   <code class="xml spaces"> <code class="xml plain">property <code class="xml color1"> name<code class="xml plain">=<code class="xml string">"name" <code class="xml color1"> column<code class="xml plain">=<code class="xml string">"name" <code class="xml color1"> type<code class="xml plain">=<code class="xml string">"string"<code class="xml plain">><code class="xml keyword">property<code class="xml plain">> <code class="xml plain">   <code class="xml spaces"> <code class="xml plain">property <code class="xml color1"> name<code class="xml plain">=<code class="xml string">"age" <code class="xml color1"> column<code class="xml plain">=<code class="xml string">"age" <code class="xml color1"> type<code class="xml plain">=<code class="xml string">"int" <code class="xml plain"> ><code class="xml keyword">property<code class="xml plain">> <code class="xml plain">   <code class="xml spaces"> <code class="xml plain">property <code class="xml color1"> name<code class="xml plain">=<code class="xml string">"city" <code class="xml color1"> column<code class="xml plain">=<code class="xml string">"city" <code class="xml color1"> sql-type<code class="xml plain">=<code class="xml string">"string"<code class="xml plain">><code class="xml keyword">property<code class="xml plain">> <code class="xml spaces"> <code class="xml comments"><!-- 常用属性:length:列值长度、not-null:非空true/false、unique:唯一true/false --> <code class="xml spaces"> <code class="xml plain"><code class="xml keyword">class<code class="xml plain">> <code class="xml plain"><code class="xml keyword">hibernate-mapping<code class="xml plain">>

1)主键生成策略increment:顶层递增:

\

由hibernate自动完成,原理:先查询最大值,再插入此值加一。OID必须为long、int或short类型。

优点:跨数据库。

缺点:多线程并发访问问题。

2)主键生成策略identity:底层递增:

\

由数据库自动完成,要求数据库必须支持自增主键。mysql支持,oracle不支持。OID必须为long、int或short类型。

优点:无并发访问问题。

3)主键生成策略sequence:序列:

由数据库自动完成递增,要求数据库必须支持序列。mysql不支持,oracle支持。OID必须为long、int或short类型。

Oracle:

1创建序列:create sequence myseq;

2调用序列:insert into customer values (myseq.nextval); #序列加一

4)主键生成策略native:本地:

\

采用数据库支持的自增策略。 mysql:identity,oracle:sequence。OID必须为long、int或short类型。

优点:跨数据库平台。

5)主键生成策略uuid:标识符:

\

由数据库自动创建。 uuid是32位唯一字符串,表单主键使用varchar类型,POJO对应属性是String类型。

6)主键生成策略assigned:手动指定:

\

在调用hibernate时手动指定主键的值,用于自然主键(有意义的)。

1 2 3 4 5 6 7 8 9 10 11 12 13 14 public <code class="java keyword"> void <code class="java plain"> testInsertAssigned() { <code class="java spaces"> <code class="java plain">Session session = UtilGetSesstion.openSession(); <code class="java spaces"> <code class="java plain">Transaction transaction = session.beginTransaction(); <code class="java spaces"> <code class="java spaces"> <code class="java plain">User user = <code class="java keyword">new <code class="java plain"> User(); <code class="java spaces"> <code class="java plain">user.setId(<code class="java value">20130124<code class="java plain">); <code class="java comments">//手动设置主键 <code class="java spaces"> <code class="java plain">user.setName(<code class="java string">"EminemXXX"<code class="java plain">); <code class="java spaces"> <code class="java plain">user.setAge(<code class="java value">42<code class="java plain">); <code class="java spaces"> <code class="java plain">user.setCity(<code class="java string">"NewYorkXXX"<code class="java plain">); <code class="java spaces"> <code class="java plain">session.save(user); <code class="java spaces"> <code class="java spaces"> <code class="java plain">transaction.commit(); <code class="java spaces"> <code class="java plain">session.close(); <code class="java spaces"> <code class="java plain">}

7)主键生成策略:复合主键:

(1)编写POJO类 Person.java:

1 2 3 4 5 6 7 8 9 10 11 package <code class="java plain"> cn.cvu.domain; <code class="java keyword">import <code class="java plain"> java.io.Serializable; <code class="java comments">//务必事先序列化接口 <code class="java keyword">public <code class="java keyword"> class <code class="java plain"> Person <code class="java keyword">implements <code class="java plain"> Serializable { <code class="java spaces"> <code class="java keyword">private <code class="java plain"> String firstName; <code class="java comments">//对应表单的复合主键 <code class="java spaces"> <code class="java keyword">private <code class="java plain"> String secondName; <code class="java comments">//对应表单的复合主键 <code class="java spaces"> <code class="java keyword">private <code class="java plain"> String address; <code class="java spaces"> <code class="java spaces"> <code class="java comments">//get/set <code class="java spaces"> <code class="java comments">//toString <code class="java plain">}

(2)配置POJO.hbm.xml:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 <code class="xml keyword">xml <code class="xml color1"> version<code class="xml plain">=<code class="xml string">"1.0" <code class="xml color1"> encoding<code class="xml plain">=<code class="xml string">"UTF-8"<code class="xml plain">?> <code class="xml plain">DOCTYPE <code class="xml plain"> hibernate-mapping PUBLIC <code class="xml spaces"> <code class="xml plain">"-//Hibernate/Hibernate Mapping DTD 3.0//EN" <code class="xml spaces"> <code class="xml plain">"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <code class="xml plain">hibernate-mapping <code class="xml color1"> package<code class="xml plain">=<code class="xml string">"cn.cvu.domain"<code class="xml plain">> <code class="xml spaces"> <code class="xml plain">class <code class="xml color1"> name<code class="xml plain">=<code class="xml string">"Person" <code class="xml color1"> table<code class="xml plain">=<code class="xml string">"table_person" <code class="xml color1"> catalog<code class="xml plain">=<code class="xml string">"db_hibernate"<code class="xml plain">> <code class="xml spaces"> <code class="xml comments"><!-- 复合id --> <code class="xml spaces"> <code class="xml plain">composite-id<code class="xml plain">> <code class="xml spaces"> <code class="xml comments"><!-- 主键列 name="POJO属性" column="表单列名" --> <code class="xml spaces"> <code class="xml plain">key-property <code class="xml color1"> name<code class="xml plain">=<code class="xml string">"firstName" <code class="xml color1"> column<code class="xml plain">=<code class="xml string">"nameFirst"<code class="xml plain">><code class="xml keyword">key-property<code class="xml plain">> <code class="xml spaces"> <code class="xml plain">key-property <code class="xml color1"> name<code class="xml plain">=<code class="xml string">"secondName" <code class="xml color1"> column<code class="xml plain">=<code class="xml string">"nameFirst"<code class="xml plain">><code class="xml keyword">key-property<code class="xml plain">> <code class="xml spaces"> <code class="xml plain"><code class="xml keyword">composite-id<code class="xml plain">> <code class="xml spaces"> <code class="xml comments"><!-- 普通列 name="POJO属性" column="表单列名" type="数据类型" --> <code class="xml spaces"> <code class="xml plain">property <code class="xml color1"> name<code class="xml plain">=<code class="xml string">"address" <code class="xml color1"> column<code class="xml plain">=<code class="xml string">"addr" <code class="xml color1"> type<code class="xml plain">=<code class="xml string">"string"<code class="xml plain">><code class="xml keyword">property<code class="xml plain">> <code class="xml spaces"> <code class="xml plain"><code class="xml keyword">class<code class="xml plain">> <code class="xml plain"><code class="xml keyword">hibernate-mapping<code class="xml plain">>

(3)配置hibernate.cfg.xml,加载Person.hbm.xml文件:

\

(4)操作类的方法:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 public <code class="java keyword"> void <code class="java plain"> testInsert() { <code class="java spaces"> <code class="java plain">Configuration configuration = <code class="java keyword">new <code class="java plain"> Configuration().configure(); <code class="java spaces"> <code class="java plain">SessionFactory sessionFactory = configuration.buildSessionFactory(); <code class="java spaces"> <code class="java plain">Session session = sessionFactory.openSession(); <code class="java spaces"> <code class="java plain">Transaction transaction = session.beginTransaction(); <code class="java spaces"> <code class="java spaces"> <code class="java plain">Person person = <code class="java keyword">new <code class="java plain"> Person(); <code class="java spaces"> <code class="java plain">person.setFirstName(<code class="java string">"C"<code class="java plain">); <code class="java spaces"> <code class="java plain">person.setSecondName(<code class="java string">"Vigiles"<code class="java plain">); <code class="java spaces"> <code class="java plain">person.setAddress(<code class="java string">"Beijng"<code class="java plain">); <code class="java spaces"> <code class="java plain">session.save(person); <code class="java spaces"> <code class="java spaces"> <code class="java plain">transaction.commit(); <code class="java spaces"> <code class="java plain">session.close(); <code class="java spaces"> <code class="java plain">sessionFactory.close(); <code class="java spaces"> <code class="java plain">}

(5)结果:

\

INFO: HHH000262: Table not found: tb_person
2013-11-5 10:07:12 org.hibernate.tool.hbm2ddl.SchemaUpdate execute
ERROR: HHH000388: Unsuccessful: create table db_hibernate.tb_person (namef varchar(255) not null, names varchar(255) not null, age integer, city varchar(255), primary key (namef, names)) type=InnoDB
2013-11-5 10:07:12 org.hibernate.tool.hbm2ddl.SchemaUpdate execute
ERROR: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'type=InnoDB' at line 7
2013-11-5 10:07:12 org.hibernate.tool.hbm2ddl.SchemaUpdate execute
INFO: HHH000232: Schema update complete
\

1 2 3 <!-- 方言-指定数据库为5.1版本之后的SQL语言 --> <code class="xml spaces"> <code class="xml plain">property <code class="xml color1"> name<code class="xml plain">=<code class="xml string">"hibernate.dialect"<code class="xml plain">> <code class="xml plain">  org.hibernate.dialect.MySQL5InnoDBDialect<code class="xml keyword">property<code class="xml plain">>

-end
声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
mysql blob:有什么限制吗?mysql blob:有什么限制吗?May 08, 2025 am 12:22 AM

mysqlblobshavelimits:tinyblob(255bytes),blob(65,535 bytes),中间布洛布(16,777,215个比例),andlongblob(4,294,967,967,295 bytes).tousebl观察性:1)考虑performance impactsandSandStorelargeblobsextern; 2)管理backbackupsandreplication carecration; 3)usepathsinst

MySQL:自动化用户创建的最佳工具是什么?MySQL:自动化用户创建的最佳工具是什么?May 08, 2025 am 12:22 AM

自动化在MySQL中创建用户的最佳工具和技术包括:1.MySQLWorkbench,适用于小型到中型环境,易于使用但资源消耗大;2.Ansible,适用于多服务器环境,简单但学习曲线陡峭;3.自定义Python脚本,灵活但需确保脚本安全性;4.Puppet和Chef,适用于大规模环境,复杂但可扩展。选择时需考虑规模、学习曲线和集成需求。

mysql:我可以在斑点内搜索吗?mysql:我可以在斑点内搜索吗?May 08, 2025 am 12:20 AM

是的,YouCansearchInIdeAblobInMysqlusingsPecificteChniques.1)转换theblobtoautf-8StringWithConvertFunctionWithConvertFunctionandSearchusiseLike.2)forCompresseBlyblobs,useuncompresseblobs,useuncompressbeforeconversion.3)acpperformance impperformance imperformance imptactsanddataEccoding.4)

MySQL字符串数据类型:综合指南MySQL字符串数据类型:综合指南May 08, 2025 am 12:14 AM

mysqloffersvariousStringDatatYpes:1)charforfixed Lengtth Strings,IdealforConsistLengthDatalikeCountryCodes; 2)varcharforvariable长度长,合适的forfieldslikenames; 3)texttypefesforepesforlargertext,forforlargertext,goodforforblogblogpostsbutcan impactcuctcuctcuctpercrance; 4)biland;

掌握mysql blobs:逐步教程掌握mysql blobs:逐步教程May 08, 2025 am 12:01 AM

TomasterMySQLBLOBs,followthesesteps:1)ChoosetheappropriateBLOBtype(TINYBLOB,BLOB,MEDIUMBLOB,LONGBLOB)basedondatasize.2)InsertdatausingLOAD_FILEforefficiency.3)Storefilereferencesinsteadoffilestoimproveperformance.4)UseDUMPFILEtoretrieveandsaveBLOBsco

MySQL中的BLOB数据类型:开发人员的详细概述MySQL中的BLOB数据类型:开发人员的详细概述May 07, 2025 pm 05:41 PM

blobdatatypesinmysqlareusedforvorvoringlargebinarydatalikeimagesoraudio.1)useblobtypes(tinyblobtolonglongblob)基于dondatasizeneeds。 2)库孔素pet petooptimize绩效。3)考虑Xternal Storage Forel Blob romana databasesizerIndimprovebackupe

如何将用户从命令行添加到MySQL如何将用户从命令行添加到MySQLMay 07, 2025 pm 05:01 PM

toadDuserStomySqlfromtheCommandline,loginasroot,thenusecreateuser'username'@'host'host'Indessifiedby'password'; tocreateanewuser.grantpermissionswithgrantprantallprivilegesondatabase

MySQL中有哪些不同的字符串数据类型?详细的概述MySQL中有哪些不同的字符串数据类型?详细的概述May 07, 2025 pm 03:33 PM

mySqlofferSeightStringDatateTypes:char,varchar,二进制,二进制,varbinary,blob,文本,枚举,枚举和set.1)长度,理想的forconsistentDatatalIkeCountryCodes.2)varcharisvariable长度,长度,效率foriforitifforiticforiticforiticforiticforiticforitic forvaryingdatalikename.3)

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。