java 中decode函数_decode()函数使用技巧

·软件环境:

1、Windows NT4.0+ORACLE 8.0.4

2、ORACLE安装路径为:C:/ORANT

·含义解释:

decode(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)

该函数的含义如下:

IF 条件=值1 THEN

RETURN(翻译值1)

ELSIF 条件=值2 THEN

RETURN(翻译值2)

......

ELSIF 条件=值n THEN

RETURN(翻译值n)

ELSE

RETURN(缺省值)

END IF

·        使用方法:

1、比较大小

select decode(sign(变量1-变量2),-1,变量1,变量2) from dual; --取较小值

sign()函数根据某个值是0、正数还是负数,分别返回0、1、-1

例如:

变量1=10,变量2=20

则sign(变量1-变量2)返回-1,decode解码结果为“变量1”,达到了取较小值的目的。

2、表、视图结构转化

现有一个商品销售表sale,表结构为:

month    char(6)      --月份

sell    number(10,2)   --月销售金额

现有数据为:

200001  1000

200002  1100

200003  1200

200004  1300

200005  1400

200006  1500

200007  1600

200101  1100

200202  1200

200301  1300

想要转化为以下结构的数据:

year   char(4)      --年份

month1  number(10,2)   --1月销售金额

month2  number(10,2)   --2月销售金额

month3  number(10,2)   --3月销售金额

month4  number(10,2)   --4月销售金额

month5  number(10,2)   --5月销售金额

month6  number(10,2)   --6月销售金额

month7  number(10,2)   --7月销售金额

month8  number(10,2)   --8月销售金额

month9  number(10,2)   --9月销售金额

month10  number(10,2)   --10月销售金额

month11  number(10,2)   --11月销售金额

month12  number(10,2)   --12月销售金额

结构转化的SQL语句为:

create or replace view

v_sale(year,month1,month2,month3,month4,month5,month6,month7,month8,month9,month10,month11,month12)

as

select

substrb(month,1,4),

sum(decode(substrb(month,5,2),'01',sell,0)),

sum(decode(substrb(month,5,2),'02',sell,0)),

sum(decode(substrb(month,5,2),'03',sell,0)),

sum(decode(substrb(month,5,2),'04',sell,0)),

该文章转载自宋氏电脑 技术无忧:http://www.pc51.net/data/ORACLE/2007-01-12/4692.html

posted on 2008-04-11 10:42 Mark 阅读(373) 评论(0)  编辑  收藏 所属分类: Oracle

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 的编码解码涉及到字符串和字节之间的转换。字符串是由 Unicode 字符组成的,而字节是由二进制数据组成的。因此,需要在字符串和字节之间进行编码和解码。Java 提供了多种编码和解码方法,包括以下几种: 1. ASCII 编码:ASCII 码是一种基本的字符编码方式,它使用 7 位二进制数对 128 个字符进行编码。Java 可以使用 String.getBytes("US-ASCII") 方法将字符串转换为 ASCII 编码的字节数组,使用 new String(bytes, "US-ASCII") 方法将字节数组转换为字符串。 2. UTF-8 编码:UTF-8 是一种变长的 Unicode 编码方式,它使用 1 到 4 个字节表示一个 Unicode 字符。Java 可以使用 String.getBytes("UTF-8") 方法将字符串转换为 UTF-8 编码的字节数组,使用 new String(bytes, "UTF-8") 方法将字节数组转换为字符串。 3. Unicode 编码:Unicode 是一种固定长度的字符编码方式,它使用 2 个字节表示一个字符。Java 可以使用 String.getBytes("Unicode") 方法将字符串转换为 Unicode 编码的字节数组,使用 new String(bytes, "Unicode") 方法将字节数组转换为字符串。 4. Base64 编码:Base64 是一种将二进制数据转换为 ASCII 字符的编码方式,它将 3 个字节的二进制数据编码为 4 个字符。Java 可以使用 Base64 类进行编码和解码,例如: ```java String str = "Hello, world!"; byte[] bytes = str.getBytes("UTF-8"); String encoded = Base64.getEncoder().encodeToString(bytes); // 编码 byte[] decoded = Base64.getDecoder().decode(encoded); // 解码 String result = new String(decoded, "UTF-8"); ``` 以上是 Java 编码解码的基本方法,具体应根据实际需要选择合适的编码方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值