mysql 存blob_mysql 存入 blob类型数据

mysql 存blob_mysql 存入 blob类型数据mysql 存入 blob 类型数据最佳解决方案如果是字符串的 blob 在 bean 中把该字段设置成 byte 即可 遇到汉字不会乱码如果是文件可以采用下面方法 方案一把 String 类型转为 Blob 类型很简单 只要将 newSerialBlo String 对象的 getBytes 就可以获得一个 Blob 对象 要是把 Blob 对象转为 String 一种是 newStr

mysql 存入 blob类型数据

最佳 解决方案

如果是字符串 的 blob  , 在 bean 中 把 该字段 设置成 byte[]  即可,遇到汉字 不会乱码

如果是文件 可以采用下面方法。

方案一

把String类型转为Blob类型很简单,只要将 newSerialBlob(String对象的.getBytes())就可以获得一个Blob对象,

要是把Blob对象转为String 一种是new String(Blob.getBytes(0,Blob对象.length)) 可是在开发中这样是不行了,总提示一个错误,只有获得Blob对象的输入流才可以

IntputStream is = Blob对象.getBinaryStream()在用该对的read()方法读取一个字节数组在转换为String

方案二

1、在类中定义大字段:

Java代码  fbb5fe116c7b0d50bbfb392f61d635e6.png

public class informAffiche {

private Blob content;

public void setcontent(Blob S_content)

{

content=S_content;

}

public Blob getcontent()

{

return content;

}

}

2、数据库中读取大字段内容并set进去:

Java代码  fbb5fe116c7b0d50bbfb392f61d635e6.png

while(rs.next())

{

s.setcontent(rs.getBlob(“content”));

}

3、在页面得到

Java代码  fbb5fe116c7b0d50bbfb392f61d635e6.png

if (list.size()>0){

s=(informAffiche)list.get(0);

Blob blob= s.getcontent();

if(blob == null || blob.length()==0){

content = “”;

}else{

content = new String(blob.getBytes((long)1, (int)blob.length()));

System.out.println(“content—->”+content);

}

}

4、页面输出:

方案三

package org.util;

import java.io.BufferedInputStream;

import java.io.BufferedOutputStream;

import java.io.File;

import java.io.FileInputStream;

import java.io.FileNotFoundException;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.InputStream;

import java.io.InputStreamReader;

import java.io.OutputStream;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.SQLException;

public class BlobTest {

/

* @param args

* @throws SQLException

* @throws IOException

*/

public static void main(String[] args) throws SQLException, IOException {

// TODO Auto-generated method stub

//create();

read(2);

}

//将二进制流存储入数据库blob字段类型。

public static void create() throws SQLException, IOException{

String sql = “insert into blob_test values(id,?)”;

Connection conn = null;

PreparedStatement ps = null;

try{

conn = JdbcUtil.getInstance().getConnection();

ps = conn.prepareStatement(sql);

File file = new File(“input_text_right.gif”);

BufferedInputStream in = new BufferedInputStream(new FileInputStream(file));

ps.setBlob(1, in);

int id = ps.executeUpdate();

System.out.println(“id:”+id);

in.close();

}finally{

JdbcUtil.free(null, ps, conn);

}

}

//读取二进制流,并写入新的文件

public static void read(int id) throws SQLException, IOException{

String sql = “select big_bit from blob_test where id=? limit 1”;

Connection conn = null;

PreparedStatement ps = null;

ResultSet rs = null;

try{

conn = JdbcUtil.getInstance().getConnection();

ps = conn.prepareStatement(sql);

ps.setInt(1, id);

rs = ps.executeQuery();

byte[] b = new byte[1024];

while(rs.next()){

InputStream in = rs.getBinaryStream(1);//InputStream是字节输入流的所有类的超类

File file = new File(“left.gif”);

BufferedOutputStream out = new BufferedOutputStream(new FileOutputStream(file));//BufferedOutputStream是缓冲的输出流

for(int i=0; (i=in.read(b))>0;){//read方法接收byte数组,并将数据存储在缓冲数组b中

out.write(b);//将指定的字节写入此缓冲的输出流。

}

out.close();//关闭此输出流并释放与此流有关的所有系统资源。

}

}finally{

JdbcUtil.free(rs, ps, conn);

}

}

}

public class PostJdbcDao extends JdbcDaoSupport implements PostDao {

private LobHandler lobHandler;

private DataFieldMaxValueIncrementer incre;

public LobHandler getLobHandler() {

return lobHandler;

}

public void setLobHandler(LobHandler lobHandler) {

this.lobHandler = lobHandler;

}

public void addPost(final Post post) {

String sql = ” INSERT INTO t_post(post_id,user_id,post_text,post_attach)”

+ ” VALUES(?,?,?,?)”;

getJdbcTemplate().execute(

sql,

new AbstractLobCreatingPreparedStatementCallback(

this.lobHandler) {

protected void setValues(PreparedStatement ps,

LobCreator lobCreator) throws SQLException {

ps.setInt(1, incre.nextIntValue());

ps.setInt(2, post.getUserId());

lobCreator.setClobAsString(ps, 3, post.getPostText());

lobCreator.setBlobAsBytes(ps, 4, post.getPostAttach());

}

});

}

}

方案四

class=”org.springframework.jdbc.support.nativejdbc.CommonsDbcpNativeJdbcExtractor”

lazy-init=”true” />

class=”org.springframework.jdbc.support.lob.OracleLobHandler”

lazy-init=”true”>

class=”com.baobaotao.dao.jdbc.PostJdbcDao”>

Oracle 10g或其他数据库如下设置:

class=”org.springframework.jdbc.support.lob.DefaultLobHandler”

lazy-init=”true” />

class=”com.baobaotao.dao.jdbc.PostJdbcDao”>

public List getAttachs(final int userId){

String sql = “SELECT post_id,post_attach FROM t_post where user_id =? and post_attach is not null”;

return getJdbcTemplate().query(

sql,new Object[] {userId},

new RowMapper() {

public Object mapRow(ResultSet rs, int rowNum) throws SQLException {

Post post = new Post();

int postId = rs.getInt(1);

byte[] attach = lobHandler.getBlobAsBytes(rs, 2);

post.setPostId(postId);

post.setPostAttach(attach);

return post;

}

});

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/229794.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月16日 下午3:51
下一篇 2026年3月16日 下午3:52


相关推荐

  • eclipse的svn使用教程_eclipse svn插件安装

    eclipse的svn使用教程_eclipse svn插件安装  SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于RCS、CVS,它采用了分支管理系统,它的设计目标就是取代CVS。互联网上很多版本控制服务已从CVS迁移到Subversion。说得简单一点SVN就是用于多个人共同开发同一个项目,共用资源的目的。集中式代码管理的核心是服务器,所有开发者在开始新一天的工作之前必须从服务器获取代码,然后开发,最后解决冲突,提交。所有的版本信…

    2026年4月13日
    4
  • 网线RJ45接口针脚[通俗易懂]

    网线接头分两类:DTE:连接到网络中的终端设备,如连PC机网卡的网线DCE:网络设备间连接。如路由器接交换机,或交换机接交换机RJ45接头(水晶头)的接口定义有8个镀金接片的面向上,最左边是第1脚,最右边是第8脚:RJ45网线插头线序接网线有两种线序:T568A和T568B。交叉网线和直连网线直连网线的两端均按T568B连接,用于连接主机和设备,即DTE与DCE,如:电脑←—→ADSL猫、电脑←—→ADSL路由器的LAN口、电脑←—→集线器或交换机等。交叉网线的一端按T568B接,

    2022年4月15日
    53
  • unresolved external symbol怎么解决_fatal error lnk1169

    unresolved external symbol怎么解决_fatal error lnk11691.LNK2019错误一般都是compile是能找到相应的header(.h)文件,但链接时找不到相应的lib库文件(也含dll文件)。如果相关库存在的话,一般通过添加附加库,可以解决问题

    2022年10月5日
    3
  • 用python做学生信息管理系统_python管理系统实例

    用python做学生信息管理系统_python管理系统实例Python面向对象版学员管理系统文章目录Python面向对象版学员管理系统目标一.系统需求二.准备程序文件2.1分析2.2创建程序文件三.书写程序3.1student.py3.1.2程序代码3.2managerSystem.py3.2.1定义类3.2.2管理系统框架3.3main.py3.4定义系统功能函数3.4.1添加功能3.4.2删除学员3.4.3修改学员信息3.4.5查询学员信息3.4.6显示所有学员信息3.4.7保存学员信息3.4.8加载学员信息四.总结

    2026年1月31日
    5
  • linux iscsiadm_iscsi发起程序怎么用

    linux iscsiadm_iscsi发起程序怎么用ISCSIADMNAMEiscsiadm-open-iscsiadministrationutility  SYNOPSISiscsiadm -mdiscovery[-hV][-ddebug_level][-Pprintlevel][-Iiface-ttype-pip:port[-l]]|[-oope

    2022年8月23日
    9
  • Linux挂载磁盘分区「建议收藏」

    Linux挂载磁盘分区「建议收藏」Linux系统一般都会有未挂载的磁盘,如果我们想使用这些为挂载的磁盘就需要挂载到指定目录才能使用。一、有多个磁盘,将未分区的磁盘挂载1、进入root用户su–2、查看已挂载磁盘的使用情况:df–h可以看到系统已经挂载了sda磁盘,并分为sda1、sda2、sda3,3个分区3、查看所有磁盘信息(包括未挂载磁盘):fdisk–l4、创建新的磁盘…

    2022年6月19日
    56

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号