`
ldsjdy
  • 浏览: 147394 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

java+mysql存储图片或其它大对象到数据库时的两个问题

    博客分类:
  • Jdbc
阅读更多
1、当图片文件超过1M的时候,出错如下:

JDBC错误:Packet for query is too large (1298910 > 1048576). You can change this value on the server by setting the max_allowed_packet' variable.

这是因为mysql默认一个包最大1M,需要修改my.ini

max_allowed_packet = 10M
如文件大小为10的话 max_allowed_packet应该设为两倍以上,否则还是会出现上面的异常
修改方法:
1)my-large.ini 中将 max_allowed_packet = 1M(默认为1M)设置为max_allowed_packet = 10M
2)将max_allowed_packet = 10M复制到my.ini中的
[mysqld]

# The TCP/IP Port the MySQL Server will listen on
port=3306
max_allowed_packet = 10M

3)修改配置文件后要重启mysql服务

2、图片文件的写入时候遇到

com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException:You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near

以前可直接运行的程序,后来数据库换了就不能运行,上面的错误提示是参数类型不匹配,在网上查了一下,应该是数据库字符集的类型的问题(现在字符集是gbk),
将ps.setBinaryStream(2,inputStream,file.length());
改为ps.setBytes(2, buf);直接存byte就可以了,


sql="INSERT INTO blobtest(b_title,b_text)VALUES(?,?)";


ps.setString(1, file.getName());
//新建一byte数组
byte[] buf=new byte[inputStream.available()];
//将文件读入到byte[]中
inputStream.read(buf);
ps.setBytes(2, buf);
ps.executeUpdate();
分享到:
评论

相关推荐

    基于Vue+Java+MySQL的科技服务知识图谱构建与管理工具.zip

    本系统包含存储层、逻辑层和表示层,存储层采用文件 IO 管理图元的图片文件、采用 MySQL 数据库管理系统的用户信息、图谱的文件信息以及图元模板的文件信息,采用 Neo4j 数据库管 理图谱的实体信息和图谱的关系信息...

    java源码包---java 源码 大量 实例

     Java绘制图片火焰效果,源代码相关注释:前景和背景Image对象、Applet和绘制火焰的效果的Image对象、Applet和绘制火焰的效果的Graphics对象、火焰效果的线程、Applet的高度,图片到图片装载器、绘制火焰效果的X坐标...

    基于spring boot和微信小程序的图书销售系统源代码(毕业论文+程序设计源码+数据库文件).zip

    doc下的shop目录是数据库里存储的图片地址对应的文件,项目启动后在D盘找到/home目录(没有D盘的话找找其他盘符根目录下),整个拷贝进去 随着互联网技术的蓬勃发展,电子商务技术不断成熟,网上购物已经深入到我们...

    java源码包4

     Java绘制图片火焰效果,源代码相关注释:前景和背景Image对象、Applet和绘制火焰的效果的Image对象、Applet和绘制火焰的效果的Graphics对象、火焰效果的线程、Applet的高度,图片到图片装载器、绘制火焰效果的X坐标...

    java源码包3

     Java绘制图片火焰效果,源代码相关注释:前景和背景Image对象、Applet和绘制火焰的效果的Image对象、Applet和绘制火焰的效果的Graphics对象、火焰效果的线程、Applet的高度,图片到图片装载器、绘制火焰效果的X坐标...

    java源码包2

     Java绘制图片火焰效果,源代码相关注释:前景和背景Image对象、Applet和绘制火焰的效果的Image对象、Applet和绘制火焰的效果的Graphics对象、火焰效果的线程、Applet的高度,图片到图片装载器、绘制火焰效果的X坐标...

    JAVA上百实例源码以及开源项目源代码

     Java绘制图片火焰效果,源代码相关注释:前景和背景Image对象、Applet和绘制火焰的效果的Image对象、Applet和绘制火焰的效果的Graphics对象、火焰效果的线程、Applet的高度,图片到图片装载器、绘制火焰效果的X坐标...

    JAVA上百实例源码以及开源项目

     Java绘制图片火焰效果,源代码相关注释:前景和背景Image对象、Applet和绘制火焰的效果的Image对象、Applet和绘制火焰的效果的Graphics对象、火焰效果的线程、Applet的高度,图片到图片装载器、绘制火焰效果的X坐标...

    成百上千个Java 源码DEMO 4(1-4是独立压缩包)

    Java EJB中有、无状态SessionBean的两个例子 两个例子,无状态SessionBean可会话Bean必须实现SessionBean,获取系统属性,初始化JNDI,取得Home对象的引用,创建EJB对象,计算利息等;在有状态SessionBean中,用...

    JAVA毕业设计之基于springboot的的学生干部管理系统(springboot+mysql)完整源码.zip

    该系统采用了Java作为后端编程语言,使用Spring Boot框架进行快速开发,同时结合MySQL数据库进行数据存储。整个系统分为前端界面和后端接口两大部分,实现了学生干部信息的增删改查、活动记录的管理以及通讯录的查询...

    成百上千个Java 源码DEMO 3(1-4是独立压缩包)

    Java EJB中有、无状态SessionBean的两个例子 两个例子,无状态SessionBean可会话Bean必须实现SessionBean,获取系统属性,初始化JNDI,取得Home对象的引用,创建EJB对象,计算利息等;在有状态SessionBean中,用...

    Hellohao全网对象存储图床源码

    分发群组(配置用户群组,不同群组分发图片到不同对象存储) 首页背景动态/静态,以及简约模式设置 URL列表、缩略图。查看原图等功能。 图片鉴黄配置(开启后,每天固定时间进行非法图片监测) 游客、用户的上传...

    Hellohao全网对象存储图床源码.rar

    把Tbed.jar和application.properties放到服务器你想存放的目录比如/home,注意这两个文件必须要在同一目录下不能分开。 依次运行如下命令: cd /home java -jar Tbed.jar 启动项目 启动后访问地址为:...

    Java开发实战1200例(第1卷).(清华出版.李钟尉.陈丹丹).part3

    以开发人员在项目开发中经常遇到的问题和必须掌握的技术为中心,介绍了应用Java进行桌面程序开发各个方面的知识和技巧,主要包括Java语法与面向对象技术、Java高级应用、窗体与控件应用、文件操作典型应用和数据库...

    数据库总体设计报告.docx

    该软件用java语言编写,用MySQL数据库作为后台的数据库进行信息的存储,用MySQL语句完成学生信息的添加,查询,修改,删除的操作。用ODBC驱动实现前台Java与后台数据库的连接。同时本系统采用Java Swing编程,通过...

    Java毕业设计:基于SpringBoot+Vue的度假山庄酒店管理系统(源码+文档+录像演示).zip

    用户管理包括会员用户和管理员用户两个用户。设计一个用户数据表,使用权限字段进行区分。当前台会员进行注册的时候,权限设为会员。管理员用户权限设置为管理员。虽然数据存储在一个数据库表,但是在登录的时候使用...

Global site tag (gtag.js) - Google Analytics