首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【Kotlin】安全 ① ( Kotlin 的安全机制 | 变量可空性 | 默认变量不可 | 声明可类型变量 )

    文章目录 一、Kotlin 的安全机制 二、变量可空性 1、默认变量不可 2、声明可类型变量 一、Kotlin 的安全机制 ---- Java 中的指针问题 : 在 Java 语言...Kotlin 程序的 代码健壮性 ; 二、变量可空性 ---- 1、默认变量不可 在 Java 中 , 引用类型的变量 默认为 null ; 但是在 Kotlin 中 , 变量默认不可为...null , 这样所有的 变量 在默认状态下 , 都有一个 默认的实例对象 , 从而极大的 减少了 指针异常 出现的概率 ; 代码示例 : 先定义一个 name 变量 , 为其赋值字符串 "Tom...赋值一个 , 除非 将该变量声明为 可类型 ; 2、声明可类型变量 声明可类型变量 : 如果要声明一个 可类型的变量 , 必须 声明该变量的具体的类型 , 并在该类型后添加 ?...可类型 , 此时就可以为 该变量 赋值 null ; fun main() { var name: String?

    1.9K20

    MySQL 中NULL和的区别?

    01 小木的故事 作为后台开发,在日常工作中如果要接触Mysql数据库,那么不可避免会遇到Mysql中的NULL和。那你知道它们有什么区别吗? 学不动了,也不想知道它们有什么区别。...---- 面试官:你有用过MySQL吗? 小木:有! 面试官:那你能大概说一下Mysql中 NULL的区别吗?...02 NULL和 NULL也就是在字段中存储NULL也就是字段中存储空字符(’’)。...4、索引字段说明 看到网上有一些人说: MySql中如果某一列中含有NULL,那么包含该列的索引就无效了。 one 和two 字段分别加上普通索引。...1、不占空间,NULL占空间。当字段不为NULL时,也可以插入

    2.6K10

    mysql与NULL的区别

    陷阱一:不一定为   是一个比较特殊的字段。在MySQL数据库中,在不同的情形下,往往代表不同的含义。这是MySQL数据库的一种特性。如在普通的字段中(字符型的数据),就是表示。...其实这就是在MySQL数据库中执行SQL语句时经常会遇到的一个陷阱:不一定为。在操作时,明明插入的是一个的数据,但是最后查询得到的却不是一个。   ...在MySQL数据库中,NULL对于一些特殊类型的列来说,其代表了一种特殊的含义,而不仅仅是一个。对于这些特殊类型的列,各位读者主要是要记住两个。一个就是笔者上面举的TimesTamp数据类型。...而如果在其他数据类型中,如字符型数据的列中插入Null的数据,则其插入的就是一个。   陷阱二:不一定等于空字符   在MySQL中,(Null)与空字符(’’)相同吗?...这就是在MySQL中执行SQL语句遇到的第二个陷阱。在实际工作中,数据与空字符往往表示不同的含义。数据库管理员可以根据实际的需要来进行选择。

    3.6K70

    MySQL中的ifnull()函数判断

    比如说判断的函数,在Oracle中是NVL()函数、NVL2()函数,在SQL Server中是ISNULL()函数,这些函数都包含了当值为的时候将返回替换成另一个的第二参数。...但是在MySQL中,ISNULL()函数仅仅是用于判断的,接受一个参数并返回一个布尔,不提供当值为的时候将返回替换成另一个的第二参数。...SELECT ISNULL('i like yanggb'); // 0 SELECT ISNULL(NULL); // 1 因此MySQL另外提供了一个IFNULL()函数。...简单介绍 IFNULL()函数是MySQL内置的控制流函数之一,它接受两个参数,第一个参数是要判断的字段或(傻?),第二个字段是当第一个参数是的情况下要替换返回的另一个。...两个参数都可以是文字或表达式。 函数的语法 IFNULL(v1, v2) 其中,如果v1不为NULL,则IFNULL函数返回v1; 否则返回v2的结果。

    9.8K10

    MySQL关于日期为零的处理

    前言: 前面文章我们介绍过日期和时间字段的查询方法,最近遇到日期为零的问题。原来了解过和 sql_mode 参数设置有关,但还不是特别清楚,本篇文章将探究下MySQL怎么处理日期为零的问题。...1.问题描述 这里我们说的日期为零是指年、月、日为零,即'0000-00-00'。...显然,这是不合法的日期,但由于设计问题或历史遗留问题,有时候数据库中有类似日期为零的数据,默认情况下插入零值日期会报错,可以通过修改参数sql_mode模式来避免该问题。...其中 NO_ZERO_IN_DATE、NO_ZERO_DATE这两个变量影响MySQL日期的处理。...如果你的业务有插入零值日期的需求,则可以选择sql_mode中不要包含NO_ZERO_DATE和NO_ZERO_IN_DATE,例如,某字段要求设置为DATE类型且不为,默认设为'0000-00-00

    4.4K40

    mysql (null)和空字符()的区别

    空字符('')和(null)表面上看都是,其实存在一些差异: 定义: (NULL)的长度是NULL,不确定占用了多少存储空间,但是占用存储空间的 空字符串('')的长度是0,是不占用空间的 通俗的讲...(NULL)就像是一个装满空气的杯子,含有东西。 二者虽然看起来都是的、透明的,但是有着本质的区别。...--+ | col_b+1 | +---------+ | 2 | +---------+ 1 row in set (0.00 sec) 由此可见,(null)不能参与任何计算,因为值参与任何计算都为...(null)并不会被当成有效去统计。 同理,sum()求和的时候,null也不会被统计进来,这样就能理解, 为什么null计算的时候结果为,而sum()求和的时候结果正常了。...在设置字段的时候,可以字段设置为 not null ,因为 not null 这个概念和默认是不冲突的。

    3.1K30

    带公式的excel用pandas读出来的都是和0怎么办?——补充说明_日期不是日期

    起一篇,是因为 ①频繁修改需要审核比较麻烦 ②这个问题是数据源头的错误,不常碰到,而且可控的,楼主这里是因为积攒了大批数据,去改源头之前的也改不了,还是要手动,比较麻烦 先说问题,读取excel时候,日期不是日期格式是数字或常规...,显示的是四个数字,python读取出来的也是数字,写入数据库的也是数字而不是日期 附上读取带公式的excel的正文链接: https://blog.csdn.net/qq_35866846/article.../details/102672342 读取函数rd_exel循环之前先处理日期 sheet1.Cells(2,3).NumberFormatLocal = "yyyy/mm/dd"#excel VBA语法...#添加到循环之前,2行3列对应C2是数字格式的日期 处理这个问题,楼主本人电脑是可以跑通的完全没问题,注意打印出来date,看下格式,跟平常见的不是太一样!

    1.6K20

    MySQL数据库查询对象判断与Java代码示例

    然而,查询结果并不总是如我们所期望,有时可能为。因此,在处理从MySQL数据库查询的对象时,我们需要谨慎地考虑如何处理可能的情况,以确保应用程序的稳定性和可靠性。...在使用MySQL数据库进行查询时,查询结果可能会为。这种情况通常出现在以下几种情况下: 查询条件不匹配: 查询条件可能不满足任何数据库记录,导致返回一个的结果集。...数据不完整: 数据库中的某些字段可能为,如果不进行处理,查询结果中可能包含。 数据库错误: 数据库查询可能由于连接问题或查询语法错误而失败,返回空结果。...在这些情况下,如果不对查询结果进行判断,将会引发潜在的异常,影响应用程序的正常运行。因此,判断数据库查询结果是否为是一个重要的编程实践,有助于提高应用程序的稳定性。...--- 结论 在处理从MySQL数据库查询的对象时,判断结果是否为是一项关键的开发实践。通过合理的判断,我们可以确保应用程序在面对空结果或数据库错误时能够稳定运行,避免潜在的异常和崩溃。

    82830

    Oracle中date类型对应 MySQL 时间类型以及的处理

    因为在做Oracle---->MySQL的数据迁移的时候,发现Oracle中的date类型,对应的MySQL的时间类型设置不当容易引起错误,特别是存在的时候 MySQL 版本 5.6.40版本 mysql...set (0.00 sec) 提示date类型插入告警,但是依旧可以插入进去,因为date类型只记录年月(yyyy-mm) Query OK, 1 row affected (0.01 sec) 4个时间插入测试...,time类型,插入0 mysql> insert into t1 values (null,'0','2018-01-01','2018-01-01 12:12:12','2018-10-10 00...的date类型是不一样的,Oracle为yyyy-mm-dd hh:mi:ss和mysql中的datetime类型匹配, 而 mysql 为 yyyy-mm 。...当在存在的时候,mysql的time 类型可以使用0零来插入,而date,datetime,timestamp可以使用null 来插入,但是timestamp即使为null,也会默认插入当前时间戳。

    3.1K10

    小白学习MySQL - TIMESTAMP类型字段非和默认属性的影响

    原文链接:https://mp.weixin.qq.com/s/nFO6xOuzfh8kOYDj99xE0g 同事说他通过某款商业数据同步软件将一个MySQL 5.7.28的库同步到MySQL 5.7.20...的库时,如果表中含有TIMESTAMP数据类型、缺省为current_timestamp的字段,这些表的同步任务就都失败了,而另外的一些包含了DATETIME数据类型的表就同步成功了,不知道这是不是MySQL...MySQL是否为TIMESTAMP列的默认和NULL的处理启用某些非标准的行为, https://dev.mysql.com/doc/refman/5.7/en/server-system-variables.html...这样的列分配一个NULL的是允许的,并将该列设置为current timestamp。...目标库MySQL 5.7.20的explicit_defaults_for_timestamp是默认的OFF,结合上述规则,就可以模拟复现上述问题了。

    4.7K40

    C++使用mysql判断select查询结果是否为mysql_query返回问题

    C++使用mysql判断select查询结果是否为/mysql_query返回问题 MYSQL sqlcon; string str = "SELECT * FROM dt_user where user...mysql_query(&(this->sqlcon), str) { return true; } mysql_query的返回,无效sql语句的时候会返回false,但如果输入sql语句时有效的...,仍然会返回有效的id,换句话说mysql_query无论是否查询,,只要语法不出问题,都会返回真。...row = NULL 这个表达式的bool为假 { return true; } mysql_store_result():将mysql_query()查询到的结果集,MYSQL_RES...变量 mysql_fetch_row():将MYSQL_RES变量中的一行MYSQL_ROW变量,当重复调用mysql_fetch_row()时,将逐个获取结果集的行,到最后一行后返回NULL。

    11.3K41

    关于mysql列加索引这个列中有null的情况

    由于联合索引的是先以 前面的排序在根据后面的排序所以说将区分度高的放在前面会减少扫描行数增加查询效率 但是最重要的问题来了,我就要提交SQL的时候 leader 问了一句我,你这边的话这个数据字段 默认为...我说是的默认为 null(按照规定这玩意是不能null 的 应该 not null的,但是是历史数据 我这变也没改(其实这两个字段也是我之前实习的时候加的)),于是她说这样的话索引会失效, 于是我就在想为什么啊...B+树 不能存储为null的字段吗。想想也是啊 为null 这个key 怎么建立啊,怎么进行区分呢?...所以说这个null一定是加到B+ 树里面了 但是这个就会哟疑问了 索引的key为null在B+树是怎么存储着呢 ???

    4.2K20

    技术分享 | MySQL 的 TIMESTAMP 类型字段非和默认属性的影响

    同事说他通过某款商业数据同步软件将一个 MySQL 5.7.28 的库同步到 MySQL 5.7.20 的库时,如果表中含有 TIMESTAMP 数据类型、缺省为 current_timestamp...《故障分析 | MySQL 迁移后 timestamp 列 cannot be null》这篇文章其实介绍过,MySQL 中有个 explicit_defaults_for_timestamp 变量,他决定了...MySQL 是否为 TIMESTAMP 列的默认和 NULL 的处理启用某些非标准的行为: https://dev.mysql.com/doc/refman/5.7/en/server-system-variables.html...这样的列分配一个 NULL 的是允许的,并将该列设置为 current timestamp 。...目标库 MySQL 5.7.20 的 explicit_defaults_for_timestamp 是默认的 OFF ,结合上述规则,就可以模拟复现上述问题了。

    5K20
    领券