Android Open Source - watchme Database Helper






From Project

Back to project page watchme.

License

The source code is released under:

Copyright (c) 2012 Johan Brook, Robin Andersson, Lisa Stenberg, Mattias Henriksson Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documen...

If you think the Android project watchme listed in this page is inappropriate, such as containing malicious code/tools or violating the copyright, please email info at java2s dot com, thanks.

Java Source Code

/**
 *  DatabaseHelper.java// w  w w .  j av a 2 s.c o  m
 *
 *  Manage Database creation and version managements. 
 *
 *  @author lisastenberg
 *  @copyright (c) 2012 Johan Brook, Robin Andersson, Lisa Stenberg, Mattias Henriksson
 *  @license MIT
 */

package se.chalmers.watchme.database;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

public class DatabaseHelper extends SQLiteOpenHelper {

  private static final int DATABASE_VERSION = 1;
  private static final String DATABASE_NAME = "watchme.db";

  private static final String TRIGGER_DETACH = "detach";
  private static final String TRIGGER_DETACH2 = "detach2";

  /**
   * When a Movie is deleted, the rows in the HasTag-table containing that
   * Movie should also be deleted.
   */
  private static final String CREATE_TRIGGER_DETACH = "CREATE TRIGGER "
      + TRIGGER_DETACH + " AFTER " + "DELETE ON "
      + MoviesTable.TABLE_MOVIES + " FOR EACH ROW BEGIN "
      + "DELETE FROM " + HasTagTable.TABLE_HAS_TAG + " WHERE "
      + HasTagTable.COLUMN_MOVIE_ID + " = old."
      + MoviesTable.COLUMN_MOVIE_ID + "; END;";

  /**
   * When a Tag is deleted, the rows in the HasTag-table containing that Tag
   * should also be deleted.
   */
  private static final String CREATE_TRIGGER_DETACH2 = "CREATE TRIGGER "
      + TRIGGER_DETACH2 + " AFTER " + "DELETE ON " + TagsTable.TABLE_TAGS
      + " FOR EACH ROW BEGIN " + "DELETE FROM "
      + HasTagTable.TABLE_HAS_TAG + " WHERE " + HasTagTable.COLUMN_TAG_ID
      + " = old." + TagsTable.COLUMN_TAG_ID + "; END;";

  public DatabaseHelper(Context context) {
    super(context, DATABASE_NAME, null, DATABASE_VERSION);
  }

  @Override
  public void onCreate(SQLiteDatabase db) {
    MoviesTable.onCreate(db);
    TagsTable.onCreate(db);
    HasTagTable.onCreate(db);

    db.execSQL(CREATE_TRIGGER_DETACH);
    db.execSQL(CREATE_TRIGGER_DETACH2);
  }

  @Override
  public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    MoviesTable.onUpgrade(db, oldVersion, newVersion);
    TagsTable.onUpgrade(db, oldVersion, newVersion);
    HasTagTable.onUpgrade(db, oldVersion, newVersion);

    db.execSQL("DROP TRIGGER IF EXISTS " + TRIGGER_DETACH);
    db.execSQL("DROP TRIGGER IF EXISTS " + TRIGGER_DETACH2);
    db.execSQL(CREATE_TRIGGER_DETACH);
    db.execSQL(CREATE_TRIGGER_DETACH2);
  }
}




Java Source Code List

se.chalmers.watchme.activity.AddMovieActivity.java
se.chalmers.watchme.activity.AutoCompleteAdapter.java
se.chalmers.watchme.activity.MainActivity.java
se.chalmers.watchme.activity.MovieDetailsActivity.java
se.chalmers.watchme.activity.SearchableActivity.java
se.chalmers.watchme.activity.TabsAdapter.java
se.chalmers.watchme.activity.TagMovieListActivity.java
se.chalmers.watchme.database.DatabaseAdapter.java
se.chalmers.watchme.database.DatabaseHelper.java
se.chalmers.watchme.database.GenericCursorLoader.java
se.chalmers.watchme.database.HasTagTable.java
se.chalmers.watchme.database.ICursorHelper.java
se.chalmers.watchme.database.MovieAlreadyExistsException.java
se.chalmers.watchme.database.MoviesTable.java
se.chalmers.watchme.database.TagsTable.java
se.chalmers.watchme.database.WatchMeContentProvider.java
se.chalmers.watchme.model.Movie.java
se.chalmers.watchme.model.Tag.java
se.chalmers.watchme.net.HttpRetriever.java
se.chalmers.watchme.net.IMDBHandler.java
se.chalmers.watchme.net.ImageDownloadTask.java
se.chalmers.watchme.net.MovieSource.java
se.chalmers.watchme.net.NoEntityException.java
se.chalmers.watchme.notifications.Notifiable.java
se.chalmers.watchme.notifications.NotificationClient.java
se.chalmers.watchme.notifications.NotificationService.java
se.chalmers.watchme.notifications.NotifyService.java
se.chalmers.watchme.ui.ContentListFragment.java
se.chalmers.watchme.ui.DatePickerFragment.java
se.chalmers.watchme.ui.ImageDialog.java
se.chalmers.watchme.ui.MovieListFragment.java
se.chalmers.watchme.ui.TagListFragment.java
se.chalmers.watchme.utils.DateTimeUtils.java
se.chalmers.watchme.utils.ImageCache.java
se.chalmers.watchme.utils.MenuUtils.java
se.chalmers.watchme.utils.MovieHelper.java
se.chalmers.watchmetest.Constants.java
se.chalmers.watchmetest.activity.MainActivityTest.java
se.chalmers.watchmetest.activity.MovieDetailsActivityTest.java
se.chalmers.watchmetest.activity.SearchableActivityTest.java
se.chalmers.watchmetest.activity.TabsAdapterTest.java
se.chalmers.watchmetest.activity.TagMovieListActivityTest.java
se.chalmers.watchmetest.database.WatchMeContentProviderTest.java
se.chalmers.watchmetest.model.MovieTest.java
se.chalmers.watchmetest.model.TagTest.java
se.chalmers.watchmetest.net.HttpRetrieverTest.java
se.chalmers.watchmetest.net.IMDBHandlerTest.java
se.chalmers.watchmetest.ui.MovieListFragmentTest.java
se.chalmers.watchmetest.ui.TagListFragmentTest.java
se.chalmers.watchmetest.util.DateTimeUtilsTest.java
se.chalmers.watchmetest.util.MovieHelperTest.java