标签云
asm恢复 bbed bootstrap$ dul kcbzib_kcrsds_1 kccpb_sanity_check_2 kcratr_nab_less_than_odr kgegpa MySQL恢复 ORA-00312 ORA-00704 ORA-00742 ORA-01110 ORA-01190 ORA-01200 ORA-01555 ORA-01578 ORA-01595 ORA-600 2662 ORA-600 3020 ORA-600 4000 ORA-600 4137 ORA-600 4193 ORA-600 4194 ORA-600 16703 ORA-600 kcbzib_kcrsds_1 ORA-600 KCLCHKBLK_4 ORA-15042 ORA-15196 ORACLE 12C oracle dul ORACLE PATCH Oracle Recovery Tools oracle加密恢复 oracle勒索 oracle勒索恢复 oracle异常恢复 ORACLE恢复 Oracle 恢复 ORACLE数据库恢复 oracle 比特币 OSD-04016 YOUR FILES ARE ENCRYPTED 勒索恢复 比特币加密文章分类
- Others (2)
- 中间件 (2)
- WebLogic (2)
- 操作系统 (106)
- 数据库 (1,801)
- DB2 (22)
- MySQL (79)
- Oracle (1,637)
- Data Guard (53)
- EXADATA (8)
- GoldenGate (24)
- ORA-xxxxx (166)
- ORACLE 12C (72)
- ORACLE 18C (6)
- ORACLE 19C (15)
- ORACLE 21C (3)
- Oracle 23ai (8)
- Oracle ASM (69)
- Oracle Bug (8)
- Oracle RAC (54)
- Oracle 安全 (6)
- Oracle 开发 (28)
- Oracle 监听 (29)
- Oracle备份恢复 (611)
- Oracle安装升级 (101)
- Oracle性能优化 (62)
- 专题索引 (5)
- 勒索恢复 (86)
- PostgreSQL (33)
- pdu工具 (7)
- PostgreSQL恢复 (11)
- SQL Server (32)
- SQL Server恢复 (13)
- TimesTen (7)
- 达梦数据库 (3)
- 达梦恢复 (1)
- 生活娱乐 (2)
- 至理名言 (11)
- 虚拟化 (2)
- VMware (2)
- 软件开发 (43)
- Asp.Net (9)
- JavaScript (12)
- PHP (2)
- 小工具 (26)
-
最近发表
- obet(Oracle Block Editor Tool)第二版发布
- Oracle数据块编辑工具( Oracle Block Editor Tool)-obet
- Oracle坏块修复工具:Patch_blk
- ORA-01172 ORA-01151故障处理
- C_OBJ#_INTCOL#坏块导致数据库无法open故障处理
- ORA-600 kkkicreatecgmap:!efn3
- Oracle 19c 202510补丁(RUs+OJVM)-19.29
- 记录一次raid恢复之后数据库故障处理(ora-01200,ORA-26101,ORA-600)
- nbu备份文件img格式直接rman恢复
- ORA-600 kokasgi1故障处理(sys被重命名)
- Patch_SCN for Linux 功能完善
- ORA-600 2662错误处理-202510
- system表空间丢失部分文件恢复
- arm环境vg损坏mysql数据库恢复
- redhat系列7/8进入单用户模式
- Failed to open \EFI\redhat\grubx64.efi – Not Found 故障处理
- 11.2.0.4升级到19c详细操作过程
- Postgres数据库truncate表无有效备份恢复
- 一次幸运的ORA-07445 kdxlin故障恢复
- ORA-704 ORA-604 ORA-1426故障分析处理
标签归档:ORA-01465
ORA-01465: invalid hex number
网友反馈blob插入一些字段报错,查询metalink,发现使用rawtohex处理即可,测试如下:
SQL> create table t_lob (t blob);
Table created.
SQL> insert into t_lob values('-------');
insert into t_lob values('-------')
*
ERROR at line 1:
ORA-01465: invalid hex number
SQL> insert into t_lob values(rawtohex('---------'));
1 row created.
SQL> insert into t_lob values('----------&');
insert into t_lob values('----------&')
*
ERROR at line 1:
ORA-01465: invalid hex number
SQL> insert into t_lob values(rawtohex('----------&'));
1 row created.
SQL> commit;
Commit complete.
网友提供java处理代码如下:
///插入
public void test()
{
conn=DBUtil.getActiveConnection();
String sqlStr="Set define off";
String ss="————";
String sql="insert into test1(names,btestname) values('12',rawtohex('"+ss+"'))";
System.out.println(sqlStr);
System.out.println(sql);
try {
pstmt=conn.prepareStatement(sqlStr);
pstmt.addBatch();
pstmt=conn.prepareStatement(sql);
pstmt.addBatch();
pstmt.executeBatch();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
finally
{
DBUtil.closeStatement(pstmt);
DBUtil.closeConnection(conn);
}
}
////查询语句
public void getTest()
{
conn=DBUtil.getActiveConnection();
String sql="select * from test1 where names='12'";
//oracle.sql.BLOB blob = null;
InputStream inStream=null;
try {
pstmt=conn.prepareStatement(sql);
set=pstmt.executeQuery();
if(set!=null && set.next())
{
//接收blob类型
java.sql.Blob blob = (oracle.sql.BLOB)set.getBlob("btestname");
//注意
inStream = blob.getBinaryStream();
if(blob!=null) System.out.println("有值============");
try {
byte[] data = new byte[200];
int length=0;//每次读取的实际字节长度
//is.read()方法:从buff缓中区的第0个位开始读取字节,每次最多读取200,
//方法会返回一个实际读取的长度,用length接收,当值为-1时,表示所有的字节全部读取完毕
while((length=inStream.read(data,0,200))!=-1)
{
//把字节以平台的默认编码方式转为字符,从buff的第0个位开始转换,实际要转换的长度是length
String str=new String(data,0,length);
System.out.println("最终结果==== "+str+" ====");
}
//关闭流
inStream.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
finally
{
DBUtil.closeResultSet(set);
DBUtil.closeStatement(pstmt);
DBUtil.closeConnection(conn);
}
}

加我QQ(107644445)
