Android:week 11總結 內容提供者、數據庫

目錄

Monday

1.內容提供者

 

Tuesday

1.數據庫

 


Monday

1.內容提供者

創建方式: (URL Authorities和文件夾路徑名保持一致)

自動生成

 

Tuesday

1.數據庫

1.新建SQL的java代碼

DBaseHelper:

package com.example.myapplication;

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

public class DBaseHelper extends SQLiteOpenHelper {
    public DBaseHelper(Context context){
        super(context, "provider.db", null, 1);
    }
    @Override
    public void onCreate(SQLiteDatabase db){
        //整數、主鍵、自動增加、類型
        db.execSQL("create table info(_id integer primary key autoincrement, name varchar(20))");
    }
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion){}
}

2.創建ContentProvider

MyContentProvider:

package com.example.myapplication;

import android.content.ContentProvider;
import android.content.ContentValues;
import android.content.UriMatcher;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.net.Uri;

public class MyContentProvider extends ContentProvider {
    private static UriMatcher uriMatcher = new UriMatcher(-1);//匹配失敗的返回值-1
    private DBaseHelper helper;
    static {
        uriMatcher.addURI("com.example.mycontentprovider", "info", 1);
    }
    public MyContentProvider() {
    }

    @Override
    public int delete(Uri uri, String selection, String[] selectionArgs) {
        // Implement this to handle requests to delete one or more rows.
        if(uriMatcher.match(uri) == 1){
            SQLiteDatabase database = helper.getWritableDatabase();//打開數據庫
            int cont = database.delete("info", selection, selectionArgs);//刪除的數量
            database.close();
            return cont;
        }
        else
            throw new IllegalArgumentException("Uri is error.");
    }

    @Override
    public String getType(Uri uri) {
        // TODO: Implement this to handle requests for the MIME type of the data
        // at the given URI.
        return null;
    }

    @Override
    public Uri insert(Uri uri, ContentValues values) {
        // TODO: Implement this to handle requests to insert a new row.
        if(uriMatcher.match(uri) == 1){
            SQLiteDatabase database = helper.getWritableDatabase();
            //空爲null 否則values
            database.insert("info", null, values);
            database.close();
            return uri;
        }
        else
            throw new IllegalArgumentException("Uri is error.");
    }

    @Override
    public boolean onCreate() {
        // TODO: Implement this to initialize your content provider on startup.
        helper = new  DBaseHelper(getContext());//實例化
        return false;
    }

    @Override
    public Cursor query(Uri uri, String[] projection, String selection,
                        String[] selectionArgs, String sortOrder) {
        // TODO: Implement this to handle query requests from clients.
        if(uriMatcher.match(uri) == 1){ //匹配
            SQLiteDatabase database = helper.getReadableDatabase();
            //執行對數據庫的查詢
            Cursor cursor = database.query("info", projection, selection, selectionArgs, null, null, sortOrder);
            database.close();
            return cursor;
        }
        else
            throw new UnsupportedOperationException("Uri is error.");
    }

    @Override
    public int update(Uri uri, ContentValues values, String selection,
                      String[] selectionArgs) {
        // TODO: Implement this to handle requests to update one or more rows.
        if(uriMatcher.match(uri) == 1){
            SQLiteDatabase database = helper.getWritableDatabase();
            int cont = database.update("info", values, selection, selectionArgs);
            database.close();
            return cont;
        }
        else
            throw new IllegalArgumentException("Uri is error.");
    }
}

activity_main:

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <TextView
        android:id="@+id/tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="provider test!"
        android:textSize="15sp"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
    <Button
        android:id="@+id/add"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textSize="15sp"
        android:text="添加"
        app:layout_constraintTop_toBottomOf="@+id/tv"
        app:layout_constraintLeft_toLeftOf="@+id/tv"
        android:onClick="click"/>
    <Button
        android:id="@+id/delete"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textSize="15sp"
        android:text="刪除"
        app:layout_constraintTop_toBottomOf="@+id/add"
        app:layout_constraintLeft_toLeftOf="@+id/add"
        android:onClick="click"/>

    <Button
        android:id="@+id/query"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textSize="15sp"
        android:text="查詢"
        app:layout_constraintTop_toBottomOf="@+id/delete"
        app:layout_constraintLeft_toLeftOf="@+id/delete"
        android:onClick="click"/>
    <Button
        android:id="@+id/update"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textSize="15sp"
        android:text="更新"
        app:layout_constraintTop_toBottomOf="@+id/query"
        app:layout_constraintLeft_toLeftOf="@+id/query"
        android:onClick="click"/>

</androidx.constraintlayout.widget.ConstraintLayout>

MainActivity:

package com.example.myapplication;

import androidx.appcompat.app.AppCompatActivity;

import android.content.ContentResolver;
import android.content.ContentValues;
import android.net.Uri;
import android.os.Bundle;
import android.util.Log;
import android.view.View;

public class MainActivity extends AppCompatActivity {
    private ContentResolver resolver;
    private Uri uri;
    private int count = 0;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        DBaseHelper helper = new DBaseHelper(this);
    }
    public void click(View view){
        uri = Uri.parse("content://com.example.myapplication/info");
        resolver = getContentResolver();

        switch (view.getId()){
            case R.id.add:
                ContentValues values = new ContentValues();
                values.put("name", "software"+count ++);
                resolver.insert(uri, values);
                Log.d("***", "insert");
                break;
            case R.id.delete:
                resolver.delete(uri,"name=?", new String[]{"software0"});
                Log.d("***", "delete");
                break;
            case R.id.query:
                break;
            case R.id.update:
                break;
        }
    }
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章