看完这篇你就知道查询结果为空时候为什么集合会是空集合而不是 NULL,而对象为什么会是 NULL 了。 PS:对过程不感兴趣的可以直接跳到最后看结论。...如果一条SQL语句能够产生多个ResultSet, // 那么在编写Mapper.xml映射文件的时候,我们可以在SQL标签的resultMap属性中配置多个 // <resultMap...} | 返回结果为多行数据 那么我们看到 DefaultSqlSession#selectList() 方法,先说结论:返回值为空集合而不是 NULL。...所以不管是集合类型还是普通对象,Mybatis 都会先初始化一个 List 存储结果,然后返回值为普通对象且查为空的时候,selectOne 会判断然后直接返回 NULL 值。...而返回值为集合对象且查为空时,selectList 会把这个存储结果的 List 对象直接返回,此时这个 List 就是个空集合。
其实,NULL值在数据库中是一个很特殊且有趣的存在,下面我们一起来看看吧; 在查询数据库时,如果你想知道一个列(例如:用户注册年限 USER_AGE)是否为 NULL,SQL 查询语句该怎么写呢?...为什么要以这种方式来处理 NULL? 因为,在 SQL 中,NULL 表示“未知”。也就是说,NULL 值表示的是“未知”的值。...NULL = 未知; 在大多数数据库中,NULl 和空字符串是有区别的。 但并不是所有数据库都这样,例如,Oracle 就不支持空字符串,它会把空字符串自动转成 NULL 值。...Oracle 比较特殊,两个值都使用 NULL 来表示,而其他大多数数据库会区分对待。 但只要记住 NULL 表示的是一个未知的值,那么在写 SQL 查询语句时就会得心应手。...希望大家现在都清楚该怎么在 SQL 语句中处理 NULL 值了。
其实,NULL值在数据库中是一个很特殊且有趣的存在,下面我们一起来看看吧; 前言 在查询数据库时,如果你想知道一个列(例如:用户注册年限 USER_AGE)是否为 NULL,SQL 查询语句该怎么写呢...例如,如果我们想要知道一个列的值是否等于 1,WHERE 语句是这样的: WHERE USER_AGE = 1 那为什么 NULL 值要用 IS 关键字呢?为什么要以这种方式来处理 NULL?...因为,在 SQL 中,NULL 表示“未知”。也就是说,NULL 值表示的是“未知”的值。 NULL = 未知; 在大多数数据库中,NULL 和空字符串是有区别的。...Oracle 比较特殊,两个值都使用 NULL 来表示,而其他大多数数据库会区分对待。 但只要记住 NULL 表示的是一个未知的值,那么在写 SQL 查询语句时就会得心应手。...希望大家现在都清楚该怎么在 SQL 语句中处理 NULL 值了。
如果找不到结果集中第一行的第一列;则返回 null 引用(在 Visual Basic 中为 Nothing)。 如果数据库中的该值为 null,此查询将返回 DBNull.Value。...KEY,3 keyword VARCHAR(40) NOT NULL,4 UNIQUE KEY(keyword)5 ) 上面的 SQL 语句来源于《SQL反模式》一书 第17章 可怜人的搜索引擎 第5...语句返回的结果集中有一行数据,但是其值是 NULL,这是因为 SQL MAX() 函数在起作用。...《SQL反模式》中的用法 在《SQL反模式》一书第159页是在以下存储过程中使用 MAX() 函数的: 1 CREATE PROCEDURE BugsSearch(keyword VARCHAR(40)...,所以需要使用 MAX() 函数将空的查询结果转换为值为 NULL 的有一行的查询结果。
、avg()--计算平均值、min()--计算最小值、max()--计算最大值 返回person.contact表的总数 Select count(*) from person.contact 返回production.product...表listprice字段的最小值、最大值,取别名min_price、max_price Select min(listprice) min_price,max(listprice)max_price from...LOG ON (NAME = 'AccountingLog', FILENAME = 'D:\Program Files\Microsoft SQL Server\MSSQL10.MSSQLSERVER..., City varchar(20) NOT NULL, State char(2) NOT NULL, Zip varchar(10) NOT NULL, Contact varchar...NULL, FirstName varchar(25) NOT NULL, MiddleInitial varchar(1) NULL, LastName varchar(25) NOT NULL
简介 SQL Server每个表中各列的数据类型的有各种形式,产生的效果也各有不同,我们主要根据效率兼顾性能的情况下讨论下如何规定类型。 ...在SQL Server中,数据的存储以页为单位。八个页为一个区。一页为8K,一个区为64K,这个意味着1M的空间可以容纳16个区。 ...然后是溢出行,在SQL Server 2000中,一行超过8060字节是不被允许的,在SQL Server 2005之后的版本对这个特性进行了改进,使用Varchar,nvarchar等数据类型时,当行的大小不超过...数据类型的选择 在了解了一些基础知识之后。我们知道SQL Server读取数据是以页为单位,更少的页不仅仅意味着更少的IO,还有更少的内存和CPU资源消耗。...这样做是由于SQL Server比较时就不会使用三值逻辑(TRUE,FALSE,UNKNOWN),而使用二值逻辑(True,False),并且查询的时候也不再需要IsNull函数来替换Null值。
2.NOT NULL : 指示某列不能存储 NULL 值; 如果不向字段添加值就无法插入新记录或者更新记录,否则会报错; 3.UNIQUE : 保证某列的每行必须有唯一的值; 在设置字段为UNIQUE...Server Date 函数 函数 描述 GETDATE() 返回当前的日期和时间 DATEPART() 返回日期/时间的单独部分 DATEADD() 在日期中添加或减去指定的时间间隔 DATEDIFF...返回最后一个记录的值 MAX(column_name) - 返回最大值 MIN(column_name) - 返回最小值 SUM(column_name) - 返回总和 ROUND(column_name...,decimals) - 对某个数值字段进行指定小数位数的四舍五入(decimals 返回的小数位数) 基础实例: -- SQL Server、MySQL 和 Oracle 中的 SQL FIRST(...Scalar 函数 描述:SQL Scalar 函数基于输入值,返回一个单一的值。
VARCHAR / NVARCHAR 上的 MAX SQL Server 支持特殊字符串“MAX”在 VARCHAR 和 NVARCHAR 数据类型中,表示“最大可能长度”。...server_version_info 将始终返回数据库服务器版本信息(在本例中为 SQL2005),而不是兼容性级别信息。...参数: none_as_null=False – 如果为 True,则将值None持久化为 SQL NULL 值,而不是null的 JSON 编码。...VARCHAR / NVARCHAR 上的 MAX SQL Server 支持特殊字符串“MAX”在VARCHAR和NVARCHAR数据类型中,以指示“可能的最大长度”。...默认的可空性允许空值,并且在 CREATE TABLE 构造中是显式的: name VARCHAR(20) NULL 如果指定了nullable=None,则不做任何规定。
如果对一个表定义 CHECK 约束,那么此约束会在特定的列中对值进行限制。 下面的 SQL 在 "Persons" 表创建时为 "Id_P" 列创建 CHECK 约束。...19.SQL NULL 值 如果表中的某个列是可选的,那么我们可以在不向该列添加值的情况下插入新记录或更新已有的记录。这意味着该字段将以 NULL 值保存。 NULL 值的处理方式与其他值不同。...内建 SQL 函数的语法是: SELECT function(列) FROM 表 1.SQL AVG 函数 AVG 函数返回数值列的平均值。NULL 值不包括在计算中。...SQL LAST() 语法 SELECT LAST(column_name) FROM table_name 5.MAX() 函数 MAX 函数返回一列中的最大值。NULL 值不包括在计算中。...6.MIN() 函数 MIN 函数返回一列中的最小值。NULL 值不包括在计算中。
最近发现还有不少做开发的小伙伴,在写存储过程的时候,在参考已有的不同的写法时,往往很迷茫, 不知道各种写法孰优孰劣,该选用那种写法,以及各种写法优缺点,本文以一个简单的查询存储过程为例,简单说一下各种写法的区别...上面提到过,SQL在执行之前是需要编译的, 因为在编译的时候并不知道查询条件是否传入了值,有可能为null,有可能是一个具体的值 实话说,为什么抑制到到索引的使用,我之前也是没有弄清楚的,...评论中10楼Uest 给出了解释,这里非常感谢Uest SQL Server为了保险起见,采用了全表扫描的方式,举个简单的例子 ? ...所谓的参数化SQL,就是用变量当做占位符,通过 EXEC sp_executesql执行的时候将参数传递进去SQL中,在需要填入数值或数据的地方,使用参数 (Parameter) 来给值, 这样的话,...缺点,1,对于这种方式,也有一点不好的地方,就是拼凑的字符串处理过程中, 调试具体的SQL语句的时候,参数是直接拼凑在SQL文本中的,不能直接执行,要手动将占位参数替换成具体的参数值
mysql不支持默认值为当前时间的datetime类型(mssql很容易做到),在mysql里面是用timestamp类型 sql server里面检查是否有这个表再删除,需要这样: if exists...语法: MySQL / SQL Server: CREATE TABLE Persons ( Id_P int NOT NULL, LastName varchar(255) NOT NULL, FirstName...2.4.1 创建DEFAULT约束 下面的 SQL 在 "Persons" 表创建时为 "City" 列创建 DEFAULT 约束: My SQL / SQL Server: CREATE TABLE...MySQL 存储过程 “out” 参数:从存储过程内部传值给调用者。在存储过程内部,该参数初始值为 null,无论调用者是否给存储过程参数设置值。...在处理相互排拆的数据时容易让人理解,比如人类的性别。ENUM 类型字段可以从集合中取得一个值或使用 null 值,除此之外的输入将会使 MySQL 在这个字段中插入一个空字符串。
但是,使用pt-query-digest分析完慢SQL,我就有点蒙了,慢SQL执行的平均时间、最长执行时间都不足1秒,关于临时表的参数max_heap_table_size设置为32M,tmp_table_size...:用来指定在内存中的内部临时表的存储引擎,默认值 TempTable,而非以前默认的 MEMORY temptable_max_ram:定义 TempTable 存储引擎开始在磁盘上存储数据之前可以占用的最大内存量...也就能够解释为什么我构造2M临时表空间的查询,都无法触发磁盘临时创建的原因,因为我的2M临时表空间需求,远小于temptable_max_ram+temptable_max_mmap的值。...在我测试环境不停的操作过程中,发现Created_tmp_disk_tables计数器偶尔有少量增加,但是不管是慢日志,还是show processlist,都无法发现执行时间长的SQL,就算把测试环境的慢...,尝试一下从历史SQL中能否发现一些线索。
在后续文章中,我将展示如何通过在该归档文件上创建一个简单的哈希链来扩展此示例–这样您就可以证明是否可以通过任何方式对其进行了修改或污染,以及在何处进行了修改。...在示例代码中,我将使用mysql audit_log_read函数的新扩展功能,并说明为什么mysqlx API可以使某些任务更加简单。这个新的审计阅读功能已在MySQL 8.0.22企业版中发布。...由于安全性、分析等多种原因,最佳做法是经常从MySQL服务器上获取审计数据,并将其收集到一些中央数据存储中,您可以在其中查看所有MySQL服务器上的活动。为什么会这样做?...在归档服务器上创建模式和表 在审计数据归档服务器上 > mysqlsh \sql \connect root@server>; create schema audit_archive..., `the_os_ver` varchar(80) DEFAULT NULL, `server_id` varchar(8) DEFAULT NULL, PRIMARY KEY (`server_uuid
很多人肯定不理解为什么要使用Max函数,实际上大家都知道聚合函数是和分组进行搭配使用的。这一点毋庸置疑,那么大家可以把Max函数去掉看看会显示什么效果。...其他列都是0.那么这个时候就应该能很清楚的认识到,为什么使用Max函数了。在分组的同时取一组中的最大值。 静态行转列有一个弊端就是第一确定有多少个课程,然后再把课程名称拿出来再写查询语句。...需要注意的是分隔符不能为null,如果为null,则返回结果为null。 group_concat()函数 :将group by产生的同一个分组中的值连接起来,返回一个字符串结果。...说明:通过使用distinct可以排除重复值;如果希望对结果中的值进行排序,可以使用order by子句;separator是一个字符串值,缺省为一个逗号。...这里简单说一下,先生命一个变量赋值为null,把拼接的查询sql赋值给声明的变量表中,也可以理解为生成一个临时表,把查询出来的数据放到临时表中。预定义一个语句,并将它赋给 stmt。
大致意思是 SELECT 表的数据,WHERE 条件是 "a=0",其中 a 字段是 VARCHAR 类型,该字段存在 NULL 以及包含字符的记录,但是并无 "0" 的记录,然后执行 SQL 返回的记录恰恰就是所有包含字符的记录...SQL 错误 [245] [S0001]: 在将 varchar 值 '测试a' 转换成数据类型 int 时失败。...小结 通过以上对比,可以知道 Oracle 和 SQL Server 对 "字符型=数值型" 的条件,会自动将字符型类型转成数值型,如果因为值的问题不能转成数值型,就会提示错误,而 SQL Server...毕竟对产品来说,避免错误可能比表面上能执行更加重要,但就这个问题上,Oracle 和 SQL Server 可以说更胜一筹的。 2.3 问题分析 MySQL 为什么在这里会给出错误的结果?...3总结 我不知道这种设计是出于什么考虑,但这种"容错性"不可取,毕竟返回了错误的结果集。 当然,这个问题也和数据类型的使用有关,SQL 条件中 "a=0" 实际上是 "varchar=int"。
/* sql/unireg.cc:733 */ 在 pack_header 中存在这部分代码: if (reclength > (ulong) file->max_record_length()...MySQL Server 层计算长度的公式,可以写成这样的伪代码: data_offset = (number_null_field + 7) / 8; /*number_null_field表示允许为...srv_page_size = UNIV_PAGE_SIZE_DEF; /* 这个是默认值(DEF),如果my.cnf中配置page_size为32K,那这个值就是32K */ /* univ.i...:1092 */ # define REC_MAX_DATA_SIZE 16384 从上面的源码定义中可以看到: 1. srv_page_size 的默认值为 1<<14 即 16384,而我们配置也是...); } 3.2 小结 根据上面计算方式的梳理,在 InnoDB Server 层计算长度的公式,可以写成这样的伪代码: rec_max_size = 5; /* innodb header 中固定的两个值
int out,@id varchar(20)’为拼成的动态sql内的参数列表 @cou out,@id为为动态sql内参数列表提供值的外部参数列表 那么它们之间有什么区别呢?...中Varchar也可以的,但是我打了Sp3补丁后就不行了,必须为Nvarchar 2.动态Sql的参数列表与外部提供值的参数列表顺序必需一致,如: N’@count int out,@id varchar...该参数的默认值为 NULL。 [ @param1 = ] ‘value1’ 参数字符串中定义的第一个参数的值。该值可以是 Unicode 常量,也可以是 Unicode 变量。...必须为 stmt中包含的每个参数提供参数值。如果stmt 中的 Transact-SQL 语句或批处理没有参数,则不需要这些值。 [ OUT | OUTPUT ] 指示参数是输出参数。...这些值只能为常量或变量,不能是很复杂的表达式(例如函数)或使用运算符生成的表达式。 返回代码值 0(成功)或非零(失败) 结果集 从生成 SQL 字符串的所有 SQL 语句返回结果集。
:接收客户端请求(连接器)、检查SQL语法(分析器)、判断缓存命中(查询缓存8.0移除)、优化SQL和选择索引生成执行计划(优化器)、调用存储引擎获取记录(执行器)server层与存储引擎层的交互以学生表为例...'年龄', `student_name` varchar(20) DEFAULT NULL COMMENT '名称', `info` varchar(30) DEFAULT NULL COMMENT...,会出现随机IO(开销大)server层与存储引擎层交互的单位是记录server层优化器根据索引生成执行计划,执行器调用存储引擎层存储引擎层在联合索引中寻找满足 age=18的记录每次找到记录回表查询聚簇索引获取其他列的值然后返回给...=18的记录找到满足条件的记录后,根据索引上现有列判断其他查询条件,不满足则跳过该记录满足则回表查询聚簇索引其他列的值获取需要查询的值后,返回server层进行where过滤2-5步骤为循环执行,直到找到第一条不满足条件的记录测试开启函数创建...:连接器(管理请求连接)、分析器(处理SQL语法、词性分析)、优化器(优化SQL,根据不同索引生成执行计划)、执行器(根据执行计划调用存储引擎获取记录)server层与存储引擎层以记录为单位进行交互,server
玩爆你的数据报表之存储过程编写(下) 透视转换是一种行列互转的技术,在转过程中可能执行聚合操作,应用非常广泛。 本章与 你真的会玩SQL吗?数据聚合 内容比较重要,还涉及到 你真的会玩SQL吗?...聚合:从一组NULL值和已知值中提取出已知值,这就需要使用聚合操作,提取已知值技巧就是使用MAX或MIN函数,这两个会忽略NULL,并返回一个非NULL值,国为只包含一个值的集合最大值和最小值就是这个值...每组中若包含多个非NULL值 ,视情况也可用SUM/AVG。 ...若做到逆转换,将每个objectid 和每个attribute生成结果集中的一行 第一步是为每个甚而行生成5个属性副本,可以通过基础表和每个属性占一行虚拟辅助表执行交叉联接来实现,然后用select 返回...可能数据源中会得到与NULL值,如1的attr4,所以还需要对结果进行过滤掉Value为NULL的。
表中的enabled字段值设置 如果指定的consumers名称无效,则返回NULL 参数: in_consumer VARCHAR(64):要检查是否启用的consumers名称字符串 返回值:一个ENUM...ID值在performance_schema.threads表中未查询到,则返回UNKNOWN值,如果给定ID值为NULL则返回NULL 参数: in_connection_id BIGINT UNSIGNED...表中查询给定连接ID(processlist_id)的内部线程ID,如果给定连接ID为NULL值,则返回当前连接的内部线程ID 参数: in_connection_id BIGINT UNSIGNED:...表中查询到了该变量的非null值,则直接返回,如果查询到是null值,则使用第二个传参返回(如果在sys.sys_config表中没有查询到第一个传参的变量名---即可能传入的配置选项名称在sys.sys_config...表中不存在,返回第二个传参值) 按照惯例,调用者在sys_get_config()函数之前需要先检查相应的用户定义变量是否存在并且是否非NULL。
领取专属 10元无门槛券
手把手带您无忧上云