MySQL字段的属性应该尽量设置为NOT NULL

数据库建表时,对于一些可填可不填的字段,我们应该尽量把它设置为 NOT NULL。这种做法即可以提高性能,又可以在很大程度上避免空指针类的问题,好处颇多。

1.节省空间

NULL 列需要更多的存储空间:需要一个额外字节作为判断是否为 NULL 的标志位。

2.空指针

查询时,可以在一定程度上减少 NullPointerException。

3.减少因为空值而出现的计算错误

如果有 Null column 存在的情况下,count(NULL column) 需要格外注意,NULL 值不会参与统计。

4.索引

含有空值的列很难进行查询优化,而且对表索引时不会存储 NULL 值的。所以如果索引的字段可以为 NULL值,索引的效率会下降。因为它们使得索引、索引的统计信息以及比较运算更加复杂。

应该用0、一个特殊的值或者一个空串代替 NULL值。

5.使用 != ,NOT IN 的情况

NOT IN 、!= 等负向条件查询在有 NULL 值的情况下,返回永远为空结果,查询容易出错。

以上仅是本人最近学习所做的总结和思考,有不对的地方欢迎指正。

原文地址:https://www.cnblogs.com/xiao1997/p/10290306.html

时间: 2024-11-05 15:20:21

MySQL字段的属性应该尽量设置为NOT NULL的相关文章

MySQL字段属性介绍

这次Qi号分享MySQL字段属性简介.下面资料是Qi号搜集大量资料与个人理解的整理.看到最后有福利哦基友们 前言 MySQL提供了一组可以赋给表中各个列的数据类型,每个类型都强制数据满足为该数据类型预先确定的一组规则,例如大小.类型及格式. 这里先总结数据类型.MySQL中的数据类型大的方面来分,可以分为:日期和时间.数值,以及字符串.下面就分开来进行总结. 日期和时间数据类型 MySQL数据类型   含义 date 3字节,日期,格式:2014-09-18 time 3字节,时间,格式:08:

【转】为什么要对字段封装属性

为什么要对字段封装属性? 每次有新人来,都要问这个问题,我直接对字段操作多省事呀,就像这样: public class A{   public  string _Name;    }public Class B{   private A _MyA;   public void DoB(string n)   {      _MyA._Name=n;   }} 很多砖家会毫不犹豫的说,你这样"封装不好",于是新人眨着两只无神而又水汪汪的大眼睛,分明是在说:"这不脱了裤子放X吗&

深入理解c#的字段与属性

属性 属性的作用就是保护字段,对字段的赋值和取值进行限定 属性的本质就是两个方法,一个叫get()对取值进行限定,一个叫set()对存值进行限定,属性只是对属性的再赋值. 如果只有get是只读属性,set是只写属性.在get里面用的值是字段的值,set里面用的是value的值 所以在类里面的public 方法要访问私有字段,尽量访问属性,虽然这样可能会降低访问的效率,但是一方面会更安全地访问字段,另一方面可能是必须经过属性里的某个方法的处理才能得到这个字段的值. 代码风格 下面的例子展示了使用属

C#<字段与属性的区别>

因为以前用JAVA时候习惯使用属性,然后到C#后很少使用属性,一般用公有字段来做代替,今天为了了解这些区别特意看了一下这方面的知识. 从两者的声明上来看,公共字段只是类用public修饰符所公开的简单公共变量,而属性则是对字段的封装,它使用get和set访问器来控制如何设置或返回字段值. 由于属性是get.set方法,它的本质是方法来进行修改赋值,所以在使用上,公有字段的效率要比属性传递更快. 但是,按照面向对象的要求来说,属性是通过get().set()来给外界调用的,而字段是给类内部使用的.

1128 聚合查询 orm字段及属性

目录 一 聚合查询 1. 级联 级联删除 级联更新 2. 聚合函数 使用 aggregate 使用场景 3. 分组查询 语法 使用 annotate 代码 4. F与Q查询 F查询 Q查询 二 ORM字段及参数 1.ORM字段 常用字段 不常用字段 字段合集 2. 关系字段 ForeignKey():外键字段 OneToOneField():一对一外键字段 ManyToManyField():多对多关系字段 3. 字段属性 null unique db_index default 4. 自定义字

C#.NET中的字段与属性_1

一个类中需要有描述这个类信息的数据,而存储这些数据的变量就成为字段. 字段默认的访问级别为private(只有本类可以直接访问),我们将其访问级别改为public,在其他类中就可以访问了. 字段和属性表示对象包含的信息,字段类似于变量,因为可以直接读取或设置他们. 属性是对字段的封装.属性可以对字段的访问进行控制,可以进行非法设置值的判断.属性并不存储数据,字段存储数据. 封装后,有一些字段我只能赋值,不能读取,有些只能读取,不能赋值,而且可以对传过来的值进行选择. 建议所有的字段不要写成pub

Hibernate关于字段的属性设计

1.大文本 @Column(columnDefinition="LONGTEXT") //使用大文本字段 private String content; 2.不可更改,不为空 @Column(updatable = false,nullable=false) 3.时间戳字段,并设置默认值 @Column(columnDefinition="timestamp default CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP"

C#中的类:字段、属性、方法

C++的类中可以有三种内容:成员变量.成员函数和友元. 一般来说,成员变量描述类的属性,成员函数描述类的操作,友元则是一种特殊的声明,被声明为友元的函数或类可以操作自己的私有成员变量和成员方法. 在Java中,类的成员有两类:属性,相当于C++的成员变量:方法,相当于C++的成员函数. 而在C#中,类的成员有四种:字段.属性.方法和事件(事件还没学到,暂缓解释). 字段相当于C++中的成员变量和Java中的属性,就是在类中定义的变量(可以是基本类型或引用类型),一般来说,字段都被定义为私有. 方

c# 字段和属性

一.字段(field) 可以在声明字段的同时赋给它一个初始值. 二.属性(property) 1.引入 假如将字段声明为public,则在类的外部都可以对该字段进行访问和更改,违背了类的封装特性.如果声明为private,则这种形式的封装通常又过于彻底.例如,你可能希望字段从外部只读,但从内部可以更改,但需要验证对数据进行的更改. 以前,程序语言为了实现这些要求,采取的办法是将字段标记为私有,然后提供取值和赋值的方法来访问和修改数据.遗憾的是,这样做会影响类的可编程性.无法再用赋值运算符来设置类