我們注意到當你登錄一個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;@Overrideprotected 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() {@Overridepublic 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();@Overridepublic 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方法。