问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

oracle中有一个变量,值为 01,02,03,04 要转换为 A,B,C,D 如何转?用replace只能转一个

发布网友 发布时间:2022-04-10 06:42

我来回答

2个回答

懂视网 时间:2022-04-10 11:04

 as sysdba;
  • conn scott/123456@192.168.22.210:1521/orcl; 从当前用户转换成scott用户
  • show user; 显示当前用户名
  • show linesize; 显示的行宽
  • set linesize 150; 设置行宽
  • col ename for a8; col sal for 9999;设置列ename为字符长度为8个长度;设置列sal为4位数字;
  • c 命令字符替换,如: c /form/from 或者c!form!from
  • host cls;清屏幕
  • spool d:/1.sql 将命令写入到1.sql文件中。spool off终止写入文件中。
  • B:sql优化原则

    1. 查询的时候尽量使用列名;如:select ename,sal from emp; 
    2. 分组查询没有多行函数(聚合函数),如果使用过滤,考虑使用where还是having
    3. 在子查询和多表查询之间选择,尽量使用多表查询
    4. 在集合运算中,如果union 和union all都可以,考虑使用union all 。因为union需要去掉重复的。
    5. 能够不要使用集合运算就不要使用集合运算。

    注意:掌握oracle的常规命令,在学习过程中总结一些优化原则;

    02-空值和别名

    A:处理列值为null

    oracle中的列值为null做四则运算结果都为null。处理方法:nvl(null,0) 

    B:判断列值为null

    oracle中判断一个列值为null使用is null 或者is not null

    C:给一个列取一个别名可以使用as 或者省略as

         select empno as “员工编号” , ename 员工姓名 from emp;

         注意:别名需要使用“”,或者不加“”。别名中间有空格的需要“”;

    不能使用单引号;

    D:distinct 取出后面的所有列唯一值

    select distinct job,deptno from emp;这里的distinct作用于后面的所有的列。

                select distinct(job) from emp;可以将加()

    E:|| 和concat() 将字符连接起来

    select concat(‘hello’,’world’) from dual;使用concat()后面需要加表。mysql并严格遵循sql1990标准;

                select ‘hello’ || ‘world’ from dual;

             注意:字符串使用单引号‘’,不能使用双引号“”,使用双引号的是别名。

    dual是伪表;

    03-SQL和iSQLPLUS

    A:sql、sqlplus、isqlplus区别

    1. sql:insert update delete等常见的sql语句,关键词没有缩写。命令可以控制表中定义和数据;
    2. sqlplus:desc/ed/c/col/for等命令都是sqlplus命令,关键词有缩写,命令不能改变数据库中的数据;访问sqlplus服务端口是1158;
    3. isqlplus:是sqlplus是网页版本的sqlplus。可以执行脚本,也可以运行脚本;访问isqlplus服务需要访问5560端口;

    04-过滤where

    A:where 后面比较运算符(>,<,!=,>=,<=,between and ,in,like,not like,is null,is not null)

    1. 后面=可以接数据或者字符串,其中日期格式需要注意

        如果select * from emp where hiredate=’81-09-08’ 执行会出现错误;

     因为该日期字符串格式与oracle当前格式不一致,oralce无法处理成日期类型。但是可以修改日期格式;alter session|system set NLS_DATE_FORMATE=’yy-mm-dd’.select * from v$nls_parameters; 可以查看到系统的所有变量;

    1. between and (包括边界,小值在前,大值在后)
    2. in后面集合中可以加null,not in()集合中不能有null
    3. 注意:where 后面用于过滤或者连接其他表的条件,重点掌握常用>,<,!=,>=,<=,between and ,in,like,not like,is null,is not null操作;

    05-逻辑运算符和排序

    A:where 后面使用逻辑运算符(and ,or ,not)

    注意:condition1 and condition2 和condition2 and condition1的区别;解析的顺序是从右边到左边;explain plan for select * from emp where condition1 and condition2;

    B:查询排序(order by)

    order by 列名/表达式/别名/序列. 且order by 后面可以接多个列

    如果列中有值为null,则desc排序会出现null值行在前null最大,为了解决该问题:

    select * from emp order by comm desc nulls last;

    注意:order by 多个列参与排序的特殊性。

     06-函数简介

    A:单行函数和多行函数

     注意:操作返回一行数据的函数叫单行函数,操作返回的多行数据的函数叫多行函数;

    07-字符函数和数值函数

    A:字符函数

    1. 大小写控制

    B:数值函数

    1. round():四舍五入
    1. truncate():截断

    注意:重点掌握length(),substr(),instr(),round().

    08-日期函数

    A:日期函数

    Oracle中提供了很多和日期相关的函数,包括日期的加减,在日期加减时有一些规律

    日期 – 数字 = 日期

    日期 + 数字 = 日期

    日期 – 日期 = 数字

    09-转换函数

    A:oracle中隐式转换(查百度)

    B:to_char():日期转换成字符串,数字转换成字符

    C:to_number():字符串转换成数字

    D:to_date():字符串转换成日期

    注意:掌握to_char(),to_number(),to_date() ,3个转换函数;

    10-通用函数和条件表达式

    A:通用函数

    1. nvl(expr1,expr2) 如果repr1是null则把expr1处理成expr2
    2. nvl2(expr1,expr2,expr3),如果repr1不为null,则值为expr2,为null则返回expr3
    3. nullif(expr1,expr2),如果repr1=repr2,则返回null,否则返回expr1
    4. coalesce(expr1,expr2….), 依次参考各参数表达式,遇到非null值即停止并返回该值。
      如果所有的表达式都是空值,最终将返回一个空值B:条件表达式
      1. case  xx when xx then xx  when xxx  then xx else xx end;
      2. decode()

    注意:nvl(),nvlif()和2个条件语句必须掌握。

    11-多行函数

    A:分组函数(avg(),max(),min(),count(),sum())

    B:分组

           group by  having  order by

    注意:多行函数在sql中的使用;

    oracle01

    标签:一个   多行   编号   expr   数字   ast   定义   字符函数   xpl   

    热心网友 时间:2022-04-10 08:12

    1、可以使用decode函数
    decode(字段名,'01','A','02','B','03','C','04','D')追问我试过了,但是它只是给我转换了01的值,后面的没有转换

    追答

    那你字段里的值什么 可以示例下吗?

    比如:01020304

    replace(replace(replace(replace(字段名,'01','A'),'02','B'),'03','C'),'04','D')


    声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
    什么牌子洗发水香味好闻持久 有哪些留香久的香氛洗发水值得入手? 香味持久的洗发水有哪些? 洗发水香味最持久排行 家装适合什么地板 客厅地板装修什么地板好 我家装修是北欧风格,想选一款与家里装修风格相匹配的地板,有何推荐? 什么样的装修用什么样的地板好 镇域 村镇 集体建设用地的区别 农村宅基地的升值之路:农民的生存保障还是财富陷阱? 王牌电视机三十四寸价格多少 王牌液晶电视.32#多少价格 我的手机密码忘记了,试了很多次都开不了,怎么办? tcl王牌液晶电视怎么样?tcl王牌液晶电视报价 早上爱吃煮鸡蛋的人,切记哪“2不”比较好? 何首乌煮鸡蛋什么人不能吃 皖视王牌电视机26寸价格多少 红糖煮鸡蛋什么人吃不好 网名情侣两个字,男的叫朕 开大会员,已经有的超级会员豪华黄钻的时间如何计算 跪求两个字的唯美 个性的情侣名 求两个字的情侣名 早上吃水煮蛋有哪些好处呢?哪些人不适合吃鸡蛋呢? 我的QQ号有了会员和豪华黄钻,如果在开大会员,钱会少点吗? 开大会员自动激活svip和豪华黄钻 我现在有会员和黄钻了,再开是不是开多久大会员送多久黄钻和会员? 开年费大会员会激活一年超会和豪华黄钻吗? 《伊索寓言》读后感500字 伊索寓言读后感400字怎么写 本人急需450字伊索寓言读后感 O(∩_∩)O谢谢 450字一字不少读后感,废话走开 王牌的液晶电视55公寸价格是多少 TC乚王牌电视43寸智能液晶电视多少钱 延津县王楼镇天气预报 延津明天早上会不会下霜? 微博里关注了两个博主参与抽奖,但我屏蔽了其中一个博主的微博内容,还能参与抽奖吗?还能被抽中吗? 我想买股票,但不懂怎么操作? 如果教师编制考试通过了但是没有在规定的时间内领到教师资格证怎么办 我想买股票但是又不知道怎么买怎么办 我想买股票,不知道怎么买? 我需要买股票,首先要怎么做 补发教师资格证书的书面申书怎么写 我想去买股票,不知道怎么操作?求解…… 如果我想买股票?要怎么做呢? 神樱大社下的地下室怎么进入 《原神》神樱大祓镇守之森结界顺序是什么? 《原神》神樱大祓三个位置神里屋敷解密是什么? 《原神》神樱树为什么开不了? 原神神樱大祓三个位置 原神神樱树30级以后怎么解锁 原神神樱树背景