Extract Image from BLOB OBJ in Oracle database table

4 Ansichten (letzte 30 Tage)
Sean Lawson
Sean Lawson am 1 Sep. 2011
Kommentiert: Mustafa Zendaki am 16 Mär. 2021
Hi All,
I have a oracle database with tables in it. Some of the tables have fields of (BLOB), I know that these BLOBS contain pure jpeg image.
I can export the data in BLOB as matrices by MATLAB, these matrices are all one column matrices as I expected. However, what I really need to do is to have the .jpg image output. Does anyone have any idea how I could do this in MATLAB?
  1 Kommentar
Mustafa Zendaki
Mustafa Zendaki am 16 Mär. 2021
can you please share the code of how you exported he blob into matlab, i would really appreciate it

Melden Sie sich an, um zu kommentieren.

Antworten (2)

Walter Roberson
Walter Roberson am 1 Sep. 2011
If you want to display the image, you will have to write it to a file and use imread() .
There might be an undocumented method, or perhaps a JAVA method, of converting the byte stream in to an image array, but there is no documented MATLAB routine for doing this.
  1 Kommentar
Sean Lawson
Sean Lawson am 1 Sep. 2011
Thank you.
I do know there are some approaches in .NET, or SQL for example. But I am not sure that if matlab could do this, I do try to find some hints online but there's little. Could you tell me a little bit more?

Melden Sie sich an, um zu kommentieren.


Aleksy Barski
Aleksy Barski am 6 Apr. 2018
Bearbeitet: Aleksy Barski am 6 Apr. 2018
function [ image ] = deserializeImage( blob )
obj = blob{1,1};
is = obj.getBinaryStream();
bufferedImage = javax.imageio.ImageIO.read(is);
H = bufferedImage.getHeight;
W = bufferedImage.getWidth;
B = uint8(zeros([H,W,3]));
pixelsData = uint8(bufferedImage.getData.getPixels(0,0,W,H,[]));
for i = 1 : H
base = (i-1)*W*3+1;
B(i,1:W,:) = deal(reshape(pixelsData(base:(base+3*W-1)),3,W)');
end
image = B;
clear bufferedImage;
clear is;
end

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by