Android开发实现增删改查

创建数据库并写入方法

package com.example.sql;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

import androidx.annotation.Nullable;

import java.util.ArrayList;
import java.util.List;

public class MySQLliteOpenHelper extends SQLiteOpenHelper{
    SQLiteDatabase userDatabase;
    private static final String DB_NAME="sqls.db";
    private static final String TABLE_NAME_STUDENT="student";
    private static final String CREATE_TABLE_SQL_STUDENT="create table student("+
            "id integer primary key autoincrement,name text,num text)";
    public MySQLliteOpenHelper(@Nullable Context context, @Nullable String name, @Nullable SQLiteDatabase.CursorFactory factory, int version) {
        super(context, name, factory, version);
    }
    public MySQLliteOpenHelper(@Nullable Context context) {
        super(context,DB_NAME,null,1);
    }
    @Override
    public void onCreate(SQLiteDatabase sqLiteDatabase) {
        sqLiteDatabase.execSQL(CREATE_TABLE_SQL_STUDENT);
    }

    @Override
    public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {

    }
    //添加
    public long insertData(Student student) {
        SQLiteDatabase db=getWritableDatabase();
        ContentValues contentValues=new ContentValues();
        contentValues.put("name",student.getName());
        contentValues.put("num",student.getNum());


        return db.insert(TABLE_NAME_STUDENT,null,contentValues);
    }
    //删除
    public int deleteDataByName(String name){
        SQLiteDatabase db=getWritableDatabase();
        return db.delete(TABLE_NAME_STUDENT,"name=?",new String[]{name});
    }
    //修改
    public int update(Student student){
        SQLiteDatabase db=getWritableDatabase();
        ContentValues contentValues=new ContentValues();
        contentValues.put("name",student.getName());
        contentValues.put("num",student.getNum());
        return db.update(TABLE_NAME_STUDENT,contentValues,"name like ?",new String[]{student.getName()});
    }
    //查找
    public List<Student> selectFromName(String name){
        SQLiteDatabase db=getReadableDatabase();
        List<Student> studentList=new ArrayList<>();
        Cursor c=db.query(TABLE_NAME_STUDENT,null,"name like ?",new String[]{name},null,null,null);
        if(c!=null){
            while(c.moveToNext()){
                String stuName=c.getString(c.getColumnIndex("name"));
                String stuNum=c.getString(c.getColumnIndex("num"));
                Student student=new Student();
                student.setName(stuName);
                student.setNum(stuNum);

                studentList.add(student);
            }
            c.close();
        }
        return studentList;
    }


    //显示所有数据
    public List<Student> selectall(String name){
        SQLiteDatabase db=getReadableDatabase();
        List<Student> studentList=new ArrayList<>();
        Cursor c = db.query("student", null, null, null, null, null, null, null);
        if(c!=null){
            while(c.moveToNext()){
                String stuName=c.getString(c.getColumnIndex("name"));
                String stuNum=c.getString(c.getColumnIndex("num"));
                Student student=new Student();
                student.setName(stuName);
                student.setNum(stuNum);

                studentList.add(student);
            }
            c.close();
        }
        return studentList;
    }



}

方法调用

增加

package com.example.sql;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import com.example.sql.Student;


import android.widget.Toast;

public class InsertActivity extends AppCompatActivity {
    private EditText stuName,stuId;
    private Button btnHold;
    private MySQLliteOpenHelper mySQLliteOpenHelper;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_insert);

        initView();

        mySQLliteOpenHelper=new MySQLliteOpenHelper(this);
        btnHold.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                String name=stuName.getText().toString().trim();
                String num=stuId.getText().toString().trim();

                Student student=new Student();
                student.setName(name);
                student.setNum(num);

                long rowId=mySQLliteOpenHelper.insertData(student);
                if(rowId!=-1){
                    ToastUtill.toastshort(InsertActivity.this,"添加成功!");
                }else{
                    ToastUtill.toastshort(InsertActivity.this,"添加失败!");

                }
            }
        });
    }

    private void initView() {
        stuName=findViewById(R.id.stu_name);
        stuId=findViewById(R.id.stu_id);
        btnHold=findViewById(R.id.btn_hold);
    }


}

删除

package com.example.sql;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import android.widget.TextView;


public class DeleteActivity extends AppCompatActivity {
    EditText inname;
    private MySQLliteOpenHelper mMySQLliteOpenHelper;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_delete);
        mMySQLliteOpenHelper = new MySQLliteOpenHelper(this);
        initView();
    }

    private void initView() {
        inname=findViewById(R.id.stu_name);
    }

    public void deleteOnClick(View view) {
        String name=inname.getText().toString().trim();
        int i=mMySQLliteOpenHelper.deleteDataByName(name);
        if(i>0){
            ToastUtill.toastshort(this,"删除成功!删除了"+i+"行");
        }else{
            ToastUtill.toastshort(this,"删除失败!!");

        }
    }
}

修改

package com.example.sql;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.View;
import android.widget.EditText;

public class UpdateActivity extends AppCompatActivity {
    EditText stuName,stuNum;
    private MySQLliteOpenHelper mySQLliteOpenHelper;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_update);
        mySQLliteOpenHelper=new MySQLliteOpenHelper(this);
        initView();
    }

    private void initView() {
        stuName=findViewById(R.id.stu_name);
        stuNum=findViewById(R.id.stu_num);
    }

    public void updateOnClick(View view) {
        String name=stuName.getText().toString().trim();
        String num=stuNum.getText().toString().trim();

        Student student=new Student();
        student.setName(name);
        student.setNum(num);
        int i=mySQLliteOpenHelper.update(student);
        if(i>0){
            ToastUtill.toastshort(this,"修改成功!");
        }else{
            ToastUtill.toastshort(this,"修改失败!!!");
        }
    }
}

查询

package com.example.sql;

import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;

import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.text.TextUtils;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.TextView;

import java.util.List;

public class SelectActivity extends AppCompatActivity {
    Button btnSelectName;
    TextView toname,edinto;
    ListView lvSelect;
    private MySQLliteOpenHelper mySQLliteOpenHelper;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_select);
        mySQLliteOpenHelper=new MySQLliteOpenHelper(this);
        initView();
    }

    private void initView() {
        btnSelectName=findViewById(R.id.select_name);
        toname=findViewById(R.id.stu_name);
        edinto=findViewById(R.id.edinfo);
//        lvSelect=findViewById(R.id.lv_select);
    }

    public void selectOnClick(View view) {
        String name=toname.getText().toString().trim();
        if(!TextUtils.isEmpty(name)){
            List<Student> students=mySQLliteOpenHelper.selectFromName(name);
            if(!students.isEmpty()){
                showData(students);
                return;
            }else{
                ToastUtill.toastshort(this,"查询结果为空!");
            }

        }
    }

    private void showData(@NonNull List<Student> students){
        StringBuilder stringBuilder=new StringBuilder();
        for(Student student1:students){
            stringBuilder.append("姓名:");
            stringBuilder.append(student1.getName());
            stringBuilder.append(",学号:");
            stringBuilder.append(student1.getNum());
            stringBuilder.append("\n");
        }
        edinto.setText(stringBuilder.toString());
    }


}
  • 1
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: Android Studio是一款非常强大的开发工具,可以用来开发Android应用程序。在Android Studio实现增删改查操作,需要使用SQLite数据库。SQLite是一种轻量级的关系型数据库,非常适合在移动设备上使用。 要实现增删改查操作,需要先创建一个SQLite数据库,并定义表结构。然后在Android Studio中编写Java代码,使用SQLiteOpenHelper类来管理数据库。通过调用insert、delete、update和query等方法,就可以实现增删改查操作了。 具体实现步骤如下: 1. 创建SQLite数据库 在Android Studio中创建一个新的Android项目,然后在项目中创建一个SQLiteOpenHelper类。在该类中,定义数据库名称、版本号和表结构等信息。 2. 实现增删改查操作 在SQLiteOpenHelper类中,实现insert、delete、update和query等方法,用于增加、删除、修改和查询数据。这些方法都是基于SQL语句实现的,可以使用Android提供的SQLiteDatabase类来执行SQL语句。 3. 在应用程序中调用数据库操作 在应用程序中,创建一个数据库实例,并调用数据库操作方法来实现增删改查操作。可以使用Android提供的Cursor类来获取查询结果。 总之,Android Studio实现增删改查操作需要掌握SQLite数据库的基本知识和Android开发技术。只要掌握了这些知识,就可以轻松实现增删改查操作了。 ### 回答2: Android Studio是谷歌官方推荐的开发工具,可以用来创建各种Android应用程序。在Android中,增删改查是常见的操作,可以通过使用SQLite数据库来实现。 首先,我们需要在项目中创建一个SQLite数据库,该数据库将包含所有需要进行增删改查的数据表。在Android Studio中,我们可以使用SQLiteOpenHelper类来创建和管理数据库。在SQLiteOpenHelper类中,我们需要重写onCreate()和onUpgrade()方法来设置数据库模式及更新。 接下来,我们需要创建一个DAO(Data Access Object)类来处理增删改查操作。DAO类是一个介于应用程序和数据库之间的抽象层。它提供了一种简单的方式来访问数据库,同时避免了将数据库代码与应用程序代码混合的问题。 在DAO类中,我们需要实现以下方法: 1. insert() - 用于将新数据添加到数据库中。 2. delete() - 用于从数据库中删除数据。 3. update() - 用于更新数据库中的现有数据。 4. select() - 用于从数据库中检索数据。 这些方法都应该返回一个Boolean值,以指示它们是否成功执行了操作。 最后,我们需要在应用程序中创建一个控制器类,它将调用DAO类中的方法,以便在应用程序中执行增删改查操作。在控制器类中,我们可以设置并处理用户界面(UI)的事件,如按钮点击事件等。 总之,Android Studio实现增删改查的方法可以概括为:创建数据库、创建DAO类、创建控制器类,然后通过调用DAO类中的方法实现增删改查操作,并在控制器类中处理用户界面事件。这样就可以实现一个基本的增删改查应用程序。 ### 回答3: Android Studio是一款广泛应用于Android应用程序开发的集成开发环境(IDE)。要实现应用程序的增删改查功能,需要熟悉Android开发的基本概念和技术。 一、创建SQLite数据库 SQLite是Android中默认使用的轻型关系型数据库。要实现数据的增删改查,需要先创建一个SQLite数据库。 1. 创建一个Java类,用于管理数据库: 例如,创建一个名为DBHelper的类用于管理数据库,该类应继承SQLiteOpenHelper,并实现onCreate()和onUpgrade()方法。 2. 在onCreate()方法中创建数据表: 指定表的名称和包含的列,每个列都包含一个名称和数据类型。例如,以下代码创建一个名为“users”的数据表: 3. 将数据库带入应用程序: 在应用程序中,构造方法传递一个上下文和数据库名称。 二、实现数据的增删改查Android中,访问SQLite数据库需要使用ContentProvider和ContentResolver。这两个类可以帮助应用程序实现数据的增删改查功能。 1. 添加数据: 首先,创建一个Java类,用于实现数据的增加,并实例化它以便在应用程序中调用。例如: 其中,ContentValues对象包含需要被添加到数据表中的值对。使用ContentProvider的insert()方法将数据插入到数据表中: 2. 查询数据: 查询数据需要使用ContentResolver和Cursor。例如: 这个查询将返回一个Cursor对象,可以使用它来遍历查询得到的数据。 3. 更新数据: 更新数据需要使用ContentProvider和ContentResolver。例如: 首先获取要更新的数据行的ID号,然后将更新后的数据集合插入到ContentValues对象中,最后使用ContentProvider的update()方法进行更新操作。 4. 删除数据: 删除数据需要使用ContentProvider和ContentResolver。例如: 这将删除数据表中ID为“1”的数据行。 总结: 以上是使用Android Studio实现增删改查的基本步骤,但其中还包含了更细节和深度的实现方法,需要开发者结合具体的需求去更深入地学习与应用。通过对于这项功能的学习,可以为Android应用程序开发打下牢固的基础,为搭建更加完善的应用程序功能提供保障。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xx080

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值