web-dev-qa-db-ja.com

デフォルトでOracleデータベースを使用する場合、Hibernateはbooleanデータ型を何にマップしますか?

デフォルトでは、次のようなエンティティにフィールドを作成すると:

@NotNull
boolean myBoolean;

そして、Hibernateにテーブルを自動作成させました。これはどのOracleデータ型にマップされますか?

31
Peter D

単に数字(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>);
20
Arthur Ronald

@Arthurが言ったように、それはNumber(1)にマッピングされます。これは_0 == false_と_1 == 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;
_
55
non sequitor

これは本当に必要なものです

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 doc で述べられているように

7