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

Guava 指南 之「使用和避免 null

使用和避免nullnull,糟糕透啦!” —— Doug Lea. “我称null为百亿美金的错误!” —— C. A. R. Hoare....轻率地使用null可能导致很多令人惊愕的问题。通过研究谷歌的代码,我们发现:95% 的集合不接受null作为元素,因此相比于默默地接受null,使用快速失败的操作拒绝null值对开发者更有帮助。...例如,在内存和速度方面,null就是廉价的,而且在对象数组中,出现null也是不可避免的。但是相对于库来说,在应用代码中,null往往是导致混乱、疑难问题和含义模糊的根源。...此外,Guava 提供了很多工具类,可以让我们在必须使用null时用起来更简单,也可以让我们避免使用null....具体案例 不要在Set中使用null,也不要把null作为 Map 的键;在查询操作中,使用一个特殊值表示null,这会让我们的语言更加清晰。

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

    MySQL字段null和not null学习思考

    最后的理解是:mysql所有字段尽可能使用not null。最终时间默认值设为1970-01-01 08:00:00,使用这个的原因是该时间对应的时间戳是0。...对于MYSQL特殊的注意事项,对于timestamp数据类型,如果往这个数据类型插入的列插入NULL值,则出现的是当前系统时间,插入空值,则出现0000-00-00 00:00:00。...除非有特别的原因使用NULL值,应该总是让字段保持not null。 空值跟NULL是两个概念 (1)空值不占用空间 (2)MYSQLNULL其实是占用空间的。...你应该用0、一个特殊值或者一个空串代替NULL。(影响索引效率的原因:NULL不是空值,而是要占用空间,所以MYSQL进行比较的时候,NULL会参与字段比较,所以对效率有一部分影响。...MYSQL NULL特殊的影响和使用:https://opensource.actionsky.com/20190710-mysql/

    2.8K20

    MySQL中IS NULL、IS NOT NULL、!=不能用索引?胡扯!

    来源:我们都是小青蛙 作者:小孩子4919 不知道从什么时候开始,网上流传着这么一个说法: MySQL的WHERE子句中包含 IS NULL、IS NOT NULL、!...KEY idx_key_part(key_part1, key_part2, key_part3) ) Engine=InnoDB CHARSET=utf8; 这个表里有10000条记录: mysql...NULL值是怎么在记录中存储的 在MySQL中,每一条记录都有它固定的格式,我们以InnoDB存储引擎的Compact行格式为例,来看一下NULL值是怎样存储的。...所以MySQL优化器在真正执行查询之前,对于每个可能使用到的索引来说,都会预先计算一下需要扫描的二级索引记录的数量,比方说对于下边这个查询: SELECT * FROM s1 WHERE key1 IS...不信谣,不传谣 大家可以看到,MySQL中决定使不使用某个索引执行查询的依据很简单:就是成本够不够小。而不是是否在WHERE子句中用了IS NULL、IS NOT NULL、!=这些条件。

    4.4K30

    MySQL NULL值特性

    NULL是一种“没有类型”的值,通常表示“无值”,“未知值”,“缺失值”,“超界”,“不在其中”等,我们在日常运用中很容易和NULL字符串混淆,这里大致整理了下NULL值的一些特性,以便能够正确使用NULL...1,创建表时字段时若未添加默认值,则默认为NULL值 2,NULL值和NULL字符串的区别 1)NULL值不区分大小写,查询时都显示为大写NULL,而NULL字符串则显示为插入时候的大小写,查询的时候根据字符集是否区分大小写筛选...2)NULL字符串可以当作普通字符串进行处理,而NULL值的判断只有is null和 is not null,见第5点 3,插入数据时若不指定值,如果没其它默认值,会用默认值NULL 4,当插入大写...NULL字符时,就很难区别NULLNULL值还是NULL字符串了,这时需要用到NULL值的判断,NULL值的判断只有is NULL和is not NULL 通过肉眼很难区别,这里通过NULL值的判断...7,和NULL值的逻辑运算,is NULL运算只有null is null为真返回数字1,is not NULL运算只有 null is not null为假返回数字0 8,MySQL会把单独的

    2.7K10

    MySQL中IS NULL、IS NOT NULL、!=不能用索引?胡扯!

    不知道从什么时候开始,网上流传着这么一个说法: MySQL的WHERE子句中包含 IS NULL、IS NOT NULL、!= 这些条件时便不能使用索引查询,只能使用全表扫描。...KEY idx_key_part(key_part1, key_part2, key_part3) ) Engine=InnoDB CHARSET=utf8; 这个表里有10000条记录: mysql...NULL值是怎么在记录中存储的 在MySQL中,每一条记录都有它固定的格式,我们以InnoDB存储引擎的Compact行格式为例,来看一下NULL值是怎样存储的。...所以MySQL优化器在真正执行查询之前,对于每个可能使用到的索引来说,都会预先计算一下需要扫描的二级索引记录的数量,比方说对于下边这个查询: SELECT * FROM s1 WHERE key1 IS...不信谣,不传谣 大家可以看到,MySQL中决定使不使用某个索引执行查询的依据很简单:就是成本够不够小。而不是是否在WHERE子句中用了IS NULL、IS NOT NULL、!=这些条件。

    2.1K20

    MySQL中IS NULL、IS NOT NULL、!=不能用索引?胡扯!

    不知道从什么时候开始,网上流传着这么一个说法: MySQL的WHERE子句中包含 IS NULL、IS NOT NULL、!= 这些条件时便不能使用索引查询,只能使用全表扫描。...KEY idx_key_part(key_part1, key_part2, key_part3) ) Engine=InnoDB CHARSET=utf8; 这个表里有10000条记录: mysql...NULL值是怎么在记录中存储的 在MySQL中,每一条记录都有它固定的格式,我们以InnoDB存储引擎的Compact行格式为例,来看一下NULL值是怎样存储的。...所以MySQL优化器在真正执行查询之前,对于每个可能使用到的索引来说,都会预先计算一下需要扫描的二级索引记录的数量,比方说对于下边这个查询: SELECT * FROM s1 WHERE key1 IS...不信谣,不传谣 大家可以看到,MySQL中决定使不使用某个索引执行查询的依据很简单:就是成本够不够小。而不是是否在WHERE子句中用了IS NULL、IS NOT NULL、!=这些条件。

    2.4K30

    null出发-看看为何mysql这么排斥null

    mysql中也是如此,null代表的是一种不确定性,所以通常用is null 或者not null来判定一个实例数据是否为不确定的,而不是直接==来进行值比较。...mysql null的空间表现 nullmysql中是一种特殊的“占位符”,用来表示不确定性,但是实际上它也是需要占用一部分内存空间的,比不是所想的会省内存。...(这个是问题,但忽略不计) 某些情况可以省,但是相对于它带来的其他影响,这点优势啥都不是,继续往下看 mysql null对索引的影响 Mysql难以优化引用可空列查询,它会使索引、索引统计和值更加复杂...--《高性能mysql》 1、虽然mysql会对null字段也进行索引,但是只有is null的方式会使用上索引,所以一旦使用不好,索引就无效了。...,上面也提到啦) 4、mysql内部会对null 做很多特殊逻辑的处理影响性能。

    1.4K20

    MySQL避免索引失效

    有的时候博客内容会有变动,首发博客是最新的,其他博客地址可能会未同步,认准https://blog.zysicyj.top MySQL避免索引失效 在使用MySQL数据库时,正确地使用索引可以显著提高查询性能...以下是一些避免索引失效的策略: 1. 避免在索引列上使用函数或表达式 当在索引列上使用函数或对列进行计算时,索引将不会被使用。...「改进方法」: 尽量避免以通配符开始的模式,或者使用全文索引。 7. 避免在索引列上进行数学运算或拼接 与在索引列上使用函数类似,进行数学运算或拼接也会导致索引失效。...使用FORCE INDEX 如果确定某个索引是最优的,但MySQL优化器没有选择它,可以使用FORCE INDEX来强制使用特定的索引。...「示例」: SELECT * FROM users FORCE INDEX (index_name) WHERE username = 'johndoe'; 遵循这些策略可以帮助你更有效地利用MySQL

    14610

    在Java中如何避免“!=null”式的判空语句?

    = null在使用对象之前判断是否为空。这么做是为了避免NullPointerException。但是我发现这样检测代码实在是太丑了,而且及其不可读。 那有没有一种优雅的替代方法呢?...= null) { someobject.doCalc(); } 这么些我是为了避免抛NullPointerException异常,我不知道这个对象是不是空的。...换句话说,有两种情况会出现判空语句: null返回值按找约定是正常的返回值 null返回值不是正常的返回值 第二种情况很简单。...如果null返回值是正常的话,那你就必须去检查它了。 如果可以控制你调用代码(当然常常还是有控制权的),那就是另一回事儿了。还是尽量的不去使用null返回值。...对于返回集合的方法很简单,只需要返回空的集合就可以了,而不是null。 对于返回值不是集合的方法,就要麻烦一点了。

    2.2K10

    在Java中如何避免“!=null”式的判空语句?

    = null在使用对象之前判断是否为空。这么做是为了避免NullPointerException。但是我发现这样检测代码实在是太丑了,而且及其不可读。 那有没有一种优雅的替代方法呢?...= null) { someobject.doCalc(); } 这么些我是为了避免抛NullPointerException异常,我不知道这个对象是不是空的。...换句话说,有两种情况会出现判空语句: null返回值按找约定是正常的返回值 null返回值不是正常的返回值 第二种情况很简单。...如果null返回值是正常的话,那你就必须去检查它了。 如果可以控制你调用代码(当然常常还是有控制权的),那就是另一回事儿了。还是尽量的不去使用null返回值。...对于返回集合的方法很简单,只需要返回空的集合就可以了,而不是null。 对于返回值不是集合的方法,就要麻烦一点了。

    3.4K20

    在Java中如何避免“!=null”式的判空语句?

    = null在使用对象之前判断是否为空。这么做是为了避免NullPointerException。但是我发现这样检测代码实在是太丑了,而且及其不可读。 那有没有一种优雅的替代方法呢?...= null) { someobject.doCalc(); } 这么些我是为了避免抛NullPointerException异常,我不知道这个对象是不是空的。...换句话说,有两种情况会出现判空语句: null返回值按找约定是正常的返回值 null返回值不是正常的返回值 第二种情况很简单。...如果null返回值是正常的话,那你就必须去检查它了。 如果可以控制你调用代码(当然常常还是有控制权的),那就是另一回事儿了。还是尽量的不去使用null返回值。...对于返回集合的方法很简单,只需要返回空的集合就可以了,而不是null。 对于返回值不是集合的方法,就要麻烦一点了。

    5.3K10

    mysql explain ref null_MySQL Explain详解

    常用的类型有: NULL, system, const, eq_ref, ref, range, index, ALL(从左到右,性能从差到好) 以下列表描述了从最佳类型到最差类型的连接类型 NULL...ref_or_null SELECT * FROM ref_table WHERE key_column IS NULL; index_merge 该指数合并访问方法检索与多行 range扫描和他们的结果合并到一个...该ref列 NULL适用于此类型。...通常,您可以ALL通过添加基于常量值或早期表中的列值从表中启用行检索的索引来避免 五、possible_keys 该possible_keys列指示MySQL可以选择在此表中查找行的索引,指出MySQL...如果是这样,创造一个适当的索引并且再次用EXPLAIN检查查询 六、Key key列显示MySQL实际决定使用的键(索引) 如果没有选择索引,键是NULL

    1.8K40

    MySQL 解决查询NULL的问题

    要求查询第二大的工资数,展示项名为:SecondHighestSalary 难点: 当第二大的工资不存在的时候,查询结果为 NULL 解题思路 首先我们先忽略工资不存在的情况,只解决“第二大”这个问题。...第三种思路,执行一下,结果很happy,符合题目要求,即便是数据不存在时,也会返回 NULL,好了,你已经完成了这个题目。...第四种思路,执行一下,当数据不存在时,返回的结果集为 空,并没有返回 NULL。...为什么会想到 LEFT JOIN 呢,很明显,不存在的结果却需要显示为 NULL,这很符合 LEFT JOIN 或 RIGHT JOIN 的特质。...直接上代码: SELECT if(m.salary2 IS NULL, NULL, m.salary1) AS SecondHighestSalary FROM ( SELECT t1.salary

    2.3K10

    MySQL中的字段约束 null、not null、default、auto_increment

    今天我们来看一下MySQL的字段约束:NULL和NOT NULL修饰符、DEFAULT修饰符,AUTO_INCREMENT修饰符。...MySQL默认情况下指定字段为NULL修饰符,如果一个字段指定为NOT NULLMySQL则不允许向该字段插入空值(这里面说的空值都为NULL),因为这是“规定”。...当插入记录时,您老人家忘记传该字段的值时,MySQL会自动为您设置上该字段的默认值。 如果一个字段中没有指定DEFAULT修饰符,MySQL会依据这个字段是NULL还是NOT NULL自动设置默认值。...如果指定字段可以为NULL,则MySQL为其设置默认值为NULL。...如果是NOT NULL字段,MySQL对于数值类型插入0,字符串类型插入空字符串,时间戳类型插入当前日期和时间,ENUM类型插入枚举组的第一条。

    5.5K20
    领券