hibernate 处理text 字段,像处理字符串一样

建表脚本:

/*==============================================================*/
/* Table: StoreFile */
/*==============================================================*/
create table StoreFile (
uuid VARCHAR2(128) not null,
name VARCHAR2(200),
text CLOB,
constraint PK_STOREFILE primary key (uuid)
);

hibernate.cfg.xml:(注意多了个SetBigStringTryClob设置,其它没有什么特殊的了)

<?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>
<property name="hibernate.cglib.use_reflection_optimizer">true</property>
<property name="hibernate.connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
<property name="hibernate.connection.password">java</property>
<property name="hibernate.connection.url">jdbc:oracle:thin:@10.128.4.69:1521:kf</property>
<property name="hibernate.connection.username">java</property>
<property name="hibernate.connection.SetBigStringTryClob">true</property>
<property name="hibernate.cache.provider_class">org.hibernate.cache.OSCacheProvider</property>
<property name="hibernate.show_sql">true</property>
<property name="hibernate.format_sql">true</property>
<property name="hibernate.dialect">org.hibernate.dialect.Oracle9Dialect</property>
<mapping resource="com/study/database/hb/map/File.hbm.xml"/>
</session-factory>
</hibernate-configuration>

File.hbm.xml文件

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 2006-3-13 17:57:00 by Hibernate Tools 3.1.0.beta4 -->
<hibernate-mapping>
<class name="com.study.database.hb.map.File" table="StoreFile" batch-size="0">
<id name="uuid" type="string">
<column name="UUID" length="128" />
<generator class="uuid.hex"></generator>
</id>
<property name="name" type="string" lazy="false">
<column name="NAME" length="200"/>
</property>
<property name="file" type="string" lazy="false">
<column name="text" />
</property>
</class>
</hibernate-mapping>

File.java文件

package com.study.database.hb.map;
// Generated 2006-3-13 17:57:00 by Hibernate Tools 3.1.0.beta4

import java.sql.Clob;
/**
* File generated by hbm2java
*/

public class File
implements java.io.Serializable
{
// Fields

private String uuid;
private String name;
private String file;
// Constructors

/** default constructor */
public File()
{
}
/** full constructor */
public File(String name,String file)
{
this.name=name;
this.file=file;
}
// Property accessors

public String getUuid()
{
return this.uuid;
}
public void setUuid(String uuid)
{
this.uuid=uuid;
}
public String getName()
{
return this.name;
}
public void setName(String name)
{
this.name=name;
}
public String getFile()
{
return this.file;
}
public void setFile(String file)
{
this.file=file;
}
}
//比以前特殊的地方是hibernate.cfg.xml多了个SetBigStringTryClob设置。

//把clob映射成string类型,这样在多过4000个字符时也不会出错了。操作方法和普通的string类型一样。
### 回答1: 关于您的问题,我可以给出回答。在使用 Hibernate 时,当将字段设置为空字符串时,Hibernate 会将该字段插入数据库中,但是该字段的值将变为 NULL。这是因为在数据库中,空字符串和 NULL 值是不同的概念,空字符串表示该字段有值但为空,而 NULL 表示该字段没有值。如果您希望将空字符串保存到数据库中而不是变为 NULL,可以使用 Hibernate 的 @Column 注解的 nullable 属性设置为 false,如下所示: @Column(nullable = false) private String yourFieldName; 这将强制 Hibernate 将空字符串插入到数据库中。 ### 回答2: 在使用Hibernate进行数据插入时,如果将字段设置为空字符串,并且这个字段在数据库的表结构中不允许为空(即设置了NOT NULL约束),那么Hibernate会将该字段的值插入为NULL。 这是因为Hibernate遵循数据库的约束规则,在某些数据库中,将空字符串插入到不允许为空的字段会导致异常。为了避免这种情况,Hibernate会自动将空字符串转换为NULL来符合数据库的约束规则。 如果开发者想要将空字符串插入到数据库的某个字段中,可以考虑以下两种方法: 1. 更改数据库表结构:将对应字段的约束改为允许为空,这样就可以插入空字符串了。 2. 使用自定义的setter方法:在实体类中添加一个setter方法,在方法体中判断,如果传入参数为null或空字符串,则将其设置为一个自定义的值(例如"空"),这样就可以将空字符串插入到数据库中了。 总之,使用Hibernate时,当字段设置为空字符串,但数据库表结构不允许为空时,Hibernate会将其插入为NULL,为了避免这种情况,可以修改表结构或自定义setter方法进行处理。 ### 回答3: 在使用Hibernate时,当将字段设置为空字符串并尝试插入数据库时,该空字符串会被转换为NULL值。 这是因为Hibernate通过空间极小的Sequence Generator来判断实体是否有自动生成的主键。当字段被设置为为空字符串时,Hibernate会将其内部的字符串数据处理为空,因此在插入数据库时会将其转换为NULL。 为了避免将空字符串转换为NULL值,我们可以通过在实体的属性上设置注解来解决此问题。我们可以使用@NotEmpty注解来确保字段不为空字符串,例如: ``` @Entity public class ExampleEntity { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @NotEmpty private String field; // 省略 getter 和 setter 方法 } ``` 通过将@NotEmpty注解添加到字段上,Hibernate将不允许将该字段设置为空字符串,并在插入时验证注解的条件,如果字段为空字符串,将抛出异常。 另外,可以考虑使用@NotBlank注解来确保字段既不为空字符串也不为空白字符串,并且还可以使用@Column(nullable = false)来在数据库层面上强制该字段不为空。 综上所述,使用Hibernate时,当字段被设置为空字符串并插入数据库时,会被转换为NULL值。我们可以通过标记注解来限制字段不为空字符串,从而避免将其转换为NULL值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值