网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.Oracle 9i 在 Red Hat Enterpris.
.时钟概述.
..
.Oracle数据库技术(16).
.oracle大数据量的导入和导出.
.前高管曝甲骨文内幕:走马换将渠.
.Bitmap Index 的一点探究.
.Oracle logminer使用方法总结.
.Fravo Oracle 1Z0-030 v1.0.
.在RedHat AS3上快速安装Oracle数.
.Oracle ADF框架介绍.
.[基础]9i新特性之五闪回查询.
.Linux平台数据库大比拚(1).
.如何让postfix支持maildir.
.教你在Oracle中通过网络连接导入.
.Oracle中如何快速删除数据字典管.
.FreeBSD 5.0RC1下Oracle 9i安装日.
.ORACLE DATE和TIMESTAMP数据类型.
.Oracle 10g 中新的 SQL 优化.
.Oracle数据库 监看lock script.

Oracle的函数vsize和length的区别讨论

发表日期:2008-2-9


The "length" functions return the length of char. LENGTH calculates length using characters as defined by the input character set.

LENGTHB uses bytes instead of characters. LENGTHC uses Unicode complete characters. LENGTH2 uses UCS2 codepoints. LENGTH4 uses UCS4 codepoints

length函数返回字符的长度,它使用定义好的输入的字符集计算长度.
lengthb使用bytes代替字符

VSIZE returns the number of bytes in the internal representation of eXPr.

vsize 返回内部表示的字节的数目。internal representation of expr谁能解释一下。

看sql示例:

select length('adfad合理') "bytesLengthIs" from dual --7

select lengthb('adfad') "bytesLengthIs" from dual --5

select lengthb('adfad合理') "bytesLengthIs" from dual --11

select vsize('adfad合理') "bytesLengthIs" from dual --11

select lengthc('adfad合理')"bytesLengthIs" from dual --7

结论:在utf-8的字符集下
lengthb=vsize
lengthc=length

疑问:中文字符怎么会占用了3个byte?而不是2个。是utf-8字符集的原因?
谁知道??????

参考文献:Oracle9i SQL Reference Release 2 (9.2)
  .................................................. 用String的getBytes方法测试了一下.
结论是utf-8的中文字符占用3个字节,gbk的中文字符占用2个字节,iso-8859-1的中文字符被识别为占用2个字节,iso不支持中文字符的编码,应该是都当成某个拉丁字母了.Oracle没有关系,oracle只是负责存储数据.
可以先用 select * from v$nls_parameters 看看oracle的字符集
下边是测试的类:

import Java.io.UnsupportedEncodingException;

public class TextEncoding {

/**
*
* @author:sunflower
* @date: 2007-1-24 上午10:09:40
* @todo: 调用的是String的自己的getBytes(encoding)方法,
* 使用指定的字符集将此 String 解码为字节序列,并将结果存储到一个新的字节数组中.
* @param content
* @param encode
* @return
*/
public static byte[] getBytes(String content,String charsetName)
throws UnsupportedEncodingException{
return content.getBytes(charsetName);
}

/**
*
* @author:sunflower
* @date: 2007-1-24 上午10:19:40
* @todo: 调用的是String的自己的getBytes()方法,
* 使用平台默认的字符集将此 String 解码为字节序列,并将结果存储到一个新的字节数组中。
* @param content
* @return
*/
public static byte[] getBytes(String content){
return content.getBytes();
}

public static void main(String[]args){
String content="1e宝宝";
byte[] len;
try{
len=getBytes(content,"UTF-8");
System.out.println(" the byte array length is "+len.length);
len=getBytes(content,"GBK");
System.out.println(" the byte array length is "+len.length);
len=getBytes(content,"ISO-8859-1");
System.out.println(" the byte array length is "+len.length);
}catch(Exception e){
System.out.println("Can 't recognize");
}

// System.out.println("the content byte[] length is "+);
}

}

输出 :
the byte array length is 8
the byte array length is 6
the byte array length is 4

Trackback: http://tb.blog.csdn.net/TrackBack.ASPx?PostId=1492768
上一篇:将PENDING OFFLINE状态的回滚段OFFLINE 人气:723
下一篇:记几个容易忘的oracle 函数 人气:950
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐