Java学习之将图片文件保存到数据库
在学习编程的过程中,我觉得不止要获得课本的知识,更多的是通过学习技术知识提高解决问题的能力,这样我们才能走在最前方,本文主要讲述java编程中将图片文件保存到数据库,更多Java专业知识,广州疯狂java培训为你讲解;
其中定义了一个静态方法savePicture(),用于完成保存图片的功能。关键代码如下 public static boolean savePicture(Picture pict
实现过程
(1)在Eclipse中创建项目138,并在该项目创建com.mingrisoft 包。
(2)在com.mingrisoft包中创建类文件,名称为DBHelper,其中定义了一个静态方法savePicture(),用于完成保存图片的功能。关键代码如下
public static boolean savePicture(Picture picture) {
try {
Class.forName(DRIVER);//加载数据库驱动
} catch (ClassNotFoundException e) {
e.printStackTrace();
FilelnputStream in = null;
String sql = "insert into tb_picture (picturename, picturefile) values (?,?);"; //定义 SQL语句
Connection conn = null;
PreparedStatement ps = null;
try {
in = new FileInputStream(picture.getPictureFile());//获得文件输入流
conn = DriverManager.getCormection(URL,USERNAME, PASSWORD); //获得数据库连接
ps = conn.prepareStatement(sql); //获得预处理对象
ps.setString( 1,picture.getPictureName()); //设置文件名
ps.setBlob(2, in); //设置文件输入流
ps.execute(); //保存数据
return true;
} catch (SQLException e) {
e.printStackTrace();
} catch (FileNotFoundException e) {
e.printStackTrace();
} finally {
//省略释放资源代码
}
return false;
}
指点迷津:
由于篇幅限制,关于窗体以及JDBC的信息请参考源代码文件。
技术要点
在向MySQL中保存图片时,数据表中对应字段的类型应该是TINYBLOB、BLOE MEDIUMBLOB 或者 LONGBLOB 之一,然后使用 PrepareStatement 接口中定义的 setBlob()方法将文件流写入数据库
疯狂Java培训专注软件开发培训,提升学员就业能力,重点提升实践动手能力。没有工作经验的学员,在疯狂java,通过大量全真经典企业级项目进行集中培训,课上讲师讲解和课下项目练习课上课下双管齐下,学员通过数月培训都可获得1-2年的工作经验,进而在同类的求职者中脱颖而出。疯狂Java培训让你体会java编程的快乐,项目开发的兴奋,激情,通过短短几个月的时间,让你在半年的时间内掌握8-10万的代码量,掌握Java核心技术,迅速成为技能型的现代化高端人才,迅速获得高薪就业!