1.创建一个类MyUserlogDBHelper去继承SQLiteOpenHelper,在该类里面创建表。
package com.example.demo;
import android.content.ContentValues;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import androidx.annotation.Nullable;
public class MyUserlogDBHelper extends SQLiteOpenHelper {
public MyUserlogDBHelper db;
//对外提供参数,单例模式
private static SQLiteOpenHelper mHelper;
public static synchronized SQLiteOpenHelper getInstance(Context context){
if (mHelper==null){
mHelper=new MyUserlogDBHelper(context,"user_log",null,1);
}
return mHelper;
}
private MyUserlogDBHelper(@Nullable Context context, @Nullable String name, @Nullable SQLiteDatabase.CursorFactory factory, int version) {
super(context, name, factory, version);
}
@Override
public void onCreate(SQLiteDatabase db) {
//创建表
String sql="create table user_log (_id integer primary key autoincrement,name text)";
//拿到db执行sql语句即可
db.execSQL(sql);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
2.在Activity中写查询,增加,修改,删除数据的操作。
package com.example.demo;
import androidx.appcompat.app.AppCompatActivity;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
public void create(View view) {
SQLiteOpenHelper helper = MyUserlogDBHelper.getInstance(this);
SQLiteDatabase readableDatabase = helper.getReadableDatabase();
}
//查询语句
public void query(View view) {
SQLiteOpenHelper instance = MyUserlogDBHelper.getInstance(this);
SQLiteDatabase db = instance.getReadableDatabase();
if (db.isOpen()){
//查询语句
String sql="select * from user_log";
//获取游标
Cursor cursor = db.rawQuery(sql, null);
while(cursor.moveToNext()){
//不规范的写法
/*int _id=cursor.getColumnIndex("0");
int name=cursor.getColumnIndex("1");
*/
//规范的写法
int _id=cursor.getInt(cursor.getColumnIndex("_id"));
String name=cursor.getString(cursor.getColumnIndex("name"));
Log.d("数据库", "_id: "+_id+",name:"+name);
}
//关闭游标
cursor.close();
//关闭数据库
db.close();
}
}
//插入语句
public void insert(View view) {
SQLiteOpenHelper instance = MyUserlogDBHelper.getInstance(this);
SQLiteDatabase db = instance.getWritableDatabase();
//判断数据库是否开启
if (db.isOpen()){
String sql="insert into user_log(name) values('路宇')";
db.execSQL(sql);
}
db.close();
}
//修改
public void update(View view) {
SQLiteOpenHelper instance = MyUserlogDBHelper.getInstance(this);
SQLiteDatabase db = instance.getWritableDatabase();
if (db.isOpen()){
String sql="update user_log set name=? where _id=?";
db.execSQL(sql,new Object[]{"成龙","5"});
}
//关闭数据库
db.close();
}
//删除数据
public void delete(View view) {
SQLiteOpenHelper instance = MyUserlogDBHelper.getInstance(this);
SQLiteDatabase db = instance.getWritableDatabase();
//判断数据是否是打开状态
if (db.isOpen()){
String sql="delete from user_log where _id=?";
db.execSQL(sql,new Object[]{6});
}
}
}
3.布局文件。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity"
android:orientation="vertical"
>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="创建表"
android:onClick="create" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="查询"
android:onClick="query" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="插入"
android:onClick="insert" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="修改"
android:onClick="update" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="删除"
android:onClick="delete" />
</LinearLayout>
以上就是SQLite数据库中,最简单的增删改查操作,想深入学习SQLite在项目中的实际应用,请持续关注后面博文!
今日国内领先的智能数据服务运营商觉非科技完成近亿元A轮融资。本轮融资由和高资...
一、简介 本设计为硬币图像识别统计装置通过数码相机获取平铺无重叠堆积的硬币的...
我们知道微软将会在今年给Windows10更换全新设计的UI,让Windows10的界面更加整...
一、MVC MVC模式的意思是,软件可以分成三个部分。 视图(View):用户界面。 控...
本文实例讲述了jsp中page指令用法。分享给大家供大家参考。具体如下: 一、JSP ...
从功能测试、性能测试、界面测试、安全性测试、易用性、兼容性测试、震动测试七...
git工作区,暂存区,版本库之间的关系: 我们建立的项目文件夹就是工作区,在初...
前言 关于Window,你了解多少呢?看看下面这些问题你都能答上来吗。 如果你遇到这...
大家好,今天我们来简单的聊一聊缓存问题。什么是缓存呢?它在系统设计中是在一个...
首先给扑克牌中每张牌设定一个编号,下面算法实现的编号规则如下: u 红桃按照从...