GVKun编程网logo

为什么要指定@Column(nullable = false)?(为什么要指定科目)

25

在这里,我们将给大家分享关于为什么要指定@Column的知识,让您更了解nullable=false?的本质,同时也会涉及到如何更有效地@javax.persistence.Column(updata

在这里,我们将给大家分享关于为什么要指定@Column的知识,让您更了解nullable = false?的本质,同时也会涉及到如何更有效地@ javax.persistence.Column(updatable = false)、@ManyToOne(optional = false)与@Column(nullable = false)有什么区别、asp.net-mvc – HiddenInput(DisplayValue = false)] vs [ScaffoldColumn(false)]、c# – 与IsNullable冲突的配置设置= true IsNullable = false重用ComplexType的内容。

本文目录一览:

为什么要指定@Column(nullable = false)?(为什么要指定科目)

为什么要指定@Column(nullable = false)?(为什么要指定科目)

我有一个带注释的实体@Entity
如果我负责创建CREATE TABLE脚本,为什么要指定@Column( nullable = false )何时可以使用NOTNULL关键字在数据库中创建列?是否有任何示例显示在字段中使用此属性的好处?

答案1

小编典典

更好的错误消息和错误处理,尤其是如果您还添加了JSR303
@NotNull批注。

如果您将列创建为,NOTNULL但不告诉JPA它不是null,则JPA会假定null值可以。当您尝试使用空值保存对象时,它将继续将其发送到数据库,并且您会收到数据库级别的错误。这会增加数据库中的日志垃圾邮件,并且从错误中很难确定哪个表的哪一列是问题,更不用说将它们映射回其JPA名称了。

如果将它们注释为非null,则JPA将在保存之前引发异常,避免DB日志垃圾邮件,并且通常会给您带来更好的错误。特别是,如果你的JPA提供支持JSR303,要么转化nullable=false@NotNull内部或你添加@NotNull过,它会给你一个数据结构,你可以检查,看看是什么对象被拒绝的原因是什么什么领域,具有自定义模板一起错误消息。

这就是为什么您应该向JPA告知有关NOT NULL字段的原因。这样,其他编写您的代码的人就更容易理解,而不必阅读数据库模式。

@ javax.persistence.Column(updatable = false)

@ javax.persistence.Column(updatable = false)

如果我将字段定义为不可更新,这是否意味着该字段永远无法更新?我想做的是在保存整个实体对象时防止字段更新,但仍然能够编写显式更新此字段的查询。这可能吗?

我正在使用Hibernate和MySQL,但我更愿意编写可移植的代码。

答案1

小编典典

作为记录,设置updatable=false只影响SQL
UPDATE语句 产生 的持久性提供:

该列是否包含在持久性提供程序生成的SQL UPDATE语句中。

您仍然能够编写这样的SQL更新语句,以更新此列中的值。此功能在JPA规范中定义,并非特定于Hibernate / MySQL。

@ManyToOne(optional = false)与@Column(nullable = false)有什么区别

@ManyToOne(optional = false)与@Column(nullable = false)有什么区别

在JPA中,我什么时候使用属性optional=false和注释感到困惑@Column(nullable=false)。有什么区别?

答案1

小编典典

@Column(nullable=false)是用于生成架构的指令。在类中生成的数据库列将在实际数据库中标记为不可为空。

optional=false是运行时指令。它所做的主要功能是与延迟加载有关。您不能延迟加载非集合映射的实体,除非您记得设置了optional =
false(因为Hibernate不知道那里应该有一个代理还是一个null,除非您告诉它null是不可能的,否则它可以生成代理人。)

asp.net-mvc – HiddenInput(DisplayValue = false)] vs [ScaffoldColumn(false)]

asp.net-mvc – HiddenInput(DisplayValue = false)] vs [ScaffoldColumn(false)]

什么是Exaclty ScaffoldColumn(false)和HiddenInput(displayValue = false)?

这两者之间的主要区别是什么?哪一个最好用?

谢谢!!!

解决方法

[ScaffoldColumn(false)]告诉Visual Studio在为视图生成模板时不支持列.创建新视图时,可以创建强类型视图.当你这样做Visual Studio询问你要使用什么模板(创建,编辑,列表等).如果您创建一个编辑/创建模板;例如,如果您将[ScaffoldColumn(false)]放在模型属性上,那么它将不会在模板中生成displayFor()或EditorFor()调用,因此它不会包含在视图中.

[HiddenInput]会告诉displayFor / EditorFor方法,它应该为该值创建一个隐藏的html字段.当您发布到表单时,它将被包含在值中,但当人们看到它时,它将被视为“隐藏”.

c# – 与IsNullable冲突的配置设置= true IsNullable = false重用ComplexType

c# – 与IsNullable冲突的配置设置= true IsNullable = false重用ComplexType

我不知道这种行为是设计的还是EF6中的错误,或者还有另一种方法可以做到这一点.有这种复杂的类型:

[ComplexType]
public partial class Company    
    public bool HasValue { get { return !string.IsNullOrEmpty(this.Name); } }

    [MaxLength(100)]
    public string Name { get; set; }

    [MaxLength(20)]
    public string PhoneNumber { get; set; }

    [MaxLength(128)]
    public string EmailAddress { get; set; }
}

我在这两个实体中重用它:

public partial class Customer
{
    public Customer ()
    {
        this.Company = new Company();       
    }

    [Key]
    public int IdCustomer { get; set; }

    [MaxLength(100)]
    [required]
    public string FirstName { get; set; }

    [MaxLength(100)]
    [required]
    public string LastName { get; set; }

    public Company Company { get; set; }

    public virtual AcademicInfo AcademicInfo { get; set; }
}


public partial class AcademicInfo
{       
    public AcademicInfo()
    {
        this.Organization = new Company();
    }       

    [Key,ForeignKey("Customer")]
    public int IdCustomer { get; set; }

    public Company Organization { get; set; }

    [MaxLength(100)]
    public string Subject { get; set; }

    [MaxLength(100)]
    public string Degree { get; set; }

    public virtual Customer Customer { get; set; }
}

在dbcontext的OnModelCreating中(编辑:为了简单起见,我添加了之前省略的FK代码):

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{    
    modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();

    // ... Other code here related to entities not related to the problem reported omitted to avoid confusion.

    modelBuilder.Entity<AcademicInfo>()
            .Hasrequired(a => a.Customer)
            .WithOptional(c => c.AcademicInfo)
            .WillCascadeOnDelete(true);

    modelBuilder.Entity<Customer>()
            .Property(p => p.Company.Name)
            .HasColumnName("CompanyName")
            .IsOptional(); // CONFLICT HERE
    modelBuilder.Entity<Customer>()
            .Property(p => p.Company.EmailAddress)
            .HasColumnName("CompanyEmailAddress")
            .IsOptional();  //CONFLICT HERE
    modelBuilder.Entity<Customer>()
            .Property(p => p.Company.PhoneNumber)
            .HasColumnName("CompanyPhoneNumber")
            .IsOptional();

    modelBuilder.Entity<AcademicInfo>()
            .Property(a => a.Organization.Name)
            .HasColumnName("OrganizationName")
            .Isrequired(); // CONFLICT
    modelBuilder.Entity<AcademicInfo>()
            .Property(a => a.Organization.EmailAddress)
            .HasColumnName("OrganizationEmail")
            .Isrequired(); // CONFLICT
    modelBuilder.Entity<AcademicInfo>()
            .Property(a => a.Organization.PhoneNumber)
            .HasColumnName("OrganizationPhone")
            .IsOptional();
}

Add-Migration命令失败,并显示以下错误:
为’Company’类型的属性’Name’指定了冲突的配置设置:
    IsNullable =与IsNullable = True的错误冲突

但它没有任何意义,因为我在AcademicInfo表中定义了不可为空的字段,在Customer表中定义了可为空的字段.

解决方法

这是一个老问题,但仍然适用于EF版本6.1.3.

根据this issue,行为是关于如何配置特定复杂类型的实体框架限制.

This is a limitation of EF,some property facets need to be stored in C-Space and EF doesn’t have a way of configuring a particular usage of a complex type. So you can only specify different S-Space facets like ColumnName or ColumnType

我们今天的关于为什么要指定@Columnnullable = false?的分享就到这里,谢谢您的阅读,如果想了解更多关于@ javax.persistence.Column(updatable = false)、@ManyToOne(optional = false)与@Column(nullable = false)有什么区别、asp.net-mvc – HiddenInput(DisplayValue = false)] vs [ScaffoldColumn(false)]、c# – 与IsNullable冲突的配置设置= true IsNullable = false重用ComplexType的相关信息,可以在本站进行搜索。

本文标签: