我尝试在从数据库中读取图像后更新图像并抛出
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());
答案 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'