1. 程式人生 > >Android 第十四課 使用LitePal新增資料(更新資料)

Android 第十四課 使用LitePal新增資料(更新資料)

我們注意到當你登入一個app,是不是需要先註冊呢?,所謂註冊,簡單地來理解是不是就是把輸入框中地資料傳入資料庫中呢?

這裡我們設定簡單一點,註冊的資訊只包括兩項,一項是使用者名稱,另一項是密碼。我們乾脆建立一個表Driveruser。

在Android Studio 中新建一個java目錄下,新建一個表Driveruser,

內容如下:

public class Driveruser{

    private String Dtel;//註冊所用手機號

    private String Dpassword;註冊密碼

}

以及我們使用快捷鍵生成相應的getter和setter方法。這個Driveruser表就對應資料庫中的Driveruser表,其中每個欄位分別對應了每一個列,這就是物件關係映最直觀的體驗。

但是注意,每次新建一個類,都需要將其加入到對映模型列表中,修改litepal.xml中的程式碼,如下,

<litepal>

    ....

        <list>

                <mapping class= "com.example.testapp.Driveruser"

        </list>

</litepal>

以上內容屬於建立資料庫的操作。言歸正傳,

使用LitePal來新增資料,操作非常簡單,

1、只需要創建出模型類的例項

2、再將所有要儲存的資料設定好。

3、最後再呼叫一下save()方法。

觀察所有的模型類,都是沒有繼承結構的,因為LitePal進行表管理操作時不需要模型類有任何的繼承結構,但是進行

CURD操作時就不行了,必須要繼承自DataSupport類才行,因此這裡我們需要先把繼承結構給加上。修改Driveruser表中的程式碼,如下:

private class Book extends DataSupport{

......

}

接著我們把輸入框中輸入的資料通過點選按鈕傳入資料庫,修改RegisterActivity中的程式碼:

package com.example.testappb;

import android.content.Intent;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.provider.ContactsContract;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

import org.litepal.crud.DataSupport;

import java.util.List;

public class RegisterActivity extends AppCompatActivity {

    private EditText DtelEdit;//定義EditText型別的變數,用來儲存從輸入框中輸入的資料
    private EditText DpasswordEdit;



    private Button querenzhuce;//定義按鈕,
    private Button zhucefanhui;

    //宣告刪除資訊
    private EditText edittext_shanchu;
    private Button   button_shanchu;
    private SQLiteOpenHelper dbHelper;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.register_layout);

        //獲取輸入框的例項
        DtelEdit = (EditText)findViewById(R.id.edittext_Dtel);
        DpasswordEdit = (EditText)findViewById(R.id.edittext_Dpassword);

        querenzhuce= (Button)findViewById(R.id.button_querenzhuce);
        zhucefanhui=(Button)findViewById(R.id.button_zhucefanhui);


        //設定返回登入按鈕透明度
        querenzhuce.getBackground().setAlpha(50);
        querenzhuce.setOnClickListener(new View.OnClickListener() {
            @Override//按鈕點選事件
            public void onClick(View view) {
                String dteledit = DtelEdit.getText().toString();//將資料框中輸入的資料用toString()轉化為String。
                String dpasswordedit = DpasswordEdit.getText().toString();
                if(dteledit.equals("")|| dpasswordedit.equals("") ){//異常判斷

                    Toast.makeText(RegisterActivity.this, "手機號或密碼為空", Toast.LENGTH_SHORT).show();
                    return;

                }
                List<Driveruser> driveruers = DataSupport.findAll(Driveruser.class);
                for(Driveruser driveruser:driveruers) {
                    if ((driveruser.getDtel().toString()).equals(dteledit) && (driveruser.getDpassword().toString()).equals(dpasswordedit)) {
                        Toast.makeText(RegisterActivity.this,"手機號不可重複註冊",Toast.LENGTH_SHORT).show();
                        return;
                    }
                }
                Driveruser driveruser_2 = new Driveruser();//首先創造了一個Driveruser的例項。
                driveruser_2.setDtel(dteledit);//使用set方法對資料進行設定
                driveruser_2.setDpassword(dpasswordedit);
                driveruser_2.save();//使用save()儲存。save方法來源於DataSupport中繼承而來的。
                Toast.makeText(RegisterActivity.this, "註冊成功", Toast.LENGTH_SHORT).show();
} }); zhucefanhui.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { Intent intent = new Intent(RegisterActivity.this,MainActivity.class); startActivity(intent); } }); edittext_shanchu = (EditText)findViewById(R.id.edittext_shanchu); button_shanchu = (Button)findViewById(R.id.button_shanchu); button_shanchu.setOnClickListener(new View.OnClickListener() { //獲取輸入的資訊後轉化為字串 String edittextshanchu = DtelEdit.toString(); @Override public void onClick(View view) { // // List<Driveruser> driveruers = DataSupport.findAll(Driveruser.class); //for(Driveruser driveruser:driveruers) { //if ((driveruser.getDtel().toString()).equals(edittextshanchu)) { //DataSupport.deleteAll(Driveruser.class,"Dtel ==?","edittextshanchu"); //driveruser.save(); DataSupport.deleteAll(Driveruser.class); // SQLiteOpenHelper TestApp = dbHelper.getWritableDatabase(); // TestApp.delete("driveruser","Dtel==",new String[] ("edittextshanchu") Toast.makeText(RegisterActivity.this,"刪除成功",Toast.LENGTH_SHORT).show(); return; } }); } }

閱讀斜體字,首先我們建立了一個Driveruser的例項,然後呼叫Driveruser中的set方法對資料進行設定,最後再呼叫driveruser.save()方法就能完成資料新增操作了。save()是從DataSupport()類中繼承而來的。除了save()方法,DataSupport()類還提供了豐富的CRUD方法。