默认情况下使用 Oracle 数据库时,Hibernate 将布尔数据类型映射到啥?

Posted

技术标签:

【中文标题】默认情况下使用 Oracle 数据库时,Hibernate 将布尔数据类型映射到啥?【英文标题】:What does Hibernate map a boolean datatype to when using an Oracle database by default?默认情况下使用 Oracle 数据库时,Hibernate 将布尔数据类型映射到什么? 【发布时间】:2010-12-15 04:13:38 【问题描述】:

默认情况下,如果我在如下实体中创建字段:

@NotNull
boolean myBoolean;

我让 Hibernate 自动创建我的表。这将映射到什么 Oracle 数据类型?

【问题讨论】:

那里的注解对生成的schema有任何意义吗? 【参考方案1】:

这才是你真正需要的

Java POJO

//@Type(type="true_false") //not working for '1' and '0' in NUMERIC(1) field
@Type(type= "org.hibernate.type.NumericBooleanType")
@NotNull(message="NOT_NULL")
@Column(name = "IS_DELEGATION", nullable = false)
private Boolean isDelegation;

Oracle DDL

alter table agent add (is_delegation number(1) default 0 not null);

如中所述 Hibernate docu

【讨论】:

【参考方案2】:

正如@Arthur 所说,它映射到Number(1),这将是0 == false1 == true 的标准sql 位。作为替代方案,您可以像这样将char(1) 映射到“T”或“F”

@org.hibernate.annotations.Type(type="true_false")
@NotNull
boolean myBoolean;

或将其映射到“Y”或“N”

@org.hibernate.annotations.Type(type="yes_no")
@NotNull
boolean myBoolean;

【讨论】:

是否也可以使用 xml 示例? @rogerdpack 【参考方案3】:

简单数字(1)

如果您愿意,可以使用 SchemaExport 为您的目标数据库生成一个脚本。类似的东西

AnnotationConfiguration configuration = new AnnotationConfiguration();

configuration
    .addAnnotatedClass(<TYPE_YOUR_CLASS>.class)
    .setProperty(Environment.USER, <TYPE_YOUR_USER>)
    .setProperty(Environment.PASS, <TYPE_YOUR_PASSWORD>)
    .setProperty(Environment.URL, <TYPE_YOUR_URL>)
    .setProperty(Environment.DIALECT, <TYPE_YOUR_DIALECT>)
    .setProperty(Environment.DRIVER, <TYPE_YOUR_DRIVER>);

SchemaExport schema = new SchemaExport(configuration);
schema.setOutputFile("schema.sql");

schema.create(<DO_YOU_WANT_TO_PRINT_TO_THE_CONSOLE>, <DO_YOU_WANT_TO_EXPORT_THE_SCRIPT_TO_THE_DATABASE>);

【讨论】:

以上是关于默认情况下使用 Oracle 数据库时,Hibernate 将布尔数据类型映射到啥?的主要内容,如果未能解决你的问题,请参考以下文章

Oracle中插入默认时间

hiber

ORACLE中创建如何创建表,并设置结构和默认值

Oracle 11g R2 管理归档日志文件

单纯修改oracle归档路径需要关闭数据库吗

oracle数据库表空间占用太大,如何在不删除表的情况下缩小占用空间