——冯梦龙 NULLIF函数是MySQL中的一个条件函数,用来返回两个表达式的比较结果。具体来说,如果两个表达式相等,NULLIF函数返回NULL;如果不相等,它就返回第一个表达式的值。...使用NULLIF函数将空字符串转换为NULL是一个简单直接的方法。...除了基本的转换,NULLIF与其他SQL函数结合使用,可以实现更复杂的数据处理逻辑。...比如,与COALESCE函数结合,可以实现多重默认值的逻辑: SELECT COALESCE(NULLIF(email, ''), 'no-email@example.com') AS email FROM...users; 这个例子中,如果email是空字符串,则首先被NULLIF转换为NULL,然后COALESCE函数会将其替换为默认邮箱地址no-email@example.com,这样无论email是'
SQL函数 NULLIF 如果两个表达式具有相同的值,则返回 NULL 的函数。...大纲 NULLIF(expression1,expression2) 参数 expression1 - 表达式,可以是列名、数字或字符串文字、主变量或另一个标量函数的结果。...expression2 - 表达式,可以是列名、数字或字符串文字、主变量或另一个标量函数的结果。 NULLIF 返回与 expression1 相同的数据类型。...描述 如果 expression1 的值等于 expression2 的值,则 NULLIF 函数返回 NULL。否则,它返回 expression1 值。...False returns ex 示例 以下示例使用 NULLIF 函数将 Age=20 的所有记录的显示字段设置为空: SELECT Name,Age,NULLIF(Age,20) AS Nulled20
简介 nullif和ifnull是数据库中常用的两个函数。不同的数据库可能会略微有差异。...详解 NULLIF NULLIF(expr1,expr2) NULLIF接受两个参数,如果两个参数相等则返回NULL,不相等则返回第一个参数。...实例 运行环境:MYSQL --返回 NULL SELECT NULLIF('culturesun.site','culturesun.site'); --返回 culturesun.site SELECT...NULLIF('culturesun.site',NULL); --返回 NULL ,因为第一个参数是 NULL SELECT NULLIF(NULL,'culturesun.site'); 注意第三句...实例 运行环境:MYSQL --返回 culturesun.site SELECT IFNULL('culturesun.site',NULL); --返回 culturesun.site SELECT
则返回所有商品价格,如果有null的则返回0; NULLIF(expr1,expr2) 如果expr1和expr2相等,则返回null,否则返回expr1的值 例如 查询商品的促销价格和市场价格是否相等...,不相等返回促销价格,相等则返回null select nullif(goods_price,goods_marketprice) from goods; 当然,一般情况下相等也不返回null,这只是个实例
数据库版本:MySql 5.7 FIND_IN_SET 定义: 在逗号分隔的字符串列表中查找指定字符串的位置 FIND_IN_SET(str,strlist) FIND_IN_SET()函数接受两个参数...第二个参数strlist是要搜索的逗号分隔的字符串列表 FIND_IN_SET()函数根据参数的值返回一个整数或一个NULL值: 如果str或strlist为NULL,则函数返回NULL值。...IF函数 定义: IF函数根据条件的结果为true或false,true 返回第一个值,false返回第二个值。...是则返回1,否则返回0 ISNULL(expr) IFNULL(exper1,exper2) 定义: 判断exper1是否为空,是则用exper2代替 IFNULL(exper1,exper2) NULLIF...NULLIF(exper1,exper2) 字符串函数 SUBSTR SUBSTR (str, pos) 截取从pos位置开始到最后的所有str字符串,mysql中的start是从1开始的 SUBSTR
正文部分 SAP HANA SQL中有IFNULL,还有NULLIF 两者的用法和区别简单说一下 IFNULL是返回第一个不为NULL的数据 用法如下: NULLIF是比较前后两个参数是否相等 如果相等
) SECOND() TIME_TO_SEC() TO_DAYS() WEEKDAY() YEAR() YEARWEEK() 等 当然,还有FLOOR(),CEILING() 等,前提是使用这两个分区函数的分区健必须是整型...EXPLAIN PARTITIONS跟踪发现都是全区扫描的,条件里加入WEEKDAY(visittime)这样的也不行 但是如果你插入的datetime字段是不带时间只有日期的话,where条件里没出现函数只用...=来判断日期,是可以分区搜索的 分区应该和索引一样,一但where中出现函数,就会全区扫描 下面的表PARTITION BY LIST (month(create_time)),Explain结果不太乐观...mysql> Explain partitions select * from rec_pay where create_time = ‘2014-06-01 00:00:00’ limit 20;...时发生 range:这个连接类型使用索引返回一个范围中的行,比如使用>或 index:以索引的顺序进行全表扫描,优点是不用排序,缺点是还要全表扫描 ALL:全表扫描,应该尽量避免 8 Extra:关于MYSQL
字符串函数 函数 用法 ASCII...,sn) 同CONCAT(s1,s2,...)函数,但是每个字符串之间要加上x INSERT(str, idx, len, replacestr) 将字符串str从第idx位置开始...s2是一个以逗号分隔的字符串 REVERSE(s) 返回s反转后的字符串 NULLIF...> SELECT NULLIF('mysql','mysql'),NULLIF('mysql', ''); +-------------------------+--------------------...-+ | NULLIF('mysql','mysql') | NULLIF('mysql', '') | +-------------------------+---------------------
目录: 函数与存储过程的区别 创建函数 使用函数 查看函数 删除函数 函数也是一组预先编译回到SQL的集合,基本和存储过程相似。...创建函数 语法: create function 函数名称(参数列表) returns 返回类型 binlog参数 begin 函数体 end; 详解: 参数列表:参数名称 参数类型 binlog...参数: no sql:函数体中没有SQL语句,也不会修改数据 reads sql data:函数体中存在SQL语句,但是整个数据是只读的,不会修改数据 modifies sql data:函数体中存在SQL...语句,并且会修改数据 contains sql:函数体中包含有SQL语句 函数体:在函数体中必须包含return语句,讲return放在函数体的最后一行执行。...return input1+input2; end;// 使用函数 语法: select 函数名(参数列表); 查看函数 语法: show create function 函数名; 删除函数 语法:
MySQL 函数MySQL 有很多内置的函数,以下列出了这些函数的说明。----MySQL 字符串函数函数描述实例ASCII(s)返回字符串 s 的第一个字符的 ASCII 码。...;有2个参数时,将参数加和mysql> SELECT TIMESTAMP("2017-07-23", "13:10:11"); -> 2017-07-23 13:10:11 mysql> SELECT...WHEN conditionN THEN resultN ELSE result ENDCASE 表示函数开始,END 表示函数结束。...判断表达式是否为 NULLSELECT ISNULL(NULL); ->1LAST_INSERT_ID()返回最近生成的 AUTO_INCREMENT 值SELECT LAST_INSERT_ID(); ->6NULLIF...(expr1, expr2)比较两个字符串,如果字符串 expr1 与 expr2 相等 返回 NULL,否则返回 expr1SELECT NULLIF(25, 25); ->SESSION_USER(
函数相关内容。...UPPER() 获取左侧、右侧 字符 LEFT('MYSQL',2) RIGHT('MYSQL',2) LENGTH() LTRIM() RTRIM() TRIM() 例子,删除前导的字符 TRIM(LEADING...MYSQL???') 结果为 MYSQL???...字符串截取 SUBSTRING('MYSQL','1','2') 结果 MY 模式匹配 [NOT] LIKE % 任意字符 下划线 _ 任意一个字符 替换 REPLACE('??MYSQL??'...() 加密函数 MD5() PASSWORD() 自定义函数 创建函数 CREATE FUNCTION 函数名 RETURNS {STRING|INTEGER|REAL|DECIMAL} 函数体; 删除函数
extract(hour_minute from current_date); //返回两个日期值之间的差值(月数):select period_diff(200302,199802); //在mysql...在这种情况下,mysql提供了case函 数,它和php及perl语言的switch-case条件例程一样。...如果 没有指定else块,而且所有的when-then比较都不是真,mysql将会返回null。...示例: mysql> select case 'green' when 'red' then 'stop' when 'green' then 'go' end; select case 9 when...//为了进行数据类型转化,mysql提供了cast()函数,它可以把一个值转化为指定的数据类型。
,如下: 函数索引的字段数量受到表的字段总数限制 函数索引能够使用的函数与虚拟列上能够使用的函数相同 子查询,参数,变量,存储过程,用户定义的函数不允许在函数索引上使用 虚拟列本身不需要存储,函数索引和其他索引一样需要占用存储空间...函数索引可以使用 UNIQUE 标识,但是主键不能使用函数索引,主键要求被存储,但是函数索引由于其使用的虚拟列不能被存储,因此主键不能使用函数索引 如果表中没有主键,那么 InnoDB 将会使其非空的唯一索引作为主键...,因此该唯一索引不能定义为函数索引 函数索引不允许在外键中使用 空间索引和全文索引不能定义为函数索引 对于非函数的索引,如果创建相同的索引,将会有一个告警信息,而函数索引则不会 如果一个字段被用于函数索引...,那么删除该字段前,需要先删除该函数索引,否则删除该字段会报错 非函数索引支持对字段前缀进行索引,函数索引不支持前缀。...,SUBSTRING(col1, 1, 10) 可以使用函数索引。
Mysql常用函数的汇总,可看下面文章 https://www.cnblogs.com/poloyy/p/12890763.html if 的作用 根据表达式的某个条件或值结果来执行一组 sql 语句...Mysql 中怎么才算表达式?...结合文字,变量,运算符,甚至函数来组合 表达式可以返回 true、false、null if 的语法格式 IF(expr,v1,v2) 语法格式说明 expr:表达式,返回 true、false、null...栗子: SQL分析 查询员工的name、在职状态 在职状态通过 if 函数去判断,返回【在职】or【离职】 select name,if(is_enable = 1,"在职","离职") "在职状态"
前言: MySQL数据库中提供了很丰富的函数,比如我们常用的聚合函数,日期及字符串处理函数等。...SELECT语句及其条件表达式都可以使用这些函数,函数可以帮助用户更加方便的处理表中的数据,使MySQL数据库的功能更加强大。本篇文章主要为大家介绍几类常用函数的用法。...函数返回结果为连接参数产生的字符串 若有任何一个参数为 NULL,则返回值为 NULL mysql> SELECT CONCAT('MySQL','5.7'),CONCAT('MySQL',NULL);...(arg1,arg2) 如果arg1不是空,返回arg1,否则返回arg2 NULLIF(arg1,arg2) 如果arg1=arg2返回NULL;否则返回arg1 CASE WHEN[test1...函数 mysql> SELECT NULLIF(5,8),NULLIF(8,8); +-------------+-------------+ | NULLIF(5,8) | NULLIF(8,8) |
1、MySQL 函数介绍 1.1、MySQL 函数简介 函数是指一段可以直接被另一段程序调用的程序或代码。...2.1、MySQL 函数分类 MySQL 函数按功能分类主要可以分为以下几种类型: 数学函数:用于执行数学计算,如加法、减法、乘法、除法、取余、四舍五入、取绝对值等。...常见的控制流函数包括 IF(), CASE, IFNULL(), NULLIF() 等; 比较函数和运算符:用于比较数据的函数和运算符,包括等于、不等于、大于、小于等。...2、MySQL 数学函数 MySQL 提供了多种数学函数,可以帮助用户执行各种数学运算,包括基本的算术运算、三角函数、对数运算等。...示例: SELECT NULLIF('A', 'B') AS test; -- 返回 'A' SELECT NULLIF('A', 'A') AS test; -- 返回 NULL COALESCE(expr1
1.数学函数 用来处理数值数据方面的运算,主要的数学函数有:绝对值函数,三角函数,对数函数,随机函数。使用数学函数过程中,如果有错误产生,该函数会返回null值。... 处理字符串数据,字符串函数主要有:计算字符串长度函数、字符串合并函数、字符串转换函数、字符串比较函数、查找指定字符串位置函数。...(1)日期时间函数 时间转化秒函数:time_to_sec MySQL> select time_to_sec('01:01:01'); +-------------------------+ | time_to_sec...---------+ | 01:01:01 | +-------------------+ 1 row in set (0.00 sec) 日期转为天数函数:to_days mysql> select...> (2)数值函数 ABS(X) :返回表达式X的绝对值 mysql> select abs(-2); +---------+ | abs(-2) | +---------+ | 2 | +-----
前言 上一篇给大家介绍了,MySQL常用的操作符其实已经是非常的详细了,现在给大家分享的是MySQL的常用函数。希望对我和对大家都有帮助。...一、字符串函数 1.1、LOWER、lcase(string); //转换为小写 ? 1.2、UPPER、ucase(string); //转换为大写 ? ...二、数学函数 2.1、round(number, [decimals]); //四舍五入,decimals为小数位数 ? ...2.8、rand([seed]); //随机数 2.9、sign(number); //返回符号,正负或0,正数返回1,负数回复-1 2.10、sqrt(num); //开平方 三、日期类函数...3.3、DateDIFF() DateDIFF()函数返回expr1起始时间和结束时间expr2之间的天数 expr1和expr2为日期或者date and time表达式。
MySQL 函数介绍 MySQL中的函数主要分为以下四类: 字符串函数、数值函数、日期函数、流程函数; MySQL 字符串函数 MySQL中内置了很多字符串函数,常用的几个如下: 1、concat :...字符串拼接 select concat('Hello' , ' MySQL'); 2、 lower : 全部转小写 select lower('Hello'); 3、upper : 全部转大写 select...lpad('01', 5, '-'); 5、rpad : 右填充 select rpad('01', 5, '-'); 6、 trim : 去除空格 select trim(' Hello My ') MySQL...rand(); 4、round:四舍五入 select round(2.344,2); MySQL 日期函数 1、curdate:当前日期 select curdate(); 2、curtime...流程函数 流程函数也是很常用的一类函数,可以在SQL语句中实现条件筛选,从而提高语句的效率。
领取专属 10元无门槛券
手把手带您无忧上云