Oracle raw类型

RAW(size):长度为size字节的原始二进制数据,size的最大值为2000字节;  RAW类型好处:在网络中的计算机之间传输 RAW 数据时,或者使用 Oracle 实用程序将 RAW 数据从一个数据库移到另一个数据库时,Oracle 服务器不执行字符集转换。  RAW,类似于CHAR,声明方式RAW(L),L为长度,以字节为单位,作为数据库列最大2000,作为变量最大32767字节。  LONG RAW,类似于LONG,作为数据库列最大存储2G字节的数据,作为变量最大32760字节;

操作:  
create table raw_test (id number, raw_date raw(10)); 

insert into raw_test values (1, hextoraw(‘ff‘));
insert into raw_test values (2,UTL_RAW.cast_to_raw(‘abc‘));
insert into raw_test values (3,UTL_RAW.cast_to_raw(‘你好你你的‘));

SELECT r.*,DUMP(r.raw_date),RAWTOHEX(r.raw_date),UTL_RAW.CAST_TO_VARCHAR2(r.raw_date) FROM raw_test r;
-----------------------------------------------------------------------------

ID    RAW_DATE    DUMP(R.RAW_DATE)        RAWTOHEX(R.RAW_DATE)    UTL_RAW.CAST_TO_VARCHAR2(R.RAW
1      FF        Typ=23 Len=1: 255        FF                  
2      616263      Typ=23 Len=3: 97,98,99     616263               abc
3    C4E3BAC3C4E3C4E3B5C4    Typ=23 Len=10: 196,227,186,195,196,227,196,227,181,196    C4E3BAC3C4E3C4E3B5C4    你好你你的

这里用到了几个函数:

  1. UTL_RAW.CAST_TO_RAW:该函数按照缺省字符集(一般为GB2312),将VARCHAR2字符串转换为RAW,直接把字符串中每个字符的ASCII码存放到RAW类型的字段中。

  2.UTL_RAW.CAST_TO_VARCHAR2:该函数按照缺省字符集合(一般为GB2312),将RAW转换为VARCHAR2。

  3.HEXTORAW(string):当使用HEXTORAW时,会把字符串中数据当作16进制数,String中的每两个字符表示了结果RAW中的一个字节。

  4.RAWTOHEX(rawvalue):将RAW类数值rawvalue转换为一个相应的十六进制表示的字符串. rawvalue中的每个字节都被转换为一个双字节的字符串. RAWTOHEX和HEXTORAW是两个相反的函数.

 其实RAW和VARCHAR是类似的,只是存储在RAW里的是二进制值,在任何时候不会做自动的字符集转换,这是RAW和VARCHAR的不同,RAW只是一种外部类型,其内部存储是VARRAW  
时间: 2024-08-25 20:42:11

Oracle raw类型的相关文章

Oracle数据库类型总结

RACLE基本数据类型(亦叫内置数据类型 built-in datatypes)可以按类型分为:字符串类型.数字类型.日期类型.LOB类型.LONG RAW& RAW类型.ROWID & UROWID类型.一 字符串类型CHAR类型 CHAR(size [BYTE | CHAR]) CHAR类型,定长字符串,会用空格填充来达到其最大长度.非NULL的CHAR(12)总是包含12字节信息.CHAR字段最多可以存储2,000字节的信息.如果创建表时,不指定CHAR长度,则默认为1.另外你可以指

Oracle 字段类型

Oracle 字段类型 http://www.cnblogs.com/lihan/archive/2010/01/06/1640547.html 字段类型 描述 字段长度及其缺省值 CHAR (size) 用于保存定长(size)字节的字符串数据. 每行定长(不足部分补为空格):最大长度为每行2000字节,缺省值为每行1字节.设置长度(size)前需考虑字符集为单字节或多字节. VARCHAR2 (size ) 用于保存变长的字符串数据.其中最大字节长度由(size)指定. 每行长度可变,最大长

Oracle number类型查询精度丢失的解决方法

Oracle number类型查询时,有时候会遇到精度丢失的问题,下面为您介绍了一个解决Oracle number类型查询精度丢失的方法,供您参考. 一.Oracle number类型查询需求中要求查到一个字段的值然后保持小数点后2位//如果采用如下方法从ResultSet得到一个数字,而这个数字大于40000,则得到的数据将不准确 floatzcxxhj+=rss.getFloat(3); //而如果采用double就没有问题 doublezcxxhj+=rss.getDouble(3); /

oracle 自定义类型 type / create type

一:Oracle中的类型有很多种,主要可以分为以下几类: 1.字符串类型.如:char.nchar.varchar2.nvarchar2. 2.数值类型.如:int.number(p,s).integer.smallint. 3.日期类型.如:date.interval.timestamp. 4.PL/SQL类型.如:pls_integer.binary_integer.binary_double(10g).binary_float(10g).boolean.plsql类型是不能在sql环境中使

oracle队列类型

本文参照oracle11gr2官方文档<Oracle? Database Reference11g Release 2 (11.2)> 队列定义:oracle队列存在共享内存中串行访问数据库资源的锁.它产生于一次回话或者一个事物. 队列查找:在系统数据库词典视图 DBA_LOCK_INTERNAL和DBA_LOCK的Lock_type那一列. 产生原因:oracle资源唯一地标识一个对象,可以被不同的会话实例之间在一个实例(本地资源)或(全球资源).每个会话试图锁定资源所以就会产生队列 队列名

oracle 数组类型

create or replace function my_test(p_str varchar2) return number as --普通变量 v_var varchar2(1000); --固定长度数组 type v_ar is varray(10) of varchar2(30); my_ar v_ar:=v_ar('g','m','d','龚','帅'); --可变长度数值 type type_array is table of varchar2(20) index by binar

Oracle数组类型

Oracle数组类型 Oracle的数组类型,范例: Sql代码 create or replace function my_test(p_str varchar2) return number as --普通变量 v_var varchar2(1000); --固定长度数组 type v_ar is varray(10) of varchar2(30); my_ar v_ar:=v_ar('g','m','d','龚','帅'); --可变长度数值 type type_array is tab

Oracle数据库类型

字符类型char[(length)] 定长字符 最长2000字节varchar2[(length)] 可变长度的字符数据类型,最长4000字节NCHAR[(length)] 固定长度的字符数据类型,由国际字符语言(national language Support,NLS)字符集字符组成,最长2000字节LONG 可变长度的字符数据类型 最长2GBRAW 原始的二进制数据类型,最长2000字节long raw 原始的二进制数据类型,最长2GBrawid 数据库中一窜12字节地址,用于定位磁盘上某

db2和oracle字段类型对比

在网上找到一片关于oracle与DB2数据类型的比较,特记下来. Oracle DB2/400 Oracle数据类型 注意事项 DB2 UDB数据类型 注意事项 DATE DATETIMETIMESTAMP l 如果只使用MM/DD/YYY,那么使用DATE类型.l 如果只使用HH:MM:SS, 那么使用TIME类型.l 如果要使用日期和时间,则使用时间戳类型(TIMESTAMP)l 能使用Oracle中的TO_CHAR()函数来取DATE的字串来分别和DB2/400的DATE.TIME相匹配.