javafx将图像更新到mysql数据库

时间:2017-01-24 14:08:23

标签: java mysql jdbc javafx

我尝试在从数据库中读取图像后更新图像并抛出

java.lang.NullPointerException
SQL Error
    at java.io.FileInputStream.<init>(FileInputStream.java:130)
    at tprison.Tprison.lambda$startgu$21(Tprison.java:947)

如果我使用文件选择器选择图像,它会起作用,但是这样做可以在不改变人物图像的情况下更改人名或年龄。

我知道文件是空的,但是如果它有图像的话。

这是将图像保存在布局中的代码

browse = new JFXButton("browse");

    browse.setOnAction(e -> {

    fileg = filechooser.showOpenDialog(stageg);

    if(fileg != null){
        imageg = new Image(fileg.toURI().toString(),130,140,true,true);

         rectangleg = new Rectangle(130,140);
         rectangleg.setFill(new ImagePattern(imageg));

         rectangleg.setArcWidth(10);
         rectangleg.setArcHeight(10);

         bpgu.setTop(rectangleg);
         BorderPane.setAlignment(rectangleg, Pos.TOP_LEFT);
         bpgu.setMaxSize(130, 140);
         bpgu.setPrefSize(130, 140);
         bpgu.setVisible(true);

这是从数据库中检索图像并显示的代码。

InputStream is = rsgf.getBinaryStream("Pic");
         OutputStream os = new FileOutputStream( new File("photo.jpg"));



            byte[] content = new byte[1024];
            int size = 0;
            while((size = is.read(content)) != -1){
                os.write(content,0,size);
            }
            os.close();
            is.close();

            imageg = new Image("file:photo.jpg", 130, 140, true, true);
            rectangleg = new Rectangle(130,140);
            rectangleg.setFill(new ImagePattern(imageg));

            rectangleg.setArcWidth(10);
            rectangleg.setArcHeight(10);

            bpgu.setTop(rectangleg);
            BorderPane.setAlignment(rectangleg, Pos.TOP_LEFT);
            bpgu.setMaxSize(130, 140);
            bpgu.setPrefSize(130, 140);
            bpgu.setVisible(true);

最后这里是将图像更新到数据库的代码以及错误点(fileg为null)的位置。

 pica = new FileInputStream(fileg);
 pstgu.setBinaryStream(10,(InputStream)pica, (int)fileg.length());

1 个答案:

答案 0 :(得分:0)

更改此

fileg = new File("photo.jpg");
imageg = new Image(fileg.toURI().toString(), 130, 140, true, true);

到此完成工作

select PartNo, WODate
from   Inspection 
where  Convert(date,WODate,121) between '20170103'
       and '05-01-20170105'