安卓使用sql语句实现SQLite数据库的增删改查

本篇博文是在上一篇新建了数据库的基础上编写的,上一篇博文链接:https://blog.csdn.net/liyunfu233/article/details/84193368

首先在布局文件中添加四个按键分别是增删改查四种方法,在主窗口类中实现四种方法:
第一个点击按钮增加一条记录
在这里插入图片描述
第二个点击按钮删除一条记录
在这里插入图片描述

第三个点击按钮更新一条记录

在这里插入图片描述

第四个点击按钮查询记录
在这里插入图片描述

本篇博文需要将上一篇博文创建的数据库字段增加一个phone字段。
在这里插入图片描述
cursor为行的集合,即如果查询到数据,cursor就不为空,moveTonext是移动到下一行。

所有代码如下:
布局代码:

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

    <Button
            android:onClick="click1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="add"/>
    <Button
            android:onClick="click2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="delete"/>
    <Button
            android:onClick="click3"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="update"/>
    <Button
            android:onClick="click4"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="find"/>

</LinearLayout>

myopenhelper类代码:

package com.example.a15114.createsqlitedemo;

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

import java.sql.ResultSet;

public class MyOpenHelper extends SQLiteOpenHelper {
    /**
     *
     *  context 上下文
     *   name  数据库的名字
     *  factory   目的创建cursor对象
     *  version    数据库的版本  从1开始
     */
    public MyOpenHelper(Context context) {
        super(context, "itheima.db", null, 4);
    }
    /**
     * 当数据库第一次创建的时候调用
     * 那么这个方法特别适合做表结构的初始化 创建表就是写sql语句
     *
     */
    @Override
    public void onCreate(SQLiteDatabase db) {
        //id 一般以_id
        db.execSQL("create table info(_id integer primary key autoincrement,name varchar(20),phone varchar(20))");
    }
    /**
     *
     * 当数据库版本升级的时候调用
     *
     * 这个方法适合做 表结构的更新
     */
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

        System.out.println("升级");
        db.execSQL("alter table info add phone varchar(20)");
    }
}

主窗口类代码:

package com.example.a15114.createsqlitedemo;

import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;

public class MainActivity extends AppCompatActivity {
    MyOpenHelper myOpenHelper;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        myOpenHelper=new MyOpenHelper(getApplicationContext());
        //打开或者创建数据库  如果是第一次就是创建
        //SQLiteDatabase sqLiteDatabase=myOpenHelper.getWritableDatabase();

        //打开或创建数据库 如果是第一次就是创建  如果磁盘满了只返回一个可读的
        SQLiteDatabase sqLiteDatabase=myOpenHelper.getReadableDatabase();


    }

    //点击按钮增加一条记录
    public void click1(View view) {
        //[1]获取数据库对象
        SQLiteDatabase db=myOpenHelper.getReadableDatabase();
        //[2]执行增加一条的sql语句
        db.execSQL("insert into info(name,phone) values(?,?)",new Object[]{"张三","138888"});
        //[3]数据库用完需要关闭
        db.close();
    }


    //删除
    public void click2(View view) {

        SQLiteDatabase db=myOpenHelper.getReadableDatabase();

        db.execSQL("delete from info where name=?",new Object[]{"张三"});

        db.close();
    }

    //更新
    public void click3(View view) {

        SQLiteDatabase db=myOpenHelper.getReadableDatabase();

        db.execSQL("update info set phone=? where name=?",new Object[]{"139999"});

        db.close();

    }

    //查找
    public void click4(View view) {

        SQLiteDatabase db=myOpenHelper.getReadableDatabase();

        Cursor cursor=db.rawQuery("select * from info",null);
        if (cursor!=null&&cursor.getCount()>0){
            while (cursor.moveToNext()){
                //columindex代表列的索引
                String name=cursor.getString(1);
                String phone=cursor.getString(2);
                System.out.println("name:"+name+"---------"+phone);
            }
        }
    }
}

猜你喜欢

转载自blog.csdn.net/liyunfu233/article/details/84193577