mysql操作blob经验谈

a2009123410

a2009123410

2016-02-19 19:25

下面请跟着图老师小编一起来了解下mysql操作blob经验谈,精心挑选的内容希望大家喜欢,不要忘记点个赞哦!

  背景!jsp+mysql 记住 要用mysql的longblob类型来存默认的blob大小不够

  数据库字段:id (char) pic (longblob)

  转载请注明出处,这时我与我的知己的合作的结过

  原来操作blob字段时都要先差个空值,在查blob,好麻烦,用prepareStatment就不用那么麻烦了,哈哈

(本文来源于图老师网站,更多请访问https://m.tulaoshi.com/webkaifa/)

  postblob.heml页面

  !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
  html xmlns="http://www.w3.org/1999/xhtml"
  head
  meta http-equiv="Content-Type" content="text/html; charset=gb2312" /
  title无标题文档/title
  /head
  body
  form action="testblob.jsp" method="post"
  table width="291" border="1"
    tr
      td width="107"id /td
      td width="168"input name="id" type="text" //td
    /tr
    tr
      tdfile/td
      tdinput name="file" type="file" //td
    /tr
    tr
      tdinput  type="submit"  value="提交"//td
    
    /tr
  /table
  /form
  /body
  /html
  ***************************************************************

  testblob.jsp

  %@ page contentType="text/html;charset=gb2312"% 
  %@ page import="java.sql.*" %
  %@ page import="java.util.*"%
  %@ page import="java.text.*"%
  %@ page import="java.io.*"% 
  html xmlns="http://www.w3.org/1999/xhtml"
  head
  meta http-equiv="Content-Type" content="text/html; charset=gb2312" /
  title无标题文档/title
  /head
  body
  %
   String id=request.getParameter("id");
   String file=request.getParameter("file");
   out.print(id);
   out.print(file);
   FileInputStream str=new FileInputStream(file);
   out.print(str.available());
     java.sql.Connection conn;
     java.lang.String strConn;
     Class.forName("org.gjt.mm.mysql.Driver").newInstance();
     conn= java.sql.DriverManager.getConnection("jdbc:mysql://localhost/test","root","");
   String sql="insert into test(id,pic) values(?,?)";
   PreparedStatement pstmt=conn.prepareStatement(sql);
   pstmt.setString(1,id);
   pstmt.setBinaryStream(2,str,str.available());
  pstmt.execute();
  out.println("Success,You Have Insert an Image Successfully");
   pstmt.close();
  %
  a href="readblob.jsp"查看图片/a
  a href="postblob.html"返回/a
  /body
  /html

  ********************************************************

  readblob.jsp

  %@ page contentType="text/html;charset=gb2312"% 
  %@ page import="java.sql.*, javax.sql.*" %
  %@ page import="java.util.*"%
  %@ page import="java.text.*"%
  %@ page import="java.io.*"% 
  !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
  html xmlns="http://www.w3.org/1999/xhtml"
  head
  meta http-equiv="Content-Type" content="text/html; charset=gb2312" /
  title无标题文档/title
  /head

  body
  %
   
   java.sql.Connection conn;
   ResultSet rs=null;
    Class.forName("org.gjt.mm.mysql.Driver").newInstance();
     conn= java.sql.DriverManager.getConnection("jdbc:mysql://localhost/test","root","");
     Statement stmt=conn.createStatement();
     rs=stmt.executeQuery("select * from test where id='1'");
    if(rs.next())
    {
      Blob b = rs.getBlob("pic");
    
   int size =(int)b.length();
        out.print(size);
    InputStream in=b.getBinaryStream();
    byte[] by= new byte[size];
    response.setContentType("image/jpeg");
    ServletOutputStream sos = response.getOutputStream();
       int bytesRead = 0;
         while ((bytesRead = in.read(by)) != -1) {
               sos.write(by, 0, bytesRead);
            }
           in.close();
           sos.flush();
     
    }
   
   
  %
  /body
  /html
  ********************************************************************

(本文来源于图老师网站,更多请访问https://m.tulaoshi.com/webkaifa/)

  注意:在用sos.write(by, 0, bytesRead);时,该方法把inputstream中的内容在一个新的页面中输出,

  如果本页中还有别的内容要输出的话,只有把上述方法改为,bytesRead = in.read(by)) ;

  再用out.print(new String(by));方法输出结果,注意在这里不能用by.toString()方法,该方法返回的是要输出内容的内存地址。mysql中有blob textarea类型大小了66536基本上放点小的东东就足够了,哈哈,但是现在的数码pic越来越大就只能用longblob了 大小有4g能 ,放个电影都够了哈哈

展开更多 50%)
分享

猜你喜欢

mysql操作blob经验谈

Web开发
mysql操作blob经验谈

哺乳经验谈(上)

免疫力 育儿知识 怀孕 孕妇
哺乳经验谈(上)

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

Windows操作系统加速安装经验谈

windows 操作系统
Windows操作系统加速安装经验谈

验楼经验谈

生活常识
验楼经验谈

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

网页设计经验谈

Web开发
网页设计经验谈

Windows操作系统的加速安装经验谈

windows 操作系统
Windows操作系统的加速安装经验谈

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

妙用Replace函数替代字符串连接操作符

妙用Replace函数替代字符串连接操作符

一个可以发送附件及HTML格式邮件的PHP类

一个可以发送附件及HTML格式邮件的PHP类
下拉加载更多内容 ↓