电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

MySQL基礎教程6 —— 函數之控制流程函數

瀏覽:26日期:2023-10-17 16:11:36

語法:

CASEvalueWHEN [compare-value] THENresult[WHEN [compare-value] THENresult...] [ELSEresult] END CASE WHEN [condition] THENresult[WHEN [condition] THENresult...] [ELSEresult] END

在第一個方案的返回結果中,value=compare-value。而第二個方案的返回結果是第一種情況的真實結果。如果沒有匹配的結果值,則返回結果為ELSE后的結果,如果沒有ELSE部分,則返回值為NULL。

mysql>SELECT CASE 1 WHEN 1 THEN ’one’

->WHEN 2 THEN ’two’ ELSE ’more’ END;

-> ’one’

mysql>SELECT CASE WHEN 1>0 THEN ’true’ ELSE ’false’ END;

-> ’true’

mysql>SELECT CASE BINARY ’B’

->WHEN ’a’ THEN 1 WHEN ’b’ THEN 2 END;

-> NULL

一個CASE表達式的默認返回值類型是任何返回值的相容集合類型,但具體情況視其所在語境而定。如果用在字符串語境中,則返回結果味字符串。如果用在數字語境中,則返回結果為十進制值、實值或整數值。

IF(expr1,expr2,expr3)

如果expr1是TRUE (expr1<> 0 andexpr1<> NULL),則IF()的返回值為expr2;否則返回值則為expr3。IF()的返回值為數字值或字符串值,具體情況視其所在語境而定。

mysql>SELECT IF(1>2,2,3);

-> 3

mysql>SELECT IF(1<2,’yes ’,’no’);

-> ’yes’

mysql>SELECT IF(STRCMP(’test’,’test1’),’no’,’yes’);

-> ’no’

如果expr2或expr3中只有一個明確是NULL,則IF()函數的結果類型 為非NULL表達式的結果類型。

expr1作為一個整數值進行計算,就是說,假如你正在驗證浮點值或字符串值,那么應該使用比較運算進行檢驗。

mysql>SELECT IF(0.1,1,0);

-> 0

mysql>SELECT IF(0.1<>0,1,0);

-> 1

在所示的第一個例子中,IF(0.1)的返回值為0,原因是0.1被轉化為整數值,從而引起一個對IF(0)的檢驗。這或許不是你想要的情況。在第二個例子中,比較檢驗了原始浮點值,目的是為了了解是否其為非零值。比較結果使用整數。

IF() (這一點在其被儲存到臨時表時很重要)的默認返回值類型按照以下方式計算:

表達式返回值expr2或expr3返回值為一個字符串。字符串expr2或expr3返回值為一個浮點值。浮點expr2或expr3返回值為一個整數。整數

假如expr2和expr3都是字符串,且其中任何一個字符串區分大小寫,則返回結果是區分大小寫。

IFNULL(expr1,expr2)

假如expr1不為NULL,則IFNULL()的返回值為expr1;否則其返回值為expr2。IFNULL()的返回值是數字或是字符串,具體情況取決于其所使用的語境。

mysql>SELECT IFNULL(1,0);

-> 1

mysql>SELECT IFNULL(NULL,10);

-> 10

mysql>SELECT IFNULL(1/0,10);

-> 10

mysql>SELECT IFNULL(1/0,’yes’);

-> ’yes’

IFNULL(expr1,expr2)的默認結果值為兩個表達式中更加“通用”的一個,順序為STRING、REAL或INTEGER。假設一個基于表達式的表的情況,或MySQL必須在內存儲器中儲存一個臨時表中IFNULL()的返回值:

CREATE TABLE tmp SELECT IFNULL(1,’test’) AS test;

在這個例子中,測試列的類型為CHAR(4)。

NULLIF(expr1,expr2)

如果expr1=expr2成立,那么返回值為NULL,否則返回值為expr1。這和CASE WHENexpr1=expr2THEN NULL ELSEexpr1END相同。

mysql>SELECT NULLIF(1,1);

-> NULL

mysql>SELECT NULLIF(1,2);

-> 1

注意,如果參數不相等,則MySQL兩次求得的值為 expr1。

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 薪动-人力资源公司-灵活用工薪资代发-费用结算-残保金优化-北京秒付科技有限公司 | 湖州织里童装_女童男童中大童装_款式多尺码全_织里儿童网【官网】-嘉兴嘉乐网络科技有限公司 | 蔬菜配送公司|蔬菜配送中心|食材配送|饭堂配送|食堂配送-首宏公司 | 齿轮减速机电机一体机_齿轮减速箱加电机一体化-德国BOSERL蜗轮蜗杆减速机电机生产厂家 | 合肥礼品公司-合肥礼品定制-商务礼品定制公司-安徽柏榽商贸有限公司 | 长沙一级消防工程公司_智能化弱电_机电安装_亮化工程专业施工承包_湖南公共安全工程有限公司 | Pos机办理_个人商户免费POS机申请-拉卡拉办理网 | 聚氨酯保温钢管_聚氨酯直埋保温管道_聚氨酯发泡保温管厂家-沧州万荣防腐保温管道有限公司 | 登车桥动力单元-非标液压泵站-非标液压系统-深圳市三好科技有限公司 | 广东教师资格网-广东教师资格证考试网| 青岛侦探_青岛侦探事务所_青岛劝退小三_青岛婚外情取证-青岛王军侦探事务所 | 色油机-色母机-失重|称重式混料机-称重机-米重机-拌料机-[东莞同锐机械]精密计量科技制造商 | 山东限矩型液力偶合器_液力耦合器易熔塞厂家-淄博市汇川源机械厂 | 固诺家居-全屋定制十大品牌_整体衣柜木门橱柜招商加盟 | 蜘蛛车-登高车-高空作业平台-高空作业车-曲臂剪叉式升降机租赁-重庆海克斯公司 | 齿辊分级破碎机,高低压压球机,立式双动力磨粉机-郑州长城冶金设备有限公司 | 世界箱包品牌十大排名,女包小众轻奢品牌推荐200元左右,男包十大奢侈品牌排行榜双肩,学生拉杆箱什么品牌好质量好 - Gouwu3.com | 商标转让-商标注册-商标查询-软著专利服务平台 - 赣江万网 | PCB接线端子_栅板式端子_线路板连接器_端子排生产厂家-置恒电气 喷码机,激光喷码打码机,鸡蛋打码机,手持打码机,自动喷码机,一物一码防伪溯源-恒欣瑞达有限公司 假肢-假肢价格-假肢厂家-河南假肢-郑州市力康假肢矫形器有限公司 | 绿萝净除甲醛|深圳除甲醛公司|测甲醛怎么收费|培训机构|电影院|办公室|车内|室内除甲醛案例|原理|方法|价格立马咨询 | 亿立分板机_曲线_锯片式_走刀_在线式全自动_铣刀_在线V槽分板机-杭州亿协智能装备有限公司 | 袋式过滤器,自清洗过滤器,保安过滤器,篮式过滤器,气体过滤器,全自动过滤器,反冲洗过滤器,管道过滤器,无锡驰业环保科技有限公司 | 郑州水质检测中心_井水检测_河南废气检测_河南中环嘉创检测 | 茶楼装修设计_茶馆室内设计效果图_云臻轩茶楼装饰公司 | 污水处理设备维修_污水处理工程改造_机械格栅_过滤设备_气浮设备_刮吸泥机_污泥浓缩罐_污水处理设备_污水处理工程-北京龙泉新禹科技有限公司 | 北京易通慧公司从事北京网站优化,北京网络推广、网站建设一站式服务商-北京网站优化公司 | 外观设计_设备外观设计_外观设计公司_产品外观设计_机械设备外观设计_东莞工业设计公司-意品深蓝 | 硬齿面减速机_厂家-山东安吉富传动设备股份有限公司 | 小型玉石雕刻机_家用玉雕机_小型万能雕刻机_凡刻雕刻机官网 | 国际船舶网 - 船厂、船舶、造船、船舶设备、航运及海洋工程等相关行业综合信息平台 | 不锈钢螺丝 - 六角螺丝厂家 - 不锈钢紧固件 - 万千紧固件--紧固件一站式采购 | 顺辉瓷砖-大国品牌-中国顺辉 | 高温热泵烘干机,高温烘干热泵,热水设备机组_正旭热泵 | 北京律师事务所_房屋拆迁律师_24小时免费法律咨询_云合专业律师网 | 电动葫芦|手拉葫芦|环链电动葫芦|微型电动葫芦-北京市凌鹰起重机械有限公司 | 电缆隧道在线监测-智慧配电站房-升压站在线监测-江苏久创电气科技有限公司 | 济南侦探调查-济南调查取证-山东私家侦探-山东白豹调查咨询公司 密集架|电动密集架|移动密集架|黑龙江档案密集架-大量现货厂家销售 | 气象监测系统_气象传感器_微型气象仪_气象环境监测仪-山东风途物联网 | 品牌设计_VI设计_电影海报设计_包装设计_LOGO设计-Bacross新越品牌顾问 | PAS糖原染色-CBA流式多因子-明胶酶谱MMP-上海研谨生物科技有限公司 | 小型单室真空包装机,食品单室真空包装机-百科 |