Android 第十四课 使用LitePal添加数据(更新数据)

我们注意到当你登录一个app,是不是需要先注册呢?,所谓注册,简单地来理解是不是就是把输入框中地数据传入数据库中呢?

这里我们设置简单一点,注册的信息只包括两项,一项是用户名,另一项是密码。我们干脆建立一个表Driveruser。

在Android Studio 中新建一个java目录下,新建一个表Driveruser,

内容如下:

public class Driveruser{

    private String Dtel;//注册所用手机号

    private String Dpassword;注册密码

}

以及我们使用快捷键生成相应的getter和setter方法。这个Driveruser表就对应数据库中的Driveruser表,其中每个字段分别对应了每一个列,这就是对象关系映最直观的体验。

但是注意,每次新建一个类,都需要将其加入到映射模型列表中,修改litepal.xml中的代码,如下,

    ....

       

               

        


以上内容属于建立数据库的操作。言归正传,

使用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 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 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方法。
















你可能感兴趣的:(app,Android,Studio)