回答

收藏

getBytes vs getBinaryStream vs getBlob用于从BLOB列中获取数据

技术问答 技术问答 247 人阅读 | 0 人回复 | 2023-09-14

有3种不同的方法可以从BLOB列中获取数据ResultSet) |5 W* _$ k  U- z+ w, C
getBytes# Y' u) O5 y* H9 P& O
getBinaryStream. z/ O3 U) R. _8 P& w- Q7 k' k$ Z
getBlob5 k$ ]# P" y9 z

) k* a' m8 {) E1 ^* _% b# A此外,由Blob返回的对象getBlob还具有getBytes和getBinaryStream可用的方法。
& F- S" Y( x7 B4 s. w是否有任何我应该选择的特殊原因(性能,内存,数据库特定的问题)?, N7 `; X/ f8 p. e: U
该Blob对象还具有free()从JDBC 4.0开始引入的调用。这有什么区别吗?
7 Q/ Y& }0 u8 ]3 i9 d, T$ T8 o               
* I- g6 _6 D( {$ a; w解决方案:
2 Z# N6 F) |& {1 ^# f+ y               
7 J) Y6 e8 r& \6 x( A7 p# b* n$ h- u( z; _3 h4 {1 g/ W
! b8 S' e' @( s# k! e  Z8 j; ]( h
                如果您要提取大量数据(即,足够多的数据会导致内存问题),那么getBinaryStream将为您提供最大的灵活性,使您可以在读取数据时处理和丢弃数据。
0 R% x$ q  \5 F0 C3 K; o: Z另一方面,这可能会非常慢,具体取决于您的JDBC驱动程序,因为从流中进行的每次读取都可能导致数据库与网络进行大量的网络聊天。如果调用getBytes,则驱动程序会知道一次性获取全部内容,这可能会更有效率。5 p0 H4 ?- Y5 P& {# `
getBlob()向数据返回一个“指针”,您可以使用Blob接口上的方法对其进行操作。如果您需要修改数据或以其他方式欣赏原位数据,那么这可能是最适合您的。
分享到:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则