转: Java+Access存取图片

1.将图片存入数据库
 try
  { 
     File f=new File(photopath);//photopath为图片的路径
     FileInputStream fis=new FileInputStream(f);
     sqlcommand="insert into Directory values('"+name+"','"+na+"','"+tp+"','";
     sqlcommand+= mp+"',"+groupid+",?,'"+rm+"')";
     ps=mycon.con.prepareStatement(sqlcommand);
     ps.setBinaryStream(1,fis,(int)f.length());
     ps.executeUpdate();
     JOptionPane.showMessageDialog(null,"联系人["+name+"]添加成功!","提示",JOptionPane.PLAIN_MESSAGE);
     flag=true;
   }
   catch(FileNotFoundException fnfe)
    {
      JOptionPane.showMessageDialog(null,fnfe.getMessage(),"异常",JOptionPane.ERROR_MESSAGE);
    }
   catch(IOException ioe)
    {    
     JOptionPane.showMessageDialog(null,ioe.getMessage(),"异常",JOptionPane.ERROR_MESSAGE);
    }

2.从数据库中读出图片
try
 {
   MyCon mycon=new MyCon();
   Statement stmt=mycon.con.createStatement();
   String querycommand="SELECT * FROM Directory, User_Group WHERE ";
   querycommand+="Directory.GroupId=User_Group.Group_ID And Name='"+name+"'";
   ResultSet rs=stmt.executeQuery(querycommand);
   while(rs.next())
    {
      byte b[] = new byte[10*1024];
      int c=0;
      try
       {
         File f = new File("Icon//demo.jpg");//先指定一临时图片,存放从数据库中读出的图片
         FileOutputStream fos = new FileOutputStream(f);
         InputStream is = rs.getBinaryStream("Photo");
         while ((c=is.read(b))!=-1)
          {
           fos.write(b, 0, c);
          }
         fos.flush();
         fos.close();
         is.close();
        }//try
       catch(FileNotFoundException enfe) { }
       catch(IOException ioe)  { }
       jbphoto.setIcon(new ImageIcon(b));//将读出的图片设置为按钮的图标
     }//while
     stmt.close();
     mycon.con.close();
   }//try
   catch(SQLException sqle)  { }
 



本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/zhangyang0402/archive/2007/06/30/1672965.aspx

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值