针对sql中BLOB类型的转换
SQL BLOB 值在 Java 编程语言中的序列化映射关系。
SerialBlob 类提供一个根据 Blob 对象创建实例的构造方法。注意,在根据 Blob 对象构造 SerialBlob 对象之前,Blob 对象应该已经将 SQL Blob 值的数据置于客户端上。SQL Blob 值的数据可以在客户端上以字节数组(使用 Blob.getBytes 方法)或未解释字节流的形式(使用 Blob.getBinaryStream 方法)实现。
SerialBlob 方法能够以字节数组或流的形式复制 SerialBlob 对象。这些方法还可以在 SerialBlob 对象中查找给定模式的字节或 Blob 对象,并可以更新或截断 Blob 对象。
| 构造方法摘要 | |
|---|---|
SerialBlob(Blob blob)根据给定 Blob 对象的序列化形式构造一个 SerialBlob 对象。 |
|
SerialBlob(byte[] b)按照给定 byte 数组的序列化形式构造一个 SerialBlob 对象。 |
|
| 方法摘要 | |
|---|---|
void |
free()此方法释放 Blob 对象及其占有的资源。 |
InputStream |
getBinaryStream()以输入流的形式返回此 SerialBlob 对象。 |
InputStream |
getBinaryStream(long pos, long length)返回一个包含部分 Blob 值的 InputStream 对象,它从 pos 指定的字节开始,具有 length 个字节长度。 |
byte[] |
getBytes(long pos, int length)将指定的字节数(从给定位置开始)从此 SerialBlob 对象复制到另一个字节数组。 |
long |
length()获取此 SerialBlob 对象字节数组中的字节数。 |
long |
position(Blob pattern, long start)返回此 SerialBlob 对象中给定 Blob 对象开始的位置,搜索从指定位置开始。 |
long |
position(byte[] pattern, long start)返回在此 SerialBlob 对象中给定模式的字节开始的位置,搜索从指定的位置开始。 |
OutputStream |
setBinaryStream(long pos)获取用于写入此 Blob 对象所表示的 BLOB 值的流。 |
int |
setBytes(long pos, byte[] bytes)将给定字节数组写入此 Blob 对象表示的 BLOB 值(从位置 pos 处开始),并返回写入的字节数。 |
int |
setBytes(long pos, byte[] bytes, int offset, int length)将所有或部分给定的 byte 数组写入此 Blob 对象表示的 BLOB 值中,并返回写入的字节数。 |
void |
truncate(long length)截取此 Blob 对象表示的 BLOB 值,使其长度为 len 个字节。 |
SerialBlob
public SerialBlob(byte[] b)
throws SerialException,
SQLException
- 按照给定
byte数组的序列化形式构造一个SerialBlob对象。新的
SerialBlob对象使用byte数组中的数据进行初始化,因此允许未连接RowSet对象无需接触数据源即可建立序列化的Blob对象。- 参数:
b- 一个byte数组,包含要序列化的Blob对象的数据- 抛出:
SerialException- 如果在序列化期间发生错误SQLException- 如果发生 SQL 错误
SerialBlob
public SerialBlob(Blob blob) throws SerialException, SQLException
- 根据给定
Blob对象的序列化形式构造一个SerialBlob对象。新的
SerialBlob对象使用Blob对象中的数据进行初始化;因此,Blob对象应该预先从数据库将 SQLBLOB值的数据置于客户端上。否则,新SerialBlob对象将不包含任何数据。- 参数:
blob- 一个Blob对象,根据该对象构造此SerialBlob对象 ;此值不能为 null。- 抛出:
SerialException- 如果在序列化期间发生错误SQLException- 如果传递给此构造方法的Blob为null。- 另请参见:
Blob
getBytes
public byte[] getBytes(long pos,
int length)
throws SerialException
- 将指定的字节数(从给定位置开始)从此
SerialBlob对象复制到另一个字节数组。注意,如果要复制的给定字节数大于此
SerialBlob对象的字节数组的长度,则将其缩短为该数组的长度。 - 参数:
pos- 此SerialBlob对象中要复制的第一个字节的顺序位置;编号从1开始;不得小于1并且必须小于或等于此SerialBlob对象的长度length- 要复制的字节数- 返回:
- 一个字节数组,它是此
SerialBlob对象一个区域的副本,从给定位置开始并且包含给定的连续字节数 - 抛出:
SerialException- 如果给定开始位置超出限制- 另请参见:
Blob.setBytes(long, byte[])
详细见:https://www.oschina.net/uploads/doc/javase-6-doc-api-zh_CN/javax/sql/rowset/serial/SerialBlob.html
浙公网安备 33010602011771号