首页 数据库 mysql教程 Mysql中IFNULL与IN操作

Mysql中IFNULL与IN操作

Jun 07, 2016 pm 04:18 PM
ifnull mysql 操作

Mysql IFNULL操作 项目中用到的,当SQL查询某个字段为空的时候,查询结果中设置其值为默认值。最笨的方法当然是对查询结果进行处理了,遍历查询结果,当为空的时候,设置其值: 代码如下 $len=count($result); for($i=0;$i$len ;$i++){ $var = $result[$i]['

   Mysql IFNULL操作

  项目中用到的,当SQL查询某个字段为空的时候,,查询结果中设置其值为默认值。最笨的方法当然是对查询结果进行处理了,遍历查询结果,当为空的时候,设置其值:

 代码如下  

$len=count($result);
for($i=0;$i     $var = $result[$i]['name'];
 if(!$var){
  $result[$i]['name']='default_name';
 }
}

  如上办法,不仅费时,还??隆H绻?茉?ql语句中直接解决多好啊。

  SQL中有ISNULL方法,介绍如下:

  ISNULL

  使用指定的替换值替换 NULL。

  语法

  ISNULL ( check_expression , replacement_value )

  参数

  check_expression

  将被检查是否为 NULL的表达式。check_expression 可以是任何类型的。

  replacement_value

  在 check_expression 为 NULL时将返回的表达式。replacement_value 必须与 check_expresssion 具有相同的类型。

  但在Mysql中,isnull只是用来判断是否为空,不能实现替换功能,照上面写的话,会直接报错(Incorrect parameter count in the call to native function 'isnull' Errornumber:1582 )。

  那么Mysql中如何实现SQL中的ISNULL方法呢?

  IFNULL( check_expression , replacement_value ),实现了SQL中的ISNULL方法。

  见下sql语句

 代码如下  

mysql> SELECT IFNULL(1,0);
+-------------+
| IFNULL(1,0) |
+-------------+
|           1 |
+-------------+
1 row in set

  由于 expr1 是 1,不为 NULL,所以函数返回 1. 我们可以再试下,如果让 expr1 为 NULL,是否能返回第二个参数呢? 不妨让 expr1 = 1/0, 由于除数为0,结果就为 NULL 了。

 代码如下  

mysql> SELECT IFNULL(1/0,'NowaMagic');
+-------------------------+
| IFNULL(1/0,'NowaMagic') |
+-------------------------+
|                |
+-------------------------+
1 row in set

  前面的参数为 NULL,就返回第二个参数 了。

  这个函数不难理解,为什么要介绍这个函数呢?这是为了后面讲述 MySQL 下的高级黑客技术做的基础知识准备,你可以先试着理解这么一句 hack SQL

 代码如下  

UPDATE table SET views = '1' WHERE id = -2441 OR (ORD(MID((SELECT IFNULL(CAST(FirstName AS CHAR),0x20) FROM nowamagic.`tb2` ORDER BY id LIMIT 1,1),2,1))>112)#

  Mysql的IN操作

  见如下SQL语句

 代码如下  

select product
from ProductParameter
where val = 19116 OR val = 19127 OR val = 19128 OR val = 19119

  OR了很多是不是觉得很繁琐呀?用IN就解决了:

 代码如下  

select product
from ProductParameter
where val in (19116, 19127, 19128, 19119))

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Laravel 教程
1604
29
PHP教程
1510
276
优化MySQL用于财务数据存储 优化MySQL用于财务数据存储 Jul 27, 2025 am 02:06 AM

MySQL用于金融系统需优化四个关键点:1.金融数据必须使用DECIMAL类型确保精度,时间字段使用DATETIME避免时区问题;2.索引设计要合理,避免频繁更新字段建索引,组合索引按查询顺序排列并定期清理无用索引;3.使用事务确保一致性,控制事务粒度,避免长事务和非核心操作嵌入其中,并根据业务选择合适隔离级别;4.对历史数据按时间分区、归档冷数据并使用压缩表,提升查询效率并优化存储。

优化MySQL用于实时数据提要 优化MySQL用于实时数据提要 Jul 26, 2025 am 05:41 AM

TooptimizeMySQLforreal-timedatafeeds,firstchoosetheInnoDBstorageenginefortransactionsandrow-levellocking,useMEMORYorROCKSDBfortemporarydata,andpartitiontime-seriesdatabytime.Second,indexstrategicallybyonlyapplyingindexestoWHERE,JOIN,orORDERBYcolumns,

MySQL数据库成本效益分析用于云迁移 MySQL数据库成本效益分析用于云迁移 Jul 26, 2025 am 03:32 AM

是否值得将MySQL迁到云上取决于具体使用场景。如果你的业务需要快速上线、弹性扩展和简化运维,且能接受按需付费模式,那么迁云是值得的;但若你的数据库长期稳定、对延迟敏感或受合规限制,则可能不划算。控制成本的关键包括选择合适厂商与套餐、合理配置资源、利用预留实例、管理备份日志及优化查询性能。

用对象级特权确保MySQL 用对象级特权确保MySQL Jul 29, 2025 am 01:34 AM

TosecureMySQLeffectively,useobject-levelprivilegestolimituseraccessbasedontheirspecificneeds.Beginbyunderstandingthatobject-levelprivilegesapplytodatabases,tables,orcolumns,offeringfinercontrolthanglobalprivileges.Next,applytheprincipleofleastprivile

管理大型MySQL表的最佳实践 管理大型MySQL表的最佳实践 Aug 05, 2025 am 03:55 AM

处理大表时,MySQL性能和可维护性面临挑战,需从结构设计、索引优化、分表策略等方面入手。1.合理设计主键和索引:推荐使用自增整数作为主键以减少页分裂;使用覆盖索引提升查询效率;定期分析慢查询日志并删除无效索引。2.分区表的合理使用:按时间范围等策略分区,提升查询和维护效率,但需注意分区裁剪问题。3.考虑读写分离和分库分表:读写分离缓解主库压力,分库分表适用于数据量极大场景,建议使用中间件并评估事务和跨库查询问题。前期规划和持续优化是关键。

优化内容管理系统(CMS)的MySQL 优化内容管理系统(CMS)的MySQL Jul 28, 2025 am 03:19 AM

ToimproveMySQLperformanceforCMSplatformslikeWordPress,firstimplementacachinglayerusingpluginslikeRedisorMemcached,enableMySQLquerycaching(ifapplicable),andusepagecachingpluginstoservestaticfiles.Second,optimizeMySQLconfigurationbyincreasinginnodb_buf

实施MySQL数据库复制过滤器 实施MySQL数据库复制过滤器 Jul 28, 2025 am 02:36 AM

MySQL复制过滤可在主库或从库端配置,主库端通过binlog-do-db或binlog-ignore-db控制binlog生成,适用于减少日志体积;从库端通过replicate-do-db、replicate-ignore-db、replicate-do-table、replicate-ignore-table及通配符规则replicate-wild-do-table和replicate-wild-ignore-table控制数据应用,更灵活且利于数据恢复;配置时需注意规则顺序、跨库语句行为、

MySQL中的截断,删除和掉落有什么区别? MySQL中的截断,删除和掉落有什么区别? Aug 05, 2025 am 09:39 AM

DELETEremovesspecificorallrows,keepstablestructure,allowsrollbackandtriggers,anddoesnotresetauto-increment;2.TRUNCATEquicklyremovesallrows,resetsauto-increment,cannotberolledbackinmostcases,doesnotfiretriggers,andkeepstablestructure;3.DROPremovesthee

See all articles