首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

用了这么多年MySql,这些好习惯你用过哪些

NOT NULL),且定义默认值   说明:3.1:NOT IN、!...  3.3:当用count函数进行统计时,NULL 列不会计入统计   3.4:因为NULL的列使得索引,索引统计和值比较都更复杂,可为NULL的列会使用更多的存储空间,在mysql里也需要特殊处理,...4.每个表有自增列id且为主键,使用无符号类型unsigned,不作业务逻辑使用   说明:4.1:避免存储负值,且扩大了表示范围   4.2:如果使用非自增主键(如果身份证号或学号等),由于每次插入主键的值近似于随机...int 4 无符号:0-42.9亿 太阳 约50亿年 unsigned bigint 8 无符号:0-约10的19次方 二:增删改查好习惯 1.SELECT语句指定具体字段名称,禁止写成*,select...,否则无法利用索引 4.在多表join中,尽量选取结果集较小的表作为驱动表,来join其他表 5.插入列列表与值列表个数相同,上面二者的个数需要相同,如果没有指定列列表,则值列表长度要与表列数相同。

74200

为什么数据库字段要使用NOT NULL?

基于目前大部分的开发现状来说,我们都会把字段全部设置成NOT NULL并且给默认值的形式。 通常,对于默认值一般这样设置: 整形,我们一般使用0作为默认值。...如果查询中包含可为NULL的列,对MySql来说更难优化,因为可为NULL的列使得索引、索引统计和值比较都更复杂。可为NULL的列会使用更多的存储空间,在MySql里也需要特殊处理。...而言,如果不主动设置为NOT NULL的话,那么插入数据的时候默认值就是NULL。...举个例子,一张表中的某一条name字段是NULL,我们可以认为不知道名字是什么,反之如果是空字符串则可以认为我们知道没有名字,他就是一个空值。...对于现状大部分使用MyBatis的情况来说,我建议使用默认生成的insertSelective方法或者纯手动写插入方法,可以避免新增NOT NULL字段导致的默认值不生效或者插入报错的问题。

1.9K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    3分钟短文:书接上回,Laravel数据库迁移的那些个小技巧

    引言 使用laravel的数据库迁移功能进行表的创建,和迁移回滚之后,我们继续说说在设计中 表结构的更改之后的处理。以及如何为数据库填充一些伪数据作为测试。...很多时候,并不是说我们创建了表,并且指定了字段名,和字段数据类型就算完事儿了。 我们需要空与非空约束,默认值约束,主键约束,外键约束等等数据库所具有的特性, 这才是关系型数据库的魅力。...->string('comments')->nullable(); 比如设定整型为无符号数: $table->tinyInteger('age')->unsigned(); 在给上面的 age 字段设定默认值...: $table->tinyInteger('age')->unsigned()->default(0); 增删字段 使用迁移功能增删数据库表的字段,与之前讲的创建迁移文件相同, 首先创建一个迁移文件,...大家应该不陌生SQL语句追加字段的语法: ALTER TABLE contacts ADD last_name varchar(40) NOT NULL AFTER contact_id; laravel

    1.7K30

    数据库约束-主键约束-唯一约束-非空约束-默认值

    数据库约束-主键约束-唯一约束-非空约束-默认值 约束概述 约束其实就是一种限制,用于修饰表中的列. 通过这种限制来保证表中数据的正确性、有效性和完整性。...(主键不可为空): Column 'id' cannot be null INSERT INTO user1 VALUES(1,'tom'); -- 插入异常(主键不可重复): Duplicate entry...非空约束 NOT NULL 被修饰的这个字段必须设置值,不能是NULL 3.1 非空约束的基本格式 字段名 字段类型 NOT NULL 3.2 实现非空约束 具体操作: 创建表学生表st8, 包含字段(...默认值 DEFAULT 往表中添加数据时,如果不指定这个字段的数据,就使用默认值 4.1 默认值格式 字段名 字段类型 DEFAULT 默认值 4.2 实现字段默认值 具体操作: 创建一个学生表 st9...address VARCHAR(50) DEFAULT '广州' -- 设置默认值 -> ); Query OK, 0 rows affected (0.02 sec) -- 插入一条数据,不填写

    6.4K10

    .NET中可空值类型实现原理

    ,System.Int32,具体实现代码如下: //因为Object类中的GetType方法不允许子类重写(避免子类隐藏自己的实际类型) //所以这里使用关键字new来隐藏Object类中的GetType...方法 public new Type GetType() { return innerValue.GetType(); } 结论:没有可为空的值类型 至此,我们已经自定义了一个可为空的值类型XfhNullable...,通过以上代码,我们不难发现所谓可为空的值类型是不存在的,它是通过属性HasValue来对null值进行标记的,其内部通过字段innerValue(该字段对应Nullable中的value字段...换句话说,Nullable只是在逻辑层面上实现了把null赋值给值类型,给我们一种值类型可为null的感觉。 最后说下可空值类型的装箱与拆箱。...转载必须保留文章的完整性,且在页面明显位置处标明原文链接。 如有问题, 请发送邮件和作者联系。

    1K20

    mysql修改、增加、删除字段名等命令

    Mysql 一、.mysql修改 1.修改字段类型、字段名、字段注释、字段默认值 #修改字段类型、字段注释、字段默认值 ALTER TABLE 表名 MODIFY [COLUMN] 字段名 新数据类型...新类型长度 新默认值 新注释; -- COLUMN关键字可以省略不写 alter table box modify column boxnum varchar(40) not null comment...ALTER TABLE 表名 COMMENT '新注释' alter table box comment '座位表' 5.在指定位置插入新字段 ALTER TABLE 表名 ADD [COLUMN]...字段名 字段类型 是否可为空 COMMENT '注释' AFTER 指定某字段 ; --COLUMN关键字可以省略不写 alter table box add column boxroom varchar...//增加一个字段,默认为空 alter table box add column boxroom int 10 default null comment '座位空间' //增加一个字段,默认不为空

    1.3K20

    MySQL字段默认值设置详解

    前言: 在 MySQL 中,我们可以为表字段设置默认值,在表中插入一条新记录时,如果没有为某个字段赋值,系统就会自动为这个字段插入默认值。...1.默认值相关操作 我们可以用 DEFAULT 关键字来定义默认值,默认值通常用在非空列,这样能够防止数据表在录入数据时出现错误。...,插入数据时,若不指定该字段的值,则以默认值处理。...那这个字段推荐使用 tinyint 类型,而不应该使用 char 或 varchar 类型。 笔者结合个人经验,总结下关于默认值使用的几点建议: 非空字段设置默认值可以预防插入报错。...默认值同样可设置在可为 null 字段。 一些状态值字段最好给出备注,标明某个数值代表什么状态。 默认值要和字段类型匹配。

    10.5K10

    3分钟短文:Laravel请求对象方法极多,可不是花拳绣腿

    我们这样便捷地定义: Route::post('form', function (Illuminate\Http\Request $request) { // $request->input()}); 在匿名函数中...两者的请求方法不一样。 那么对于用于csrf拦截的字段_token,系统生成,系统自检,我们在表单中并不使用, 可以使用 except 方法将其排除在外。...这两者是有细微区别的,has方法要求键名存在,且数值不为空;exists方法仅要求键名存在。...if ($request->has('invalid_key')) {} 比如上方的代码键名不存在,所以返回 false。如果表单字段 firstName 不填任何值,也即是空字符串。...$userName = $request->input('name', 'anonymous');}); 第二个参数是指定如果键名不存在时的默认值。

    1.4K20

    MySQL面试题(一)

    不超过 255 个字符的二进制字符串 TINYTEXT(tiny text) 0-255 短文本字符串 BLOB(blob) 0-65 535 二进制形式的长文本数据 TEXT(text) 0-65...因为如果查询中包含可为 NULL 的列对 MySQL 来说更难优化,可为 NULL 的列使索引、索引统计 和 值比较 都更复杂,并且会使用更多存储空间。...当可为 NULL 的列被索引时,每个索引记录需要一个额外字节,在 MyISAM 中还可能导致固定大小的索引变成可变大小的索引。 如果计划在列上建索引,就应该尽量避免设计成可为 NULL 的列。 2....假设主键是学号或课程名称,我们新增了某个课程,需要把数据插入到表中,这时,可能只有部分人有选修这门课程,那我们插入数据的时候还要规定给哪些人插入对应的课程信息,同时可能由于成绩还没有,我们需要对成绩置空...假设主键是学号和课程名称的联合主键。同样也是新增了某课程,但是暂时没有人选修这门课,缺少了学号主键字段数据,会导致课程信息无法插入。 第三范式(3NF):在满足第二范式的情况下,消除传递依赖。

    36520

    Laravel迁移数据库!

    我们本期要使用laravel自带的迁移功能,在不操作任何数据库的条件下,完成基础的数据构建。 迁移文件 本文假设你已经正确地配置了环境变量文件,并且通过数据库配置项,系统已经可以正常连接到数据库了。...而在 laravel 里对一个空表修改字段,完全可以通过,我们创建新的迁移文件,然后在 up 方法内这样调用: $table->string('name', 100)->change(); 看,只用调用一个...('deleted_at')->nullable()->change(); 对于插入新的字段,还可以指定位于哪个字段之前或者之后: $table->string('email')->nullable()...->after('last_name'); 仅仅修改字段名,只需调用对应方法: $table->renameColumn('promoted', 'is_promoted'); 或者在回滚方法中对某些新增的字段进行删除...上面给的这些个方法,足够应对很多很多场景了。 写在最后 本文介绍了laravel中使用迁移功能操作数据库的创建,修改,移除字段,删除表等,把开发者从手动维护数据库的状态中解脱出来。

    98610

    Laravel迁移数据库!

    我们本期要使用laravel自带的迁移功能,在不操作任何数据库的条件下,完成基础的数据构建。 迁移文件 本文假设你已经正确地配置了环境变量文件,并且通过数据库配置项,系统已经可以正常连接到数据库了。...而在 laravel 里对一个空表修改字段,完全可以通过,我们创建新的迁移文件,然后在 up 方法内这样调用: $table->string('name', 100)->change(); 看,只用调用一个...('deleted_at')->nullable()->change(); 对于插入新的字段,还可以指定位于哪个字段之前或者之后: $table->string('email')->nullable()...->after('last_name'); 仅仅修改字段名,只需调用对应方法: $table->renameColumn('promoted', 'is_promoted'); 或者在回滚方法中对某些新增的字段进行删除...上面给的这些个方法,足够应对很多很多场景了。 写在最后 本文介绍了laravel中使用迁移功能操作数据库的创建,修改,移除字段,删除表等,把开发者从手动维护数据库的状态中解脱出来。

    1.1K00

    Laravel Eloquent 模型关联关系(下)

    注:实际开发中为了提高查询性能,我们往往是在 posts 表中冗余提供一个 comments_count 字段,每新增一条评论,该字段值加 1,查询的时候直接取该字段即可,从而提高查询的性能。...>orderBy('created_at', 'desc'); }]); 关联插入与更新 一对多关联记录插入 新增关联模型的时候,可以在父模型上调用相应方法直接插入记录到数据库,这样做的好处是不需要指定关联模型与父模型的外键关联字段值...空对象模型 如果外键字段 user_id 允许为空的话,当我们访问 Post 模型上的 author 属性时,默认返回为 null。...'name' => '游客用户', ]); } 再次访问对应 Post 模型上的 author 属性时,就会返回如下默认的空对象了: 该特性其实应用了设计模式中的空对象模式...多对多关联的绑定与解除 在插入多对多关联记录的时候,可以通过上面一对多关联记录插入的方式。

    19.6K30

    大战SQL列类型及其列属性

    简述其数值原理: 原理:集合中每一个元素都是对应一个对应的二进制位,比如3,二进制位为0011,在集合中,每一个元素都是对应一个二进制位,被选中为1,没有则为0;最后反过来。...实际上是不行的,因为MySQL记录中:如果任何一个字段允许为空,那么系统会自动从整个记录中保留一个字节来存储NULL,若想释放NULL所占用的字节:必须保证所有的字段都不允许为空。...空属性 两个值:NULL(默认的)和NOT NULL(不为空) 数据值是默认的,且数据库基本都是字段为空;但是实际上在开发的时候,是需要尽可能的保证所有的数据都不应该为空:因为空数据无意义,也没有办法参与运算...列描述(注释) 列描述:comment,起描述作用,无实际意义。是专门用来描述字段,根据表的创建语句一起保存的。...默认值关键字:default 默认值的生效:在数据插入的时候,不给该字段赋值即可。

    1.3K30

    接口用例设计

    背景说明 一个系统可为其他系统提供能力或者直接为UI层提供数据,在设计系统测试方案时应考虑上游调用的各种场景,不仅考虑顺利且正向思维操作的场景,还应逆向的场景。...数据表不会插入新的记录且记录不会更改,重点关注调用参数中改变参数对应的字段仍为首次调用后的值,不会更新。...例如调用打款接口,参数打款金额不可为空。...具体来说,例如一个简单的积分充值接口,积分币数量不可空。从系统本身来说,无充值数量此充值单据即无意义。而充值数量会作为积分消费、失效等接口调用的起始数据源依赖。...同时,积分充值本质为给用户充值钱款,积分数量会转化 为金额且向下请求支付中心进行资金流转,而资金流转功能限制金额不可为空。 除此之外,需注意对功能的严格定义,有些参数不可非空校验且需兼容为空。

    1.7K31

    【MySQL数据库】数据库的约束

    一个表中只能有一个字段使用 auto_increment约束,且该字段必须有唯一索引,以避免序号重复(即为主键或主键的一部分)。...非空约束(not null) 顾名思义:非空约束(not null)就是指其字段的值不能为空。...;默认约束(default) 默认约束用于给表中字段指定默认值,即当在表中插入一条新记录时,如果没有给这个字段赋值,系统会自动为这个字段插入默认值。...column 字段名> default null;零填充约束(zerofill) 插入数据时,当该字段的值的长度小于定义的长度时,会在该值的前面补上相应的0。...当使用zerofill 时,默认会自动加unsigned(无符号)属性,使用unsigned属性后,数值范围是原值的2倍,例如,有符号为-128~+127,无符号为0~256。

    5.7K40

    新增非空约束字段在不同版本中的演进

    看起来有些奇怪,因为若字段允许NULL,其默认值就是NULL,不用显示声明,可以创建一个无DEFAULT NULL的新增字段再查看desc表结构,就可以证明这点。...原因就是11g新特性,新增一个有默认值的NOT NULL约束的字段,默认值不会像以前一样,插入每条记录中,而是会存储于一张数据字典表sys.ecol$,Oracle允许NOT NULL列默认值为NULL...这种新增非空约束字段在不同版本中确实有一些细节的变化,下面做一些简单测试。...首先,创建测试表,插入一条数据,新增列为NOT NULL且默认值是”的字段: create table bisal (id number); insert into bisal values(1); alter...根据错误提示,我们删除表中数据,再新增字段,可以增加,但不能再插入一条NULL至这个非空约束字段。 ?

    3.1K10

    laravel与thinkphp之间的区别与优缺点

    2、在实际开发中我们常常遇到这样的问题,就是开发地点不固定。 这就造成了我们需要频繁的更改数据库配置,给开发工作造成了麻烦。...TP依然没有避免这个”灾难”,在laravel框架中,.env环境文件的出现解决了这个麻烦。...6、Laravel里内置了大量的方法供开发者使用 在实际应用中更接近于”让对象完成一切”的开发思想,比如在后台表单验证的时候,Laravel内置了大量的验证方法。...例如对用户名的验证:我们可以使用validate方法里'username'=>'required'(不能为空)|alpha_dash(必须数字字母下划线)|between:6,18(在多少位数之间);还内置了例如...但在Laravel框架中内置了”哈希”Hash加密单向加密方法,且同样的参数加密出的字符串是绝对不会出现相同的情况,这就提高了安全性。

    5.7K20

    mysql-完整性约束

    #标识该字段的值自动增长(整数类型,而且为主键) DEFAULT             #为该字段设置默认值 UNSIGNED            #无符号 ZEROFILL            ...字段是否有默认值,缺省的默认值是NULL,如果插入记录时不给字段赋值,此字段使用默认值 sex enum('male','female') not null default 'male' #必须为正值...- 不可空 null - 可空 默认值,创建列时可以指定默认值,当插入数据时如果未主动设置,则自动添加默认值 mysql> create database db1;  # 创建db1数据库 Query...Empty set (0.00 sec) mysql> insert into t11 values();  # 在t11表中插入一个空值 Query OK, 1 row affected (0.00...: 单列做主键 多列做主键(复合主键) 约束:等价于 not null unique,字段的值不为空且唯一 存储引擎默认是(innodb):对于innodb存储引擎来说,一张表必须有一个主键 单列主键

    82110

    表——完整约束性规则(键)

    (整数类型,而且为主键) default 为该字段设置默认值 unsigned 无符号 zerofill 使用0填充 说明: 1....字段是否有默认值,缺省的默认值是NULL,如果插入记录时不给字段赋值,此字段使用默认值 sex enum('male','female') not null default 'male' #设置了不能为空...,则无论id字段是null还是not null,都可以插入空,插入空默认填入default指定的默认值 mysql> create table t3(id int default 1); mysql>...(23000): Duplicate entry '192.168.0.10-80' for key 'host' 四 primary key primary key字段的值不为空且唯一 一个表中可以...: foreign key(表1_字段名) references 表2(字段名); 在表2的字段名是主键的情况下(即不为空,且唯一) 若表1的字段名不唯一,则是多对一 若表1的字段名唯一(unique)

    2.4K70
    领券