Android Studio初学者实例:SQLite实验:绿豆通讯录

05-13 1403阅读

本次实验是使用SQLite对一个通讯录表进行简单增删改查

以下是实验效果:

Android Studio初学者实例:SQLite实验:绿豆通讯录Android Studio初学者实例:SQLite实验:绿豆通讯录

Android Studio初学者实例:SQLite实验:绿豆通讯录Android Studio初学者实例:SQLite实验:绿豆通讯录

 首先是继承SQLiteOpenHelper的数据库自定义类

对于此类必须继承于SQLiteOpenHelper ,当new创造该类的实例的时候会执行创建数据库以及表的操作,例如本代码中数据库名为itcast,数据库表名为informatoin。db.execSQL为执行创建表语句。

MyHelper
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
public class MyHelper extends SQLiteOpenHelper {
    public MyHelper(Context context) {
//上下文、数据库名、工厂、版本
        super(context, "itcast.db", null, 1);
    }
    @Override
    public void onCreate(SQLiteDatabase db) {
//创建数据表 db.execSQL执行建表语句
        db.execSQL("CREATE TABLE information(_id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), phone VARCHAR(20))");
    }
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    }
}

主界面的界面代码

activity_main.xml


    
        
        
    
    
        
        
    
    
        
        
        
        
    
    
    

 item界面代码

list_item.xml


    
    
        
        
    

 逻辑代码

MainActivity

import androidx.appcompat.app.AppCompatActivity;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.provider.ContactsContract;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.SimpleCursorAdapter;
import android.widget.TextView;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
    MyHelper myHelper;
    private EditText mEtName;
    private EditText mEtPhone;
    private Button mBtnAdd;
    private Button mBtnQuery;
    private Button mBtnUpdate;
    private Button mBtnDelete;
    private ListView mList;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //new创建对象  传递上下文this
        myHelper = new MyHelper(this);
        init();//初始化控件 绑定控件
    }
    private void init() {
        mEtName = (EditText) findViewById(R.id.et_name);
        mEtPhone = (EditText) findViewById(R.id.et_phone);
        mBtnAdd = (Button) findViewById(R.id.btn_add);
        mBtnQuery = (Button) findViewById(R.id.btn_query);
        mBtnUpdate = (Button) findViewById(R.id.btn_update);
        mBtnDelete = (Button) findViewById(R.id.btn_delete);
        mBtnAdd.setOnClickListener(this);
        mBtnQuery.setOnClickListener(this);
        mBtnUpdate.setOnClickListener(this);
        mBtnDelete.setOnClickListener(this);
        mList = (ListView) findViewById(R.id.lv);
    }
    @Override
    public void onClick(View v) {
        String name;
        String phone;
        SQLiteDatabase db;
        ContentValues values;
        switch (v.getId()) {
            case R.id.btn_add: //添加数据
                name = mEtName.getText().toString();
                phone = mEtPhone.getText().toString();
                db = myHelper.getWritableDatabase();//获取可读写SQLiteDatabse对象
                values = new ContentValues();       // 创建ContentValues对象
                values.put("name", name);           // 将数据添加到ContentValues对象
                values.put("phone", phone);         // 将数据添加到ContentValues对象
                db.insert("information", null, values);//执行方法insert向数据表添加数据
                Toast.makeText(this, "信息已添加", Toast.LENGTH_SHORT).show();//提示框
                db.close();//关闭db
                break;
            case R.id.btn_query: //查询数据
                Toast.makeText(this, "query", Toast.LENGTH_SHORT).show();
                db = myHelper.getReadableDatabase();
                if(mEtName.getText().toString().isEmpty()){
                    Cursor cursor = db.query("information", null, null, null, null, null, null);//Cursor作为一种游标的存储类型,来存储获取到的数据
                    SimpleCursorAdapter spcAdapter = new SimpleCursorAdapter(this, R.layout.list_item, cursor,
                            new String[]{"name", "phone"}, new int[]{R.id.item_name, R.id.item_phone});
                    mList.setAdapter(spcAdapter);
                }else {
                    Cursor cursor = db.rawQuery("select * from information where name=?", new String[]{mEtName.getText().toString()});
                    SimpleCursorAdapter spcAdapter = new SimpleCursorAdapter(this, R.layout.list_item, cursor,
                            new String[]{"name", "phone"}, new int[]{R.id.item_name, R.id.item_phone});
                    mList.setAdapter(spcAdapter);
                }
                //cursor.close();
                //db.close();
                break;
            case R.id.btn_update: //修改数据
                db = myHelper.getWritableDatabase();
                values = new ContentValues();       // 要修改的数据
                values.put("phone", phone = mEtPhone.getText().toString());
                db.update("information", values, "name=?",
                        new String[]{mEtName.getText().toString()}); // 更新并得到行数
                Toast.makeText(this, "信息已修改", Toast.LENGTH_SHORT).show();
                db.close();
                break;
            case R.id.btn_delete: //删除数据
                db = myHelper.getWritableDatabase();
                db.delete("information", "name=?",new String[]{mEtName.getText().toString()});
                Toast.makeText(this, mEtName.getText().toString()+"信息已删除", Toast.LENGTH_SHORT).show();
                db.close();
                break;
        }
    }
}

 以上是一个简单的示例,详细的讲解未来补充,还有很多可以补充的地方,例如:采用实体类、换一个更详细的适配器Adapter、让通讯录的信息更加丰富等

需要资源 资源已经传到主页  绿豆通讯录   免积分下载,可以下载一下哦

VPS购买请点击我

文章版权声明:除非注明,否则均为主机测评原创文章,转载或复制请以超链接形式并注明出处。

目录[+]