How to have a default database


SDK Version: 
M3

If you want to include a database with initial data in your apk, you have to insert the database file into the projects assets folder, then programmatically check if the database, and if it does not exists copy the one from the assets.

You will need a function to check if the database exists, fox example:

  1. private static final String DATABASE_NAME = "testdatabase";
  2. private static final String DB_PATH = "/data/data/"+mContext.getPackageName()+"/databases/";
  3.  
  4. private boolean isDataBaseExist() {
  5.         File dbFile = new File(DB_PATH+DATABASE_NAME);
  6.         return dbFile.exists();
  7. }

If the check shows that the the database does not exist, a function like this will copy it:

  1. private void copyDataBase() throws IOException {
  2.         // Open your local db as the input stream
  3.         InputStream myInput = mContext.getAssets().open("databases/"+DATABASE_NAME);
  4.         // Path to the just created empty db
  5.         String outFileName = DB_PATH + DATABASE_NAME;
  6.         OutputStream myOutput = new FileOutputStream(outFileName);
  7.         // transfer bytes from the inputfile to the outputfile
  8.         byte[] buffer = new byte[1024];
  9.         int length;
  10.         while ((length = myInput.read(buffer)) > 0) {
  11.                 myOutput.write(buffer, 0, length);
  12.         }
  13.         // Close the streams
  14.         myOutput.flush();
  15.         myOutput.close();
  16.         myInput.close();
  17. }

I usually use SQLiteOpenHelper, so I add the methods above to the SQLiteOpenHelper class, and use the following code to open the database:

  1. try{
  2.         mDbHelper = new DatabaseHelper(mContext);
  3.         boolean isExist = mDbHelper.isDataBaseExist();
  4.         if(!mDbHelper.isDataBaseExist()){
  5.                 //get database, we will override it in next steep
  6.                 //but folders containing the database are created
  7.                 mDb = mDbHelper.getWritableDatabase();
  8.                 mDb.close();
  9.                 //copy database
  10.                 mDbHelper.copyDataBase();                              
  11.         }                                              
  12.         mDb = mDbHelper.getWritableDatabase();
  13. }catch(SQLException eSQL){
  14.         Log.e("log_tag","Can not open database");
  15. }
  16. catch (IOException IOe) {
  17.         Log.e("log_tag","Can not copy initial database");
  18. }

As you can see each method handles the database as a general file, so it can be used for any file you want to have a default "value" in your application.

Comments

Wirklich ein sehr interessanter und kritischer Blog, der immer wieder aktuelle Themen. Handy-Netz24 | alte handys | Super Preiswertes Smartphone

Market understands very well what their consumer wants. So, they are busied in doing best for their consumers. Used BMW Cars Some well known companies of digital camera industry have great how know about their customers. Canon is one from the best companies in cameras market. Previously, they have satisfied many of their consumers by powerful inventions in cameras industry. Used Daihatsu Cars Today, I am reviewing Canon’s best product PowerShot SX130 IS exclusively for you. Used Audi Cars for Sale

Peltiseppä Good day, Can I export your post picture and apply that on my personal blogging site?

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 beauty videos

ur Pretty good post. I just stumbled upon your blog and wanted to say that I have really enjoyed reading your blog posts. Any way I'll be subscribing to your feed and I hope you post again soon.
skincare reviews

u guess I will have to continue studying yours and pray that someday I will write on a subject with as a lot wisdom as you have! Bravo! skin care products

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.sales tax compliance

All the contents you mentioned in post is too good and can be very useful. I will keep it in mind, thanks for sharing the information. Keep updating, looking forward for more posts. Thanks sales tax consulting

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?
sales tax audit

I am very enjoyed for this side. Its a nice topic. It help me very much to solve some problems. Its opportunity are so fantastic and working style so speedy. I think it may be help all of you. Thanks, sales tax filing

I certainly enjoyed the way you explore your experience and knowledge of the subject! Keep up on it. Thanks for sharing the info How to grow taller

I really like the fresh perpective you did on the issue. Really was not expecting that when I started off studying. Your concepts were easy to understand that I wondered why I never looked at it before. Glad to know that there's an individual out there that definitely understands what he's discussing. Great job Christmas Lights

OMG! I have to say, your blog needs to be one of the best written blogs that I have learn in a protracted time.What I wouldn't give as a way to put up posts which might be as interesting| as yours. dressing gowns

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. Handyman Business

All the contents you mentioned in post is too good and can be very useful. I will keep it in mind, thanks for sharing the information. Keep updating, looking forward for more posts. Thanks. Start a Handyman Business

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?
Mountain Lakes Handyman

I am very enjoyed for this side. Its a nice topic. It help me very much to solve some problems. Its opportunity are so fantastic and working style so speedy. I think it may be help all of you. Thanks, Rockaway Handyman

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
San Diego Handyman

Happy to see your blog as it is just what I’ve looking for and excited to read all the posts. I am looking forward to another great article from you.
Temecula Handyman

I have to say, your blog needs to be one of the best written blogs that I have learn in a protracted time.What I wouldn't give as a way to put up posts which might be as interesting| as yours. Rancho Cucamonga Handyman

I really like the fresh perpective you did on the issue. Really was not expecting that when I started off studying. Your concepts were easy to understand that I wondered why I never looked at it before. Glad to know that there's an individual out there that definitely understands what he's discussing. Great job Palm Springs Handyman

I certainly enjoyed the way you explore your experience and knowledge of the subject! Keep up on it. Thanks for sharing the info Palm Desert Handyman

certainly enjoyed the way you explore your experience and knowledge of the subject! Keep up on it. Thanks for sharing the info
deck waterproofing

I am impressed by the way you covered this topic. It is not often I come across a blog with captivating articles like yours. I will note your feed to keep up to date with your approaching updates.Just striking and do uphold up the good work.
Moreno Valley Handyman

You are focused on realizing all you possibly can about this. We're completely satisfied you discovered us. On this site, we have introduced collectively an unlimited array of data and sources on this.

Mens Trench coat

blog as it is just what I’ve looking for and excited to read all the posts. I am looking forward to another great article from you.

Patio Furniture Clearance

Grard Boutin semble satisfait de son dernier investissement et ces businessmen du soleil ne semblent plus craindre le rchauffement climatique tant que le soleil brillera sur leurs toitures. Most Popular Articles

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

Hey--I just wanted to say hi and tell you how wonderful I think your blog is. I am a latecomer, unfortunately--but I will keep a close eye on it, now that I have found it. Take care, and thanks for all of the awesome information!

joann fabrics printable coupons

blog as it is just what I’ve looking for and excited to read all the posts. I am looking forward to another great article from you.

One Shoulder Dress

Your blog is a great one. What really impresses me is that you are correctly mentioned that there are thousands of tools that are available to create a website or launch one but what matters is that you choose the right one, the one that gives you all that is actually needed
Austin Home Search

Very interesting articles. Great job done
batik fabric

I came to your article from another article and am really interested in this learning about this. , I feel strongly about information and love learning more on this. If possible, as you gain expertise, It is extremely helpful for me. would you mind updating your blog with more information?

towing Service rochester ny
towing rochester ny

I came to your article from another article and am really interested in this learning about this. , I feel strongly about information and love learning more on this. If possible, as you gain expertise, It is extremely helpful for me. would you mind updating your blog with more information?

presentation folders
custom pocket folders

It such a great list. You have done really a great job to collect all that stuff. Thanks for it.

hack facebook account

A default database is a very useful thing. By the help of it we can solve many difficult internet browsing problems. Thanks for illustrating the commands. Without illustration it’s really tough to understand.austin tattoo removal

i Just Found You Site is Beautiful with a lot of good Information :)

psn code generator

Thanks for sharing. i really appreciate it that you shared with us such a informative post. Car Loan

you’ve always shared with us. Just keep writing this kind of posts.The time which was wasted in traveling for tuition now it can be used for studies.Thanks

gerda spillmann coupon code

Nice post man. Thanks a lot for the kind of perfect topic I have not a lot of information about it but I have got an extra unique info in your unique post. I also like posting comments because helps build community.

gerda spillman cosmetics

You also know how to make people rally behind it, obviously from the responses taking time and real effort to make a good article !!

Blackout Curtains

Thanks for informative and helpful post, obviously in your blog everything is good.If you post informative comments on blogs there is always the chance that actual humans will click through.

Patio Furniture Clearance

Computers for Sale So, they are plug n play devices for all operating systems (Except windows 98 and previous) with USB function. Mp3 player requires simple medium of transfer files like copy and paste but some required computer software. A backward function, they have very slow speed of file transfer as compared to USB flash drives.Electronics for Sale

Your information is very current and modern, thanks for the information in your article. Garajes de Madera

I thank you for the information you provided in your blog, you have very interesting topics. Energia Solar

Nice article and I agree with almost everything, but I think you create a new problem, where people are forced to make their point in the first three lines or 140 characters which isn't necessarily a good thing.

Help Wedding Planning