关于Mysql数据库longblob格式数据的插入com.mysql.jdbc.PreparedStatement.setBinaryStream(ILjava/io/InputStream;J)V问题分析
当数据库字段为blob类型时 ,我们如果使用PreparedStatement中的setBinaryStream(int,InputStream,int)方法需要注意
  在向blob字段类型中插入数据时,要使用javaio的inputstream,读入文件。
  而相反从blob字段中读出数据时,同样使用javaio的inputstream,再用javaio的outputstream写入文件。
  同clob的示例中的问题
  如果在设置字节流的地方不加类型转换的话,如下:
  stat.setBinaryStream(1, in, file.length());
  则会出现如下错误
  Exception in thread "main" java.lang.AbstractMethodError: com.mysql.jdbc.PreparedStatement.setBinaryStream(ILjava/io/InputStream;J)V
    at test.jdbc.BlobRW.create(BlobRW.java:38)
    at test.jdbc.BlobRW.main(BlobRW.java:24)
  后来看了看java和mysql的jdbc驱动两方面的代码,原因明白,原来是用的jdk1.6的版本中,有长度为long类型的方法。
  而对应的mysql的jdbc驱动jar中,还没有实现。
  其进行类型转换后,即可正常运行。运行代码如下:
public void insertBlob() throws Exception {
		String strimg="E:/IBM/friend/src/abc.jpg";
		String strtext="E:/IBM/friend/src/abc.txt";
		String strarea="中国中国中国中国";
		conn = DBUtil.getConnection();
		String sql = "insert into userclob(id,name,photo,note) values(?,?,?,?)";
		this.pstm = conn.prepareStatement(sql);
		this.pstm.setInt(1, 2);
		this.pstm.setString(2, "中国2");
		File fileimg = new File(strimg);
		File filetext=new File(strtext);
		this.pstm.setString(3, strarea);
		this.pstm.setCharacterStream(4, new FileReader(fileimg),(int)fileimg.length());
		this.pstm.executeUpdate();
		this.pstm.close();
		conn.close();
	}
关于Mysql数据库longblob格式数据的插入com.mysql.jdbc.PreparedStatement.setBinaryStream(ILjava/io/InputStream;J)V问题分析的更多相关文章
- PHP批量替换MySql数据库中的数据内容(替换MySql数据库内容源码)
		
PHP批量替换MySql数据库内容 UTF-8 1.0版 <?php //声明 //1.本源码开发意图:作者在使用一些CMS建站的时候发现很多CMS把网址写入到数据库了,如果换网址,那么就需要更 ...
 - MySQL数据库表的数据插入、修改、删除、查询操作及实例应用
		
一.MySQL数据库表的数据插入.修改.删除和查询 CREATE DATABASE db0504; USE db0504; CREATE TABLE student ( sno ) NOT NULL ...
 - c#几种数据库的大数据批量插入(SqlServer、Oracle、SQLite和MySql)
		
这篇文章主要介绍了c#几种数据库的大数据批量插入(SqlServer.Oracle.SQLite和MySql),需要的朋友可以了解一下. 在之前只知道SqlServer支持数据批量插入,殊不知道Ora ...
 - EF 连接MySQL 数据库  保存中文数据后乱码问题
		
EF 连接MySQL 数据库 保存中文数据后乱码问题 采用Code First 生成的数据库,MySQL数据库中,生成的表的编码格式为***** 发现这个问题后,全部手动改成UTF8(图是另一个表的 ...
 - mysql数据库千万级别数据的查询优化和分页测试
		
原文地址:原创 mysql数据库千万级别数据的查询优化和分页测试作者:于堡舰 本文为本人最近利用几个小时才分析总结出的原创文章,希望大家转载,但是要注明出处 http://blog.sina.com. ...
 - 一、初识MySQL数据库 二、搭建MySQL数据库(重点) 三、使用MySQL数据库 四、认识MySQL数据库的数据类型 五、操作MySQL数据库的数据(重点)
		
一.初识MySQL数据库 ###<1>数据库概述 1. 数据库 长期存储在计算机内的,由组织的可共享的数据集合 存储数据的仓库 文件 ...
 - JDBC Java 程序从 MySQL 数据库中读取数据,并备份到 xml 文档中
		
MySQL 版本:Server version: 5.7.17-log MySQL Community Server (GPL) 相关内容:JDBC Java 程序从 MySQL 数据库中读取数据,并 ...
 - OpenLayers添加点【php请求MySQL数据库返回GeoJSON数据】
		
php请求MySQL数据库返回GeoJSON数据的实现方法请参见: http://www.cnblogs.com/marost/p/6234514.html OpenLayers[v3.19.1-di ...
 - JDBC连接mysql数据库,添加数据
		
如下:其中添加/删除/修改只是sql字符串不同 //3.要执行的字符串 String sql="INSERT INTO t_student(NAME,age,email) VALUES('x ...
 
随机推荐
- 大型高性能ASP.NET系统架构设计
			
大型动态应用系统平台主要是针对于大流量.高并发网站建立的底层系统架构.大型网站的运行需要一个可靠.安全.可扩展.易维护的应用系统平台做为支撑,以保证网站应用的平稳运行. 大型动态应用系统又可分为几个子 ...
 - spring+ibatis环境搭建
			
简单的spring+ibatis入门实例:ibatis是一种半自动化的持久层框架,它介于JDBC和hibernate之间,使用比较灵活. 一:目录结构 二:需要导入的jar包: 所有的第三方jar包都 ...
 - rownum与rowId
			
一.RowNum Rownum是oracle生成结果集时得到的一个伪列, 按照读出行的顺序, 第一条rownum=1, 第二条=2. 对于 Oracle 的 rownum 问题,很多资料都说不支持 ...
 - Android开发了解——AIDL
			
AIDL:Android Interface Definition Language,即Android接口定义语言. 什么是AIDL Android系统中的进程之间不能共享内存,因此,需要提供一些机制 ...
 - centos7下载安装谷歌浏览器
			
centos7安装完成结束后,发现自带的火狐浏览器不太习惯,自己还是习惯谷歌浏览器,因为是新手嘛,所以自己就各种找教程看如何下载安装谷歌浏览器,一个一个按照教程试验,终于最后试验成功了一个,亲测可用. ...
 - 世界上最方便的SharePoint移动客户端--Rshare
			
Rshare我试用了一段时间,同时也测试了其他家产品,使用后的感觉是Rshare无愧于世界上最方面的SharePoint移动客户端. 1.界面设计很方便,设计中充分考虑到移动客户的使用习惯及喜好,设计 ...
 - js限制文本框只能输入数字
			
JS判断只能是数字和小数点1.文本框只能输入数字代码(小数点也不能输入) <input onkeyup="this.value=this.value.replace(/\D/g,'') ...
 - GlusterFS集群文件系统概述
			
http://blog.csdn.net/zonelan/article/details/8468383 1. GlusterFS概述 GlusterFS是Scale-Out存储解决方案Gl ...
 - Latex之CJK中文书签乱码[转]
			
在使用CJK宏包编辑中文时,可以使用不同的编码方式,一种是UTF-8格式:另外一种是GBK编码.在使用GBK编码时,生成的PDF格式中的文本是GBK的编码方式,因此大部分不支持GBK编码的PDF阅读器 ...
 - xp 中的IIS安装成功之后,访问网页显示没有权限访问解决方法
			
在做xp的IIS发布网站时遇到一个问题就是当你访问网站的时候,显示没有权限访问网站,但是我已经开启了匿名访问网站了,怎么还没有权限访问呢?后来经过上网搜资料解决,当时很多网上都说没打开匿名访问,当时我 ...