Advertisement
Guest User

Untitled

a guest
Oct 6th, 2015
475
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Java 6.95 KB | None | 0 0
  1. package com.paymon.tutorialapp;
  2.  
  3. import android.content.ContentProvider;
  4. import android.content.ContentUris;
  5. import android.content.ContentValues;
  6. import android.content.Context;
  7. import android.content.UriMatcher;
  8. import android.database.Cursor;
  9. import android.database.SQLException;
  10. import android.database.sqlite.SQLiteDatabase;
  11. import android.database.sqlite.SQLiteOpenHelper;
  12. import android.database.sqlite.SQLiteQueryBuilder;
  13. import android.net.Uri;
  14. import android.text.TextUtils;
  15.  
  16. import java.util.HashMap;
  17.  
  18.  
  19. public class MovieProvider extends ContentProvider {
  20.  
  21.     static final String PROVIDER_NAME = "com.paymon.provider.Movies";
  22.     static final String URL = "content://" + PROVIDER_NAME + "/movies";
  23.     static final Uri CONTENT_URI = Uri.parse(URL);
  24.  
  25.  
  26.     static final String NAME = "name";
  27.     static final String OVERVIEW = "overview";
  28.     static final String DATE = "date";
  29.     static final String REVIEW = "review";
  30.     static final String RATING = "rating";
  31.     static final String YOUTUBE1 = "youtube1";
  32.     static final String YOUTUBE2 = "youtube2";
  33.     static final String TITLE = "title";
  34.  
  35.  
  36.  
  37.     private static HashMap<String, String> MOVIES_PROJECTION_MAP;
  38.  
  39.     static final int MOVIES = 1;
  40.     static final int MOVIES_ID = 2;
  41.  
  42.     static final UriMatcher uriMatcher;
  43.     static{
  44.         uriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
  45.         uriMatcher.addURI(PROVIDER_NAME, "movies", MOVIES);
  46.         uriMatcher.addURI(PROVIDER_NAME, "movies/#", MOVIES_ID);
  47.     }
  48.  
  49.     /**
  50.      * Database specific constant declarations
  51.      */
  52.     private SQLiteDatabase db;
  53.     static final String DATABASE_NAME = "Movies";
  54.     static final String MOVIES_TABLE_NAME = "Movies";
  55.     static final int DATABASE_VERSION = 1;
  56.     static final String CREATE_DB_TABLE =
  57.             " CREATE TABLE " + MOVIES_TABLE_NAME +
  58.                     " (name, " +
  59.                     " overview, " +
  60.                     " title, " +
  61.                     " review, " +
  62.                     " rating, " +
  63.                     " youtube1, " +
  64.                     " youtube2, " +
  65.                     " date);";
  66.  
  67.     /**
  68.      * Helper class that actually creates and manages
  69.      * the provider's underlying data repository.
  70.      */
  71.     private static class DatabaseHelper extends SQLiteOpenHelper {
  72.         DatabaseHelper(Context context){
  73.             super(context, DATABASE_NAME, null, DATABASE_VERSION);
  74.         }
  75.  
  76.         @Override
  77.         public void onCreate(SQLiteDatabase db)
  78.         {
  79.             db.execSQL(CREATE_DB_TABLE);
  80.         }
  81.  
  82.         @Override
  83.         public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
  84.             db.execSQL("DROP TABLE IF EXISTS " +  MOVIES_TABLE_NAME);
  85.             onCreate(db);
  86.         }
  87.     }
  88.  
  89.     @Override
  90.     public boolean onCreate() {
  91.         Context context = getContext();
  92.         DatabaseHelper dbHelper = new DatabaseHelper(context);
  93.  
  94.         /**
  95.          * Create a write able database which will trigger its
  96.          * creation if it doesn't already exist.
  97.          */
  98.         db = dbHelper.getWritableDatabase();
  99.         return (db == null)? false:true;
  100.     }
  101.  
  102.     @Override
  103.     public Uri insert(Uri uri, ContentValues values) {
  104.         /**
  105.          * Add a new record
  106.          */
  107.         long rowID = db.insert(MOVIES_TABLE_NAME, "", values);
  108.  
  109.         /**
  110.          * If record is added successfully
  111.          */
  112.  
  113.         if (rowID > 0)
  114.         {
  115.             Uri _uri = ContentUris.withAppendedId(CONTENT_URI, rowID);
  116.             getContext().getContentResolver().notifyChange(_uri, null);
  117.             return _uri;
  118.         }
  119.         throw new SQLException("Failed to add a record into " + uri);
  120.     }
  121.  
  122.     @Override
  123.     public Cursor query(Uri uri, String[] projection, String selection,String[] selectionArgs, String sortOrder) {
  124.         SQLiteQueryBuilder qb = new SQLiteQueryBuilder();
  125.         qb.setTables(MOVIES_TABLE_NAME);
  126.  
  127.         switch (uriMatcher.match(uri)) {
  128.             case MOVIES:
  129.                 qb.setProjectionMap(MOVIES_PROJECTION_MAP);
  130.                 break;
  131.  
  132.             case MOVIES_ID:
  133.                 qb.appendWhere( NAME + "=" + uri.getPathSegments().get(1));
  134.                 break;
  135.  
  136.             default:
  137.                 throw new IllegalArgumentException("Unknown URI " + uri);
  138.         }
  139.  
  140.         if (sortOrder == null || sortOrder == ""){
  141.             /**
  142.              * By default sort on movie titles            */
  143.             sortOrder = NAME;
  144.         }
  145.         Cursor c = qb.query(db, projection, selection, selectionArgs,null, null, sortOrder);
  146.  
  147.         /**
  148.          * register to watch a content URI for changes
  149.          */
  150.         c.setNotificationUri(getContext().getContentResolver(), uri);
  151.         return c;
  152.     }
  153.  
  154.     @Override
  155.     public int delete(Uri uri, String selection, String[] selectionArgs) {
  156.         int count = 0;
  157.  
  158.         switch (uriMatcher.match(uri)){
  159.             case MOVIES:
  160.                 count = db.delete(MOVIES_TABLE_NAME, selection, selectionArgs);
  161.                 break;
  162.  
  163.             case MOVIES_ID:
  164.                 String id = uri.getPathSegments().get(1);
  165.                 count = db.delete( MOVIES_TABLE_NAME, NAME +  " = " + id +
  166.                         (!TextUtils.isEmpty(selection) ? " AND (" + selection + ')' : ""), selectionArgs);
  167.                 break;
  168.  
  169.             default:
  170.                 throw new IllegalArgumentException("Unknown URI " + uri);
  171.         }
  172.  
  173.         getContext().getContentResolver().notifyChange(uri, null);
  174.         return count;
  175.     }
  176.  
  177.     @Override
  178.     public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {
  179.         int count = 0;
  180.  
  181.         switch (uriMatcher.match(uri)){
  182.             case MOVIES:
  183.                 count = db.update(MOVIES_TABLE_NAME, values, selection, selectionArgs);
  184.                 break;
  185.  
  186.             case MOVIES_ID:
  187.                 count = db.update(MOVIES_TABLE_NAME, values, NAME + " = " + uri.getPathSegments().get(1) +
  188.                         (!TextUtils.isEmpty(selection) ? " AND (" +selection + ')' : ""), selectionArgs);
  189.                 break;
  190.  
  191.             default:
  192.                 throw new IllegalArgumentException("Unknown URI " + uri );
  193.         }
  194.         getContext().getContentResolver().notifyChange(uri, null);
  195.         return count;
  196.     }
  197.  
  198.     @Override
  199.     public String getType(Uri uri) {
  200.         switch (uriMatcher.match(uri)){
  201.             /**
  202.              * Get all student records
  203.              */
  204.             case MOVIES:
  205.                 return "vnd.android.cursor.dir/vnd.example.movies";
  206.  
  207.             /**
  208.              * Get a particular student
  209.              */
  210.             case MOVIES_ID:
  211.                 return "vnd.android.cursor.item/vnd.example.movies";
  212.  
  213.             default:
  214.                 throw new IllegalArgumentException("Unsupported URI: " + uri);
  215.         }
  216.     }
  217.     public void clearTable()
  218.     {
  219.         db.execSQL("DELETE FROM Movies");
  220.     }
  221.  
  222. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement