- 浏览: 816832 次
- 性别:
- 来自: 厦门
文章分类
- 全部博客 (363)
- 2010年3月 (3)
- 2010年4月 (3)
- Java (116)
- ExtJs (22)
- EJB3.0 (11)
- JQuery (28)
- SqlServer (5)
- Oracle (17)
- hibernate (21)
- struts2 (14)
- php (10)
- JavaScript (11)
- jbpm (6)
- spring (24)
- lucene (2)
- ibatis (7)
- C# (8)
- mysql (11)
- json (3)
- webservice (3)
- 设计模式 (1)
- jdbc (1)
- servlet (2)
- ice (6)
- 日常软件问题 (2)
- 生活 (2)
- iphone (1)
- rest (3)
- ruby (2)
- linux (13)
- quartz (1)
- poi (1)
- redis (13)
- memcached (4)
- nosql (2)
- tomcat调优 (1)
- 项目管理 (0)
最新评论
-
天使建站:
jquery里和数组相关的操作 附带具体的实例 ...
jquery对象数组 -
Cy0941:
$('#formId').form('submit',...) ...
easyui的form表单提交处理 -
shmily2038:
swifth 写道楼主,,你的命令写错啦,,[root@ser ...
centos直接yum安装nginx -
swifth:
楼主,,你的命令写错啦,,[root@server ~]# y ...
centos直接yum安装nginx -
随遇而安DXX:
...
REST
1、Hibernate 基本数据类型
Hibernate基本类型
JAVA类型
标准SQL字段类型
Boolean
Boolean,java.lang.boolean
BIT
Yes_no
Boolean,java.lang.boolean
Char(1)( ‘ Y ’ / ’ N ’ )
True_false
Boolean,java.lang.boolean
Char(1)( ‘ Y ’ / ’ N ’ )
Byte
Byte,java.lang.byte
TINYINT
Short
Short,java.lang.short
SMALLINT
Interger
Int,java.lang.integer
INTEGER
Long
Long,java.lang.long
BIGINT
Float
Float,java.lang.float
FLOAT
Double
Double,java.lang.Double
DOUBLE
Big_decimal
Java.math.BigDecimal
NUMBERIC
Character
Java.lang.string
CHAR(1)
String
Java.lang.string
VARCHAR
Date
Java.util.Date,java.sql.Date
DATE
Time
Java.util.Date,java.sql.Time
TIME
Timestamp
Java.util.Date,java.sql.TimeStamp
TIMESTAMP
Calender
Java.util.Calendar
TIMESTAMP
Calender_date
Java.util.Calendar
Date
Clob
Java.sql.clob
CLOB
Blob
Java.sql.blob
BLOB
Binary
Byte[]
VARBINARY,BLOB
Text
Java.lang.String
CLOB
Seralizable
Java.io.serializable
VARBINARY,BLOB
Class
Java.lang.class
VARCHAR
Local
Java.util.locale
VARCHAR
Timezone
Java.util.timezone
VARCHAR
Currency
Java.util.currency
VARCHAR
2、OR映射
(1)id映射
< id column = "ID" name = "id" type = "java.lang.String" >
< generator class = "uuid.hex" />
</ id >
name:指定POJO 类的成员变量名
type:name指定变量的数据类型
column:对应数据库表的主键字段
(2)表/类映射
< class name = "test.pojo.company" table = "company" lazy = "false" >
</ class >
name:指定POJO 类
table:POJO类对应的数据库表
lazy:延迟加载
(3)实体映射
< hibernate-mapping >
< class name = "test.pojo.company" table = "company" >
< id column = "ID" name = "id" type = "java.lang.String" >
< generator class = "uuid.hex" />
</ id >
< property column = "NAME" name = "name" type = "java.lang.String" />
< property column = "ADDRESS" name = "address" type = "java.lang.String" />
</ class >
</ hibernate-mapping >
(4)复合主键映射
< composite-id >
< key-property column = "USERID" name = "userid" type = "java.lang.String" ></ key-property >
< key-property column = "WHEN" name = "when" type = "java.sql.Date" ></ key-property >
</ composite-id >
复合主键的POJO类需要实现equals和hashcode方法,可以使用apache commons lang包中的工具类实现(commons-lang.jar)
3、generator 子元素,其class属性指定主键生成方式:
increment(递增) :用于为long, short或者int类型生成唯一标识。只有在没有其他进程往同一张表中插入数据时才能使用。 在集群下不要使用。
identity :对DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的内置标识字段提供支持。返回的标识符是long, short 或者int类型的。
sequence (序列) :在DB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence),而在Interbase中使用生成器(generator)。返回的标识符是long, short或者 int类型的。
hilo (高低位) : 使用一个高/低位算法来高效的生成long, short或者 int类型的标识符。给定一个表和字段(默认分别是是hibernate_unique_key 和next_hi)作为高位值得来源。高/低位算法生成的标识符只在一个特定的数据库中是唯一的。在使用JTA获得的连接或者用户自行提供的连接中,不要使用这种生成器。
seqhilo(使用序列的高低位) :使用一个高/低位算法来高效的生成long, short或者 int类型的标识符,给定一个数据库序列(sequence)的名字。
uuid.hex :用一个128-bit的UUID算法生成字符串类型的标识符。在一个网络中唯一(使用了IP地址)。UUID被编码为一个32位16进制数字的字符串。
uuid.string :使用同样的UUID算法。UUID被编码为一个16个字符长的任意ASCII字符组成的字符串。不能使用在PostgreSQL数据库中
native(本地) :根据底层数据库的能力选择identity, sequence 或者hilo中的一个。
assigned(程序设置) :让应用程序在save()之前为对象分配一个标示符。
foreign(外部引用)
select :hibernate3中新增的。需要提供一个唯一的标识字段进行二次读取,以获取触发器生成的主键值,通过param子元素进行定义,比如:
< generator class = "select" >
< param name = "key" > key_field </ param >
</ generator >
该方法主要针对遗留系统的改造工程,一些早期的系统主键依赖于触发器生成。当数据库insert时,触发器捕获这一操作,并为主键赋值,在插入数据库后,再次读取某一识别字段读取已经插入的数据,获取其主键值。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/xyzroundo/archive/2010/05/13/5586428.aspx
Hibernate基本类型
JAVA类型
标准SQL字段类型
Boolean
Boolean,java.lang.boolean
BIT
Yes_no
Boolean,java.lang.boolean
Char(1)( ‘ Y ’ / ’ N ’ )
True_false
Boolean,java.lang.boolean
Char(1)( ‘ Y ’ / ’ N ’ )
Byte
Byte,java.lang.byte
TINYINT
Short
Short,java.lang.short
SMALLINT
Interger
Int,java.lang.integer
INTEGER
Long
Long,java.lang.long
BIGINT
Float
Float,java.lang.float
FLOAT
Double
Double,java.lang.Double
DOUBLE
Big_decimal
Java.math.BigDecimal
NUMBERIC
Character
Java.lang.string
CHAR(1)
String
Java.lang.string
VARCHAR
Date
Java.util.Date,java.sql.Date
DATE
Time
Java.util.Date,java.sql.Time
TIME
Timestamp
Java.util.Date,java.sql.TimeStamp
TIMESTAMP
Calender
Java.util.Calendar
TIMESTAMP
Calender_date
Java.util.Calendar
Date
Clob
Java.sql.clob
CLOB
Blob
Java.sql.blob
BLOB
Binary
Byte[]
VARBINARY,BLOB
Text
Java.lang.String
CLOB
Seralizable
Java.io.serializable
VARBINARY,BLOB
Class
Java.lang.class
VARCHAR
Local
Java.util.locale
VARCHAR
Timezone
Java.util.timezone
VARCHAR
Currency
Java.util.currency
VARCHAR
2、OR映射
(1)id映射
< id column = "ID" name = "id" type = "java.lang.String" >
< generator class = "uuid.hex" />
</ id >
name:指定POJO 类的成员变量名
type:name指定变量的数据类型
column:对应数据库表的主键字段
(2)表/类映射
< class name = "test.pojo.company" table = "company" lazy = "false" >
</ class >
name:指定POJO 类
table:POJO类对应的数据库表
lazy:延迟加载
(3)实体映射
< hibernate-mapping >
< class name = "test.pojo.company" table = "company" >
< id column = "ID" name = "id" type = "java.lang.String" >
< generator class = "uuid.hex" />
</ id >
< property column = "NAME" name = "name" type = "java.lang.String" />
< property column = "ADDRESS" name = "address" type = "java.lang.String" />
</ class >
</ hibernate-mapping >
(4)复合主键映射
< composite-id >
< key-property column = "USERID" name = "userid" type = "java.lang.String" ></ key-property >
< key-property column = "WHEN" name = "when" type = "java.sql.Date" ></ key-property >
</ composite-id >
复合主键的POJO类需要实现equals和hashcode方法,可以使用apache commons lang包中的工具类实现(commons-lang.jar)
3、generator 子元素,其class属性指定主键生成方式:
increment(递增) :用于为long, short或者int类型生成唯一标识。只有在没有其他进程往同一张表中插入数据时才能使用。 在集群下不要使用。
identity :对DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的内置标识字段提供支持。返回的标识符是long, short 或者int类型的。
sequence (序列) :在DB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence),而在Interbase中使用生成器(generator)。返回的标识符是long, short或者 int类型的。
hilo (高低位) : 使用一个高/低位算法来高效的生成long, short或者 int类型的标识符。给定一个表和字段(默认分别是是hibernate_unique_key 和next_hi)作为高位值得来源。高/低位算法生成的标识符只在一个特定的数据库中是唯一的。在使用JTA获得的连接或者用户自行提供的连接中,不要使用这种生成器。
seqhilo(使用序列的高低位) :使用一个高/低位算法来高效的生成long, short或者 int类型的标识符,给定一个数据库序列(sequence)的名字。
uuid.hex :用一个128-bit的UUID算法生成字符串类型的标识符。在一个网络中唯一(使用了IP地址)。UUID被编码为一个32位16进制数字的字符串。
uuid.string :使用同样的UUID算法。UUID被编码为一个16个字符长的任意ASCII字符组成的字符串。不能使用在PostgreSQL数据库中
native(本地) :根据底层数据库的能力选择identity, sequence 或者hilo中的一个。
assigned(程序设置) :让应用程序在save()之前为对象分配一个标示符。
foreign(外部引用)
select :hibernate3中新增的。需要提供一个唯一的标识字段进行二次读取,以获取触发器生成的主键值,通过param子元素进行定义,比如:
< generator class = "select" >
< param name = "key" > key_field </ param >
</ generator >
该方法主要针对遗留系统的改造工程,一些早期的系统主键依赖于触发器生成。当数据库insert时,触发器捕获这一操作,并为主键赋值,在插入数据库后,再次读取某一识别字段读取已经插入的数据,获取其主键值。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/xyzroundo/archive/2010/05/13/5586428.aspx
发表评论
-
hibernate是否只需要一个commonDao?
2014-01-15 13:15 1772在开发中,经常遇到一个项目只有一个dao(即 ... -
hibernate缓存介绍
2013-02-28 10:12 1023Hibernate 中提供了两级Cache,第一级别的缓存 ... -
hibernate主键生成策略介绍
2013-02-28 10:10 1043Assigned Assigned方式由程序生成主键 ... -
Spring2.5.6+Struts2.1.6+Hibernate3.2升级到Spring3.1.3+Struts2.3.4+Hibernate3.6Final
2012-11-02 19:50 15791. Struts2.3.4相对于Struts2. ... -
hibernate原生sql封装,报错信息:could not find setter for rownum_
2012-10-25 11:03 18326报错信息:could not find setter for ... -
Spring事务配置的五种方式
2012-10-03 22:15 1105前段时间对Spring的事务配置做了比较深入的研究,在此之间 ... -
hibernate SQLQuery实践指南
2012-07-06 17:16 1117hibernate SQLQuery实践指南 两个表(实体) ... -
json hibernate延迟加载问题
2011-08-31 11:41 1085JsonConfig jsonConfig = new Jso ... -
解决a different object with the same identifier value was already associated with
2011-08-25 09:25 2007解决a different object with the s ... -
hibernate query和Criteria分页查询的区别
2011-08-19 09:55 1835Query Q = session.createQuery(& ... -
配置Hibernate二级缓存
2011-08-15 16:04 965Hibernate二级缓存也称为进程级的缓存或SessionF ... -
hibernate一级缓存和二级缓存的区别
2011-07-04 09:36 1049缓存是介于应用程序和 ... -
org.hibernate.PersistentObjectException: detached entity passed to persist异常
2011-01-24 09:06 1702情形:用户注册,或则使用到 sessionFactory.ge ... -
数据库方言
2010-08-26 10:57 1451RDBMS 方言 DB2 org.hibernate. ... -
Java框架的下载地址
2010-08-26 10:15 1178hibernate的下载地址: http://sourcefo ... -
hibernate的timestamp类型处理
2010-08-05 13:19 1907数据库库表某字段是timestamp类型,而要对这个字段进行时 ... -
hql时间比较
2010-08-04 16:37 2557/** * 获取现在时间 * ... -
Ibatis关于null的处理
2010-07-12 12:29 2979使用Ibatis作为数据库持久层的人都有体会,Ibatis 对 ... -
hibernate分页
2010-06-30 15:34 1091public List<Content> find ... -
Hibernate Annotation简单实现
2010-04-21 15:38 2119<!--[if !supportLists]--> ...
相关推荐
Hibernate不仅仅管理Java类到数据库表的映射(包括Java数据类型到SQL数据类型的映射),还提供数据查询和获取数据的方法,可以大幅度减少开发时人工使用SQL和JDBC处理数据的时间。 Hibernate的目标是对于开发者...
--此处hibernate 的映射采用的是.xml 配置则应设置为:class=”org.springframework.orm.hibernate3.LocalSessionFactoryBean”--> <property name="dataSource" ref="dataSource" /> <prop key="...
请你谈谈对Hibernate OR映射的理解? 答:将数据库中的每一张表都映射成一个实体。 配置了lazy="true"一定会懒加载吗? 答:不一定,如果在配置中你也使用了fetch属性的话此时lazy就会失效。 Hibernate数据库标识与...
使用ibatis 提供的ORM 机制,对业务逻辑实现人员而言,面对的是纯粹的Java 对象, 这一层与通过Hibernate 实现ORM 而言基本一致,而对于具体的数据操作,Hibernate 会自动生成SQL 语句,而ibatis 则要求...
查询出列表,也就是返回list, 在我们这个例子中也就是 List<User> , 这种方式返回数据,需要在User.xml 里面配置返回的类型 resultMap, 注意不是 resultType, 而这个resultMap 所对应的应该是我们自己配置的 ...
5. 校验,数据绑定,BeanWrapper,与属性编辑器 5.1. 简介 5.2. 使用Spring的Validator接口进行校验 5.3. 从错误代码到错误信息 5.4. Bean处理和BeanWrapper 5.4.1. 设置和获取属性值以及嵌套属性 5.4.2. 内建...
表结构元数据的API也向用户开放,同时支持在使用过程中,灵活调整映射关系,因此用户可以用API动态的创建表结构的模型,从而实现各种动态类型和表的映射(例如POJO中包含一个Map,用于映射各种动态扩展的字段)企业...
Actions: @{…} or @@{…} - 46 - Messages: &{…} - 46 - Comment: *{…}* - 46 - Scripts: %{…}% - 46 - Template inheritance继承 - 47 - 定制模板标签 - 48 - 检索tag参数 - 48 - 调用标签体 - 48 - 格式化特定...
Actions: @{…} or @@{…} - 46 - Messages: &{…} - 46 - Comment: *{…}* - 46 - Scripts: %{…}% - 46 - Template inheritance继承 - 47 - 定制模板标签 - 48 - 检索tag参数 - 48 - 调用标签体 - 48 - 格式化特定...
如果你觉得hibernate难以驾驭,或许该软件正是你所想要的 如果你觉得mybatis成堆的xml/mapper太繁琐,或许该软件正是你所想要的 如果你觉得现有的ORM软件总有那么些不太满意的地方,...