当前位置: 首页 > news >正文

seo优化网站建设静态宠物网站设计论文

seo优化网站建设,静态宠物网站设计论文,中国国家培训网,宣传片制作公司推荐目录 一、 MySql Blob类型简介 1. Mysql中的Blob类型 2. Blob类型使用的注意事项 二. 插入Blob类型数据 1. 创建表 2. 通过PreparedStatement存储Blob类型数据 三. 解除文件大小限制 四、 读取Blob类型数据 前言 本文来讲解JDBC中的Blob类型 个人主页:艺杯羹…

目录

一、 MySql Blob类型简介

1. Mysql中的Blob类型

2. Blob类型使用的注意事项

二. 插入Blob类型数据

1. 创建表

2. 通过PreparedStatement存储Blob类型数据

三. 解除文件大小限制

四、 读取Blob类型数据


前言

本文来讲解JDBC中的Blob类型

个人主页:艺杯羹

系列专栏:JDBC

一、 MySql Blob类型简介

Blob(全称:Binary Large Object 二进制大对象)。在MySql中,Blob是一个二进制的用来存储图片,文件等数据的数据类型。操作Blob类型的数据必须使用PreparedStatement
因为Blob类型的数据无法使用字符串拼接。大多数情况,并不推荐直接把文件存放在 MySQL 数据库中
但如果应用场景是文件与数据高度耦合,或者对文件安全性要求较高的,那么将文件与数据存放在一起,即安全,又方便备份和迁移。
会占用存储数据文件的空间,所以不常用

1. Mysql中的Blob类型

MySql中有四种Blob类型,它们除了在存储的最大容量上不同,其他是一致的

类型

大小

TinyBlob

最大255字节

Blob

最大65K

MediumBlob

最大16M

LongBlob

最大4G

2. Blob类型使用的注意事项

  • 实际使用中根据需要存入的数据大小定义不同的Blob类型。
  • 如果存储的文件过大,数据库的性能会下降。

结合文件的综合来考虑

二. 插入Blob类型数据

1. 创建表

create table `movie` (`movieid` int(11) not null auto_increment,`moviename` varchar(30) default null,`poster` mediumblob,primary key (`movieid`)
) engine=innodb default charset=utf8;

2. 通过PreparedStatement存储Blob类型数据

上面介绍过了,操作Blob类型的数据必须使用PreparedStatement,所以这里用PreparedStatement来实现

public class BlobTest {// 向Movie表中插入数据public void insertMovie(String moviename, InputStream is){// 声明数据库连接对象,用于与数据库建立连接Connection conn = null;// 声明预编译语句对象,用于执行 SQL 语句PreparedStatement ps = null;try{// 获取连接// 调用 JdbcUtils 工具类的 getConnection 方法获取数据库连接conn = JdbcUtils.getConnection();// 创建PreparedStatement对象// 使用预编译的方式创建 SQL 插入语句,避免 SQL 注入风险ps = conn.prepareStatement("insert into movie values(default,?,?)");// 绑定参数// 为 SQL 语句中的第一个占位符绑定电影名称参数ps.setString(1,moviename);// 为 SQL 语句中的第二个占位符绑定输入流参数,用于插入二进制数据(如图片)ps.setBlob(2,is);// 执行SQL// 执行插入操作,并返回受影响的行数ps.executeUpdate();}catch(Exception e){// 若发生异常,打印异常堆栈信息,方便调试e.printStackTrace();}finally{// 调用 JdbcUtils 工具类的 closeResource 方法关闭预编译语句和数据库连接,释放资源JdbcUtils.closeResource(ps,conn);}}public static void main(String[] args) throws FileNotFoundException {// 创建 BlobTest 类的实例对象BlobTest bt = new BlobTest();// 创建读取文件的IO流// 创建一个文件输入流,用于读取指定路径下的图片文件InputStream is = new FileInputStream(new File("d:/1.jpg"));// 调用 insertMovie 方法,插入电影名称和图片数据到数据库bt.insertMovie("战狼",is);}
}

三. 解除文件大小限制

虽然MediumBlob允许保存最大值为16M,但MySql中默认支持的容量为4194304即4M。我们可以通过修改Mysql的my.ini文件中max_allowed_packet属性扩大支持的容量,修改完毕后需要重启MySql服务

文件位置
C:\ProgramData\MySQL……


右击使用记事本打开
再使用 快捷键 ctrl + F 输入:max_allowed_packet
来快速定位到这里

这里可以看到,默认是4M的,因此修改这里即可

四、 读取Blob类型数据

 public void selectMovieById(int movieid){// 声明数据库连接对象,用于与数据库建立连接Connection conn =null;// 声明预编译语句对象,用于执行 SQL 语句PreparedStatement ps = null;// 声明结果集对象,用于存储查询结果ResultSet rs = null;try{// 获取连接conn =JdbcUtils.getConnection();// 创建PreparedStatement对象ps = conn.prepareStatement("select * from movie where movieid = ?");// 绑定参数// 为 SQL 语句中的第一个占位符绑定影片 ID 参数ps.setInt(1,movieid);// 执行sql// 执行查询操作,将查询结果存储在 ResultSet 对象中rs = ps.executeQuery();// 遍历结果集while(rs.next()){// 从结果集中获取 movieid 列的值并赋值给变量 idint id = rs.getInt("movieid");// 从结果集中获取 moviename 列的值并赋值给变量 nameString name = rs.getString("moviename");// 打印影片 ID 和影片名称System.out.println(id+" "+name);//获取blob类型的数据// 从结果集中获取 poster 列的 Blob 类型数据Blob blob = rs.getBlob("poster");//获取能够从Blob类型的列中读取数据的IO流// 从 Blob 对象中获取二进制输入流,用于读取图片数据InputStream is = blob.getBinaryStream();// 创建文件输出字节流对象// 创建一个文件输出流,用于将图片数据写入到本地文件OutputStream os = new FileOutputStream(id+"_"+name+".jpg");//操作流完成文件的输出处理// 定义一个字节数组作为缓冲区,用于存储从输入流读取的数据byte[] buff = new byte[1024];// 用于存储每次从输入流读取的字节数int len;// 循环从输入流读取数据到缓冲区,直到读取完所有数据while((len = is.read(buff)) != -1){// 将缓冲区中的数据写入到输出流os.write(buff,0,len);}// 刷新输出流,确保所有数据都被写入到文件os.flush();// 关闭输入流,释放资源is.close();// 关闭输出流,释放资源os.close();}}catch(Exception e){// 若发生异常,打印异常堆栈信息,方便调试e.printStackTrace();}finally{// 调用 JdbcUtils 工具类的 closeResource 方法关闭结果集、预编译语句和数据库连接,释放资源JdbcUtils.closeResource(rs,ps,conn);}
}

到此,就讲解完了Blob类型的讲解,希望能够帮助到你😊

http://www.dtcms.com/a/491953.html

相关文章:

  • 网站建设公司销售招聘重庆seo入门教程
  • 地产金融网站开发租一个服务器要多少钱
  • RHCSA复习练习
  • YOLOv1 与 YOLOv2 核心技术总结
  • 怎么看一个网站什么语言做的如何做网络销售
  • 重庆建站佛山人才招聘网
  • Spring Boot开发最佳实践速览
  • C程序结构
  • 大型商城网站建设方案品牌网站建设小蝌蚪a
  • 【系统分析师】写作框架:软件系统测试及其应用
  • 壹搜网站建设优化排名做网站如何躲过网警
  • 南京协会网站建设怎么做彩票平台网站吗
  • 请人做网站收费多少设计工作室装修
  • 【图像大模型】ms-swift 深度解析:一站式多模态大模型微调与部署框架的全流程使用指南
  • 基于Java适配民营及公立一二级医院His系统,支持单体医院、集团化运营及区域医疗协同
  • Python3编程之python基础
  • YOLOv1 与 YOLOv2 学习总结
  • 进程优先级、环境变量、进程地址空间
  • d42:MyBatisPlus逻辑删除,枚举处理器,JSON处理器,分页插件
  • 安徽和县住房城乡建设局网站佛山电商网站制作团队
  • 网站备案 失败批量建wordpress
  • asp做的药店网站模板成都响应式网站建设
  • Python异步IO——协程
  • QML学习笔记(四十)QML的ApplicationWindow和StackView
  • Linux学习笔记--Pinctrl子系统示例
  • 安徽网站建设seo优化如何用asp做网站的登录界面
  • wordpress网站页脚网站进行中英文转换怎么做
  • RFSOC27DR+VU13P 6U VPX板卡
  • 多门店同城配送上新!Tigshop 开源商城系统JAVA5.4.0版本正式发布!
  • 域名访问过程会不会影响网站访问国外 设计师 网站