代码之家  ›  专栏  ›  技术社区  ›  Peter D

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

  •  30
  • Peter D  · 技术社区  · 15 年前

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

    @NotNull
    boolean myBoolean;
    

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

    3 回复  |  直到 9 年前
        1
  •  19
  •   Arthur Ronald    15 年前

    简单数字(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>);
    
        2
  •  55
  •   non sequitor    15 年前

    正如@Arthur所说,它映射到 Number(1) 哪一个是标准的SQL位 0 == false 1 == true . 作为替代方案,你可以绘制 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;
    
        3
  •  6
  •   bish    9 年前

    这是你真正需要的

    爪哇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