CASE表达式实现基于条件逻辑来返回一个值
我们在开发过程中,经常需要针对一列,基于条件逻辑来返回一个值,那么,这时候就需要使用到CASE表达式了。
例如,以下对Products表的查询就在SELECT语句中使用了CASE表达式,以生成用于描述categoryid列取值的信息。
SQL代码如下:
-- 设置数据库上下文 USE TSQLFundamentals2008; GO SELECT productid,productname,categoryid, CASE categoryid WHEN 1 THEN 'Beverages' WHEN 2 THEN 'Condiments' WHEN 3 THEN 'Dairy Products' WHEN 4 THEN 'Confections' WHEN 5 THEN 'Grains/Cereals' WHEN 6 THEN 'Meat/Poultry' WHEN 7 THEN 'Produce' WHEN 8 THEN 'Seafood' ELSE 'Unkown Category' END AS categoryname FROM Production.Products;
查询结果:
相关推荐
-
CASE表达式实现基于条件逻辑来返回一个值
我们在开发过程中,经常需要针对一列,基于条件逻辑来返回一个值,那么,这时候就需要使用到CASE表达式了. 例如,以下对Products表的查询就在SELECT语句中使用了CASE表达式,以生成用于描述categoryid列取值的信息. SQL代码如下: -- 设置数据库上下文 USE TSQLFundamentals2008; GO SELECT productid,productname,categoryid, CASE categoryid WHEN 1 THEN 'Beverages' W
-
基于layui table返回的值的多级嵌套的解决方法
我在学习layui的过程中遇到了table返回值的问题,如果服务器端返回给你的数据是多级嵌套的话,那你在前台是解析不了的,在table.js源码中 它渲染数据是用了 data = res[options.response.dataName] || [] 这个意味着它源码不支持嵌套数据 举个例子把 比如服务器端返回的数据中data>dataList>list 把这个数据返回给前段解析出来的是 res[data.dataList.list]类似这种的结构,当然解析不了,所以我写了一个方法处理返回的
-
在python里从协程返回一个值的示例
下面的例子演法了怎么样从协程里返回一个值: import asyncio async def coroutine(): print('in coroutine') return 'result' event_loop = asyncio.get_event_loop() try: return_value = event_loop.run_until_complete( coroutine() ) print('it returned: {!r}'.format(return_value)) f
-
Ruby中case表达式详解
Ruby的case表达式有两种形式: 第一种形式接近于一组连续的if语句:它让你列出一组条件,并执行第一个为真的条件表达式所对应的语句. 第二种形式,在case语句的顶部指定一个目标,而每个when从句列出一个或者多个比较条件 和if一样,case返回执行的最后一个表达式的值:而且如果表达式和条件在同一行上的话,可以用then关键字来加以区分.
-
SQL CASE 表达式的具体使用
目录 CASE 表达式里的聚合函数 聚合与非聚合不能混用 WHERE 中的 CASE GROUP BY 中的 CASE ORDER BY 中的 CASE 总结 CASE 表达式分为简单表达式与搜索表达式,其中搜索表达式可以覆盖简单表达式的全部能力,我也建议只写搜索表达式,而不要写简单表达式. 简单表达式: SELECT CASE city WHEN '北京' THEN 1 WHEN '天津' THEN 2 ELSE 0 END AS abc FROM test 搜索表达式: SELECT CAS
-
基于C语言编写一个简单的抽卡小游戏
目录 效果图展示 开始的界面 输入1 输入10 输入0 实现代码 test4.26.c 许愿.c game.h 下载 小奔最近学了C语言不少的东西,但是想用学到的东西来搞一个小游戏. 不过小奔就不做那些猜数字等小游戏了,虽然很经典,但是可以尝试一下其他比较好玩的. 小奔喜欢玩原神,但它抽卡系统的中奖概率太低了,所以就类似做一个它的抽卡系统吧,不过没有保底功能哦(小奔还不想搞,还要学习新的知识,不过以后熟练了就可能会搞一个),是全角色抽卡,只有角色没有武器的,可以十连抽,没有保底功能,抽中的概率只
-
基于React Context实现一个简单的状态管理的示例代码
目录 前言 封装一个父组件用来包裹其他子组件 子组件如何获取数据呢 class Component 方式 context.Consumer useContext 总结 参考 前言 在大多数情况下,我们开发项目都需要一个状态管理,方便我们在全局共享状态库,在React生态里比较流行的几个库 redux.mobx.recoil 但是对于小项目,我们完全可以自己封装一个状态管理,减少一个包的安装就可以减小打包以后的项目体积. 主要分两步: 封装一个顶层组件提供数据 子组件获取数据和更新数据 封装一个父
-
SQL 中 CASE 表达式的使用方式
目录 1. 前言 2. 语法 3. 注意点 4. 分类汇总数据 5. 一条SQL实现不同条件的统计 6. 使用CHECK约束定义多个列的条件关系 7. 在UPDATE语句中进行条件分支 8. 生成交叉表 9. CASE表达式中使用聚合函数 10. 按照自定义规则排序列 1. 前言 CASE 表达式是从 SQL-92 标准开始被引入的. 在 CASE 表达式里,可以使用 BETWEEN .LIKE和 < .> 等便利的谓词组合,以及能嵌套子查询的 IN 和 EXISTS 谓词. 2. 语法 CA
-
详解基于vue-cli3快速发布一个fullpage组件
前言 想必大家都看过fullpage.js--这是一款非常好用的翻页插件. 现在vue非常流行,大家想不想发布一个组件给别人使用呢? 这里我们基于vue-cli3快速搭建一个简单的fullpage组件给别人使用,当然你也可以做你感兴趣的组件发布给别人用~ GITHUB 链接 开始 准备 $ npm i -g @vue/cli #全局vue-cli3 通过查看vue-cli3官网了解,创建一个新的普通项目. 思考 一开始要想别人如何调用我们写的组件,通过挂载vue实例方法(this.$alert)
-
基于ajax后台返回的数据为空前台显示出现undefined的解决方法
之前自己做的一个图书管理系统,显示图书借阅排行榜,因为翻译在数据库中有为空的字段,故前台显示会显示undefined. 以下贴上部门代码: $(document).ready(function () { $("#rankTable tbody").html(""); var id = 1; $.ajax({ url:"bookInfo/bookInfo_rank.action", type:"POST", data:{}, d
随机推荐
- 反射调用private方法实践(php、java)
- js 数组操作之pop,push,unshift,splice,shift
- js仿淘宝和百度文库的评分功能
- php使用fgetcsv读取csv文件出现乱码的解决方法
- 帝国CMS留言板回复后发送EMAIL通知客户
- C#通过反射获取当前工程中所有窗体并打开的方法
- MySQL binlog中的事件类型详解
- php中删除字符串中最先出现某个字符的实现代码
- 实例讲解php数据访问
- 使用shell脚本对Nginx日志进行切分的示例代码
- 建一个XMLHttpRequest对象池
- 浏览器兼容的JS写法总结
- Javascript createElement和innerHTML增加页面元素的性能对比
- java图片添加水印实例代码分享
- javascript实现html页面之间参数传递的四种方法实例分析
- 使用JavaScript链式编程实现模拟Jquery函数
- 路由器基础配置及传输协议
- Android7.0版本影响开发的改进分析
- 使用vue实现简单键盘的示例(支持移动端和pc端)
- OKHttp3(支持Retrofit)的网络数据缓存Interceptor拦截器的实现