Oracle的sql语句中case关键字的用法 & 单双引号的使用

关于sql中单引号和双引号的使用,来一点说明:

  1. 查询列的别名如果含有汉字或者特殊字符(如以'_'开头),需要用双引号引起来。而且只能用双引号,单引号是不可以的。

  2. 如果想让某列返回固定的值,而且这个返回值是varchar类型的,返回值需要用单引号引起来。而且只能用单引号,双引号是不可以的。

 

例子1:

a)查询列中有"_"开头的列名时,需要用双引号引起来。

b)使用"case"关键字,根据分数直接判断是否及格。

create table tbl_score(
    id NUMBER(4), --id
    name varchar2(30), --名称
    score NUMBER(3), --分数
    otherscore NUMBER(3) --其他分数
);
select t.id as "_id",
       t.name as name,
       case
           when t.score >= 60 then
            '及格'
           else
            '不及格'
       end as "是否及格",
       t.score as "分数"
  from tbl_score t;

 

例子2:

根据情况返回不同列的值。

同用上面的tbl_score表。

select t.id as "_id",
       t.name as name,
       case
           when t.score is null then
            t.otherscore --也可返回固定值
           else
            t.score
       end as "分数",
       t.score,
       t.otherscore
  from tbl_score t;

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值