Store images/files in database


SDK Version: 
M3

Hoever the practice is to store them normally and save the access route (Uri), sometimes it can be handy to store files/images completely in database.
In sqlite database there are only a few data types, so its easy to choose: files can be stored in a text as a ByteArray.

Lets see a sample code, where we download an image from the Internet then store it in the local database:

  1. //where we want to download it from
  2. URL url = new URL(IMAGE_URL);  //http://example.com/image.jpg
  3. //open the connection
  4. URLConnection ucon = url.openConnection();
  5. //buffer the download
  6. InputStream is = ucon.getInputStream();
  7. ByteArrayBuffer baf = new ByteArrayBuffer(128);
  8. //get the bytes one by one
  9. int current = 0;
  10. while ((current = bis.read()) != -1) {
  11.         baf.append((byte) current);
  12. }
  13.  
  14. //store the data as a ByteArray
  15. //db is a SQLiteDatabase object
  16. ContentValues dataToInsert = new ContentValues();                          
  17. dataToInsert.put(TABLE_FIELD,baf.toByteArray());
  18. db.insert(TABLE_NAME, null, dataToInsert);

And this is how you get the data back and convert it into a Bitmap:

  1. //select the data
  2. Cursor cursor = db.query(TABLE_STATIONLIST, new String[] {TABLE_FIELD},
  3.                                                 null, null, null, null, null);
  4. //get it as a ByteArray
  5. byte[] imageByteArray=cursor.getBlob(1);
  6. //the cursor is not needed anymore
  7. cursor.close();
  8.  
  9. //convert it back to an image
  10. ByteArrayInputStream imageStream = new ByteArrayInputStream(mybyte);
  11. Bitmap theImage = BitmapFactory.decodeStream(imageStream));

Storing a lot or big images in database is not recommended, but you can keep this solution in mind, there can be cases where this method can help you.

As the example shows in general it is possible to store anything in a database easily if you can convert it into a byte array.

If you're looking for the latest tips for your android phone, then check out the Dialaphone which always publishes the latest news from the mobile phone world. Click here for more information and to read their latest news, reviews and articles.

Comments

Very useful infor, can you let me know whether its possible to store very very big files like that too?

dekoracje domu wnętrz

Great information. I got lucky and found your site from a random Google search. Fortunately for me this topic just happens to be something that I've been trying to find more info on for research purpose. Keep us the great and thanks a lot. David Carraway // gratis webkatalog mit pagerank

Peltikatto hmmm so i stumbled upon your subject from other site that discussed this. Anyway, i spent the time to study your subject but i am somewhat confused Both way, you're a first rate writer and i wished to take the effort to put in writing thank you! I've saved your website for future referral.

hey buddy,this is one of the best posts that I’ve ever seen; you may include some more ideas in the same theme. I’m still waiting for some interesting thoughts from your side in your next post
makeup videos

Hey your collection is outstanding,I never see such a type of collection before.Thanks for sharing it with us.keep it up
skin care reviews

happy to see your article, I very much to like and agree with your point of view. Thank you for sharing.Welcome to look at my website and blog articles.Hope we can become good friends, and exchange and to help each other! Thanks!!
natural skin care

Thanks. That’s great info for a newbie like me. I even like how you segmented your blog clearly… I’m still trying to get mine that focused. I guess it’s all a work in progress. Darren Carrington // AAAFx Forex Broker

An impressive share I just given this onto a colleague who was doing a little analysis on this. And he in fact bought me breakfast because I found it for him.. smile. So let me reword that: Thnx for the treat! But yeah Thnkx... Dave Whiting // Eigene Model Homepage professionell

Thanks for this. Image files are pretty tricky to store in a database. I had some screenshots of how to buy and sell cars that I needed to store in a database and it took me about a couple weeks to figure out.

airstream
I recently came across your blog and have been reading along.I thought I would leave my first comment.I don't know what to say except that I have enjoyed reading. Nice blog. I will keep visiting this blog very often.

There must have been some kind of unclear criterias when they want to decide who are going to received the award thoug. Because I have been seeing many old names in the industry are stilll there. We need some new faces. google page rank

The site is currently undergoing more and more improvements in order to be able to cope with global requirements from their visitors. I think to have some commercial corner to sell/buy things could also something good in this tough. شات

Just want to say your article is stunning. The lucidity in your post is simply striking and i can assume you are an expert on this subject. Well with your permission allow me to grab your rss feed to keep up to date with incoming post. Thanks a million and please keep up the delightful work.
waterproof decking

Storing a lot or big images in database is not recommended, but you can keep this solution in mind, there can be cases where this method can help you.
learning guitar online

I do not know what the consideration of those who entrust their personal data online. Although they offer the security of super-sophisticated, but still I have more confidence when put in the personal property database. Swimming Pool enclosures

Google has been well known for their good quality software. This Google doc is something that will signify their quality even more. I believe this is just another great good story of their achievement. ICTMarktplaats.nl

Great post! And it's also true that it is more possible to store anything in a database if it is converted into a byte array! italian lottery

ready looking forward to who will be nominated for the Award this year. Nothing better than recognize the achievements of individuals and organizations working for the promotion of intercultural dialogueThis years award theme "Dialogue For Citizenship And Freedom" is a great choice spanish lottery and el gordo

Storing a lot or big images in database is not recommended, but you can keep this solution in mind, there can be cases where this method can help you. tatuaggi maori

I want to see what people are thinking when it comes for them to be able to act regarding to what they believe in. I need to see whether or not this is something we can share the importance with them. the very best low carb diet and weight control information

The best girls from around the world at your fingertips simply click and each of them can be yours. Each of them will do whatever you want to invite you from VisitX!

Many thanks for making the sincere effort to explain this. I feel fairly strong about it and would like to read more. If it's OK, as you find out more in depth knowledge, would you mind writing more posts similar to this one with more information?
free sounds

Well, bad for you lol. I use it in my mobile phone as a tool if I need to edit or create xls file while traveling. It is quite useful. Bible Study Lessons

Living in the current society is hard, but we enjoy the ups too. So sometimes getting up with a headache must be understood, lol. No problem at all. no win no fee

l will definitely bookmark this blog for future reference and further viewing. Thanks a bunch for sharing this with us! Mike Round //

acer aspire 5332

Storing a lot or big images in database is not recommended, but you can keep this solution in mind, there can be cases where this method can help you.
casse amplificate|casse attive

It is very light, just like it’s name, and also easy to use. That is main reason people love it. I think translator is just the same everywhere. Komodo Liveaboard

True. Once it is in your life, it will be hard to dismiss it. We can do literally a lot lot lot of things in the web. Unbelievable. It's like magic to the world. Elite Business Centers

I can just say good luck. It is unlikely to be in a more different case rather than what is anticipated. They should be able to handle it. Miami Tummy Tuck

It's valuable information and helpful Thank you for this add-on
العاب سيارات

Issues are very interesting and very useful, thank you for the information provided. Benicassim

Lets see a sample code, where we download an image from the Internet then store it in the local database.
General Finances

Hrmm that was weird my comment got eaten. Anyway I wanted to say that it's nice to know that someone else also mentioned this as I had trouble finding the same info elsewhere. This was the first place that told me the answer.euro millions

In sqlite database there are only a few data types, so its easy to choose: files can be stored in a text as a ByteArray.
Sign Companies

Woah esta é apenas uma quantidade insana de informação deve idades tomadas para compilar assim muito obrigado por apenas compartilhar com todos nós. Se a sua vez em qualquer necessidade de informação relacionada com talvez um pouco de técnicas de sedução coaching ou apenas dicas gerais basta verificar o meu próprio site! Ali Kundra // air conditioning repair Canada

There are many people searching about that now they will find enough resources by your post. T5 Adapter

The article is written in a very good manner.It help me in my college project.Thanks for sharing it.
Boats for Sale

Good post. Very impressive. Thanks for sharing.
wenger backpack

Good post. Very impressive. Thanks for sharing. android tablet

This is the type of information that should be shared around the web.

hand tools

If possible, as you gain expertise, would you mind updating your blog with more information? It is extremely helpful for me. Lappatrici usate

Clever work and reporting! Keep up the great works guys I've added you guys to my blogroll. This is a great article thanks for sharing this informative information.. I will visit your blog regularly for some latest post.thanks for sharing. kids clothing

Found your weblog by accident for the second time these days so I considered I would have a nearer appear. I've just started producing my own blog site and modeling it right after what you have done. I hope mine is going to be as profitable as yours. a math

I recently came across your blog and have been reading along. I thought I would leave my first comment. I don't know what to say except that I have enjoyed reading what you all have to say best underwater camera

I have to say this post was certainly informative and contains useful content for enthusiastic visitors. I will definitely bookmark this blog for future reference and further viewing. Thanks a bunch for sharing this with us! Mike Round // Free Online Games

modalert
Thanks for taking this opportunity to discuss this, I feel fervently about this and I like learning about this subject.