SQLite实现基本的增删改查功能

SQLite实现基本的增删改查功能


还是向之前一样,先介绍功能,再介绍所用知识点,然后贴下代码。

一,SQLite简介:

SQLite,是一款轻型的数据库,是遵守ACID(原子性、一致性、隔离性、持久性)的关联式数据库管理系统,多用于嵌入式开发中。
  SQLite的数据类型:Typelessness(无类型), 可以保存任何类型的数据到你所想要保存的任何表的任何列中. 但它又支持常见的类型比如: NULL, VARCHAR, TEXT, INTEGER, BLOB, CLOB...等. 唯一的例外:integer primary key 此字段只能存储64位整数,数据库的主键只能为"_id",设为primary key时,会自增,从1开始,不需要再加auto_increment关键字

在Android系统,提供了一个SQLiteOpenHelper抽象类,该类用于对数据库版本进行管理.数据库帮助类,用户创建和管理数据库,该类中常用的方法:
     onCreate     数据库创建时执行(第一次连接获取数据库对象时执行),初始化一些表;
     onUpgrade     数据库更新时执行(版本号改变时执行),在执行添加表,删除表,修改表时可以在此方法中操作
     onOpen          数据库每次打开时执行(每次打开数据库时调用,在 onCreate,onUpgrade方法之后)

数据库操作工具:

SQLiteHelper,SQLiteExpert,SQLite3

数据库一般操作步骤:

1,加载驱动;

2,连接数据库;

3,操作数据库

但是在android中,前两步骤省略了,andorid帮我做了

在第一次连接数据库用SQLiteOpenHelper调用getReaderDatabase()方法时创建数据库

为防止SQL注入,尽量不要把字符串拼接SQL

数据库存放路径:

/data/data/程序包名/databases/数据库名.db 下

数据库操作注意事项:

1,判断数据库是否打开,isOpen();

2,数据库使用完之后要关闭 close();

3, 查询方法:rawQuery();

4,插入方法:execSQL()

在android中,操作数据库有两种方式:

1,直接写SQL语句;

2,使用API提供的方法进行增删改查,相当于hibernate中的HQL;

数据库事务操作:

// 开启事务
 db.beginTransaction();

// 标记事务成功
 db.setTransactionSuccessful();

// 停止事务
 db.endTransaction();

使用事务会加快执行速度

Cursor结果集的特点:

1,默认指定-1

moveToNext()

Cursor使用完之后需要关闭close(),不然会一直保存在内存中,出现内存溢出。

sqlite3的使用

命令:

1,adb shell   通过adb可以轻松的执行Linux Shell命令

2, cd   /data/data/packageName/databases    进入databases 目录

3,sqlite3 test.db     进入sqlite3,操作test数据库

.tables :列出数据库中所有的表

exit:退出sqlite操作模式

二,主要功能:

  1,实现对student表的增删改查功能;

三,主要知识点:

  1,SQLiteOpenHelper抽象类的使用

  2,Cursor的使用;

  3,事务的使用;

四,工程目录结构截图:

五,代码展示:

  1,实体类Student.java

public class Student {
    private int id;
    private String name;
    private int age;
    private String info;

    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }

    public String getInfo() {
        return info;
    }

    public void setInfo(String info) {
        this.info = info;
    }
    public Student(int id, String name, int age, String info) {
        super();
        this.id = id;
        this.name = name;
        this.age = age;
        this.info = info;
    }

    public Student() {
        super();
    }
    @Override
    public String toString() {
        return "Student [id=" + id + ", name=" + name + ", age=" + age + "]";
    }
}

  2,DBHelper.java,继承SQLiteOpenHelper类

/**
 * 能够更好的管理和维护数据库,我们会封装一个继承自SQLiteOpenHelper类的数据库操作类,
 * 然后以这个类为基础,再封装我们的业务逻辑方法。
 * @author wk
 *
 */
public class DBHelper  extends SQLiteOpenHelper {

    public static final String DB_NAME = "test.db";
    public static final int VERSION = 1;

    public DBHelper(Context context) {
         //CursorFactory设置为null,使用默认值
        super(context, DB_NAME, null, VERSION);
    }

     //数据库第一次被创建时onCreate会被调用
    @Override
    public void onCreate(SQLiteDatabase db) {
        // TODO Auto-generated method stub
         db.execSQL("CREATE TABLE IF NOT EXISTS student" +
                    "(_id INTEGER PRIMARY KEY , name VARCHAR, age INTEGER, info TEXT)");
    }

    //如果DATABASE_VERSION值被改为2,系统发现现有数据库版本不同,即会调用onUpgrade
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // TODO Auto-generated method stub
    //    if(oldVersion ==1&&newVersion ==2){
    //        db.execSQL("alter table student add sex integer");
    //    }
    }

}

  3,数据库管理类DBManager,实现增删改查功能

public class DBManager {
    private DBHelper helper = null;
    private SQLiteDatabase database ;
    public DBManager(Context context) {
        this.helper = new DBHelper(context);
        //因为getWritableDatabase内部调用了mContext.openOrCreateDatabase(mName, 0, mFactory);
        //所以要确保context已初始化,我们可以把实例化DBManager的步骤放在Activity的onCreate里
        database = helper.getWritableDatabase();
    }

    /**
     * 插入操作
     * 在添加student信息时,我们采用了事务处理,确保数据完整性;
     * @param student
     */
    public boolean insert(Student student){
        boolean flag = false;
        //开启事务
        database.beginTransaction();
        try {
            if(database.isOpen()){
                database.execSQL("insert into student(name,age,info) values(?,?,?)",new Object[]{student.getName(),student.getAge(),student.getInfo()} );
                //标记事务成功,如果没执行这句话,则自动回滚
                database.setTransactionSuccessful();
            }
            flag = true;

        } catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
        }finally{
            //关闭事务
            database.endTransaction();
        }
        return flag;
    }
    /**
     * 删除操作
     * @param studentId
     */
    public boolean delete(int studentId){
        boolean flag = false;
        try {
            if(database.isOpen()){
                database.execSQL("delete from student where _id = ?",new Object[]{studentId});
            }
            flag = true;
        } catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
        }

        return flag;
    }

    /**
     * 更新操作
     * @param id
     * @param name
     * @return
     */
    public boolean update(int id,String name){
        boolean flag = false;
        try {

            if(database.isOpen()){
                database.execSQL("update student set name = ? where _id = ?",new Object[]{name,id});
                database.close();
            }
            flag = true;

        } catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
        }

        return flag;
    }
    /**
     * 根据id查询学生信息
     * @param id
     * @return
     */
    public Student queryById(int id){
        Student student = null;
        try {

            if(database.isOpen()){
                Cursor cursor = database.rawQuery("select _id,name,age,info from student where _id = ?", new String[]{String.valueOf(id)});
                if(cursor!=null && cursor.getCount()>0){
                    if(cursor.moveToFirst()){
                        int _id =cursor.getInt(0);
                        String name = cursor.getString(1);
                        int age = cursor.getInt(2);
                        String info = cursor.getString(3);
                        student = new Student(_id,name,age,info);
                    }
                }
                cursor.close();
            }
            return student;

        } catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
            return null;
        }

    }
    /**
     * 查询所有的学生信息
     * @return
     */
    public List<Student> queryAllStudent(){
        List<Student> studentList = null;
        try {
            if(database.isOpen()){
                studentList = new ArrayList<Student>();
                Cursor cursor = database.rawQuery("select _id,name,age,info from student",null);
                while (cursor.moveToNext()){

                    int _id =cursor.getInt(cursor.getColumnIndex("_id"));
                    String name = cursor.getString(cursor.getColumnIndex("name"));
                    int age = cursor.getInt(cursor.getColumnIndex("age"));
                    String info = cursor.getString(cursor.getColumnIndex("info"));
                    Student student = new Student(_id,name,age,info);
                    studentList.add(student);
                }
            }
        } catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
        }

        return studentList;
    }

    public void closeDB() {
        //释放数据库连接,否则容易出现SQLiteException
        if(database.isOpen()){
            database.close();
        }
    }
}

  4,测试类DatabaseTest,继承AndroidTestCase

public class DatabaseTest extends AndroidTestCase {

    public static final String TAG = DatabaseTest.class.getSimpleName();

    private DBManager dao ;

    public void testInsert(){
        Student student = new Student();
        student.setName("冠希");
        student.setAge(30);
        student.setInfo("hhe");
        dao = new DBManager(getContext());
        boolean flag = dao.insert(student);
        Assert.assertEquals(true, flag);
    }
    public void testDelete(){

        dao = new DBManager(getContext());
        boolean flag = dao.delete(1);
        Assert.assertEquals(true, flag);
    }
    public void testUpdate(){
        dao = new DBManager(getContext());
        boolean flag = dao.update(1, "凤姐");
        Assert.assertEquals(true, flag);
    }

    public void testQueryAll(){

        dao = new DBManager(getContext());
        List<Student> studentList= dao.queryAllStudent();
        for (int i = 0; i < studentList.size(); i++) {
            Log.i(TAG, studentList.get(i).toString());
        }
    }

    public void testQueryId(){

        dao = new DBManager(getContext());
        Student student= dao.queryById(2);

        Log.i(TAG, student.toString());

    }

}

最后为了JUnit单元测试,需要在AndroidManifest.xml文件中配置一下信息:

在manifest节点下:
    <instrumentation
        android:name="android.test.InstrumentationTestRunner"
        android:targetPackage="com.example.sqlitedemo" />

在application节点下配置下面信息:
    <uses-library android:name="android.test.runner" />

好了,通过以上步骤基本可以实现单表的增删改查功能了

时间: 2024-10-06 23:49:11

SQLite实现基本的增删改查功能的相关文章

使用MVC5+Entity Framework6的Code First模式创建数据库并实现增删改查功能

此处采用VS2017+SqlServer数据库 一.创建项目并引用dll: 1.创建一个MVC项目 2.采用Nuget安装EF6.1.3 二.创建Model 在models文件夹中,建立相应的model文件,这里建立的class名,就是数据库里表的名字.        在这里面,可以建立表之间的关系,本次将建立Course(课程).Student(学生).StuCourse(课程学生关系)来作为一个Demo [Table("t_course")]   //可以通过Attribute的形

java H2数据库使用并实现增删改查功能

原文:java H2数据库使用并实现增删改查功能 代码下载地址:http://www.zuidaima.com/share/1550463278058496.htm package com.zuidaima.h2sql.test; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.St

JavaScript之实现基本的增删改查功能

开心一笑 听说这两天,全国都很冷.福建人说1度好冷,北京人笑了:我们这零下17度.黑龙江人也笑了:我们这零下33度.呼伦贝尔人听到哈哈大笑:我们这零下43度.福建人听完冷笑一声:我说的是室内,室内,室内 提出问题 如何利用原生的js实现基本的增删改查功能 解决问题 包含两个文件(index.jsp 和 index.js) <%@ page language="java" contentType="text/html; charset=UTF-8" pageEn

js + bootstrap 实现基本的增删改查功能 -- 兰

描述:利用原生js + bootstrap 实现基本的增删改查功能:包含两个文件(index.jsp 和 index.js) <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN

JavaWeb 增删改查功能

1.今天来写一个简单的增删改查功能,这个项目还是接着在昨天写的 --JavaWeb实现简单登录注册-- 来写的. 登录成功进来后对学生信息的增删改查 好了,直接贴上今天写的代码 src文件下的代码: jsp页面: 数据库创建语句: 1 CREATE TABLE nanfeng.student ( 2 stu_id INT NOT NULL AUTO_INCREMENT, 3 stu_name varchar(100) NULL, 4 stu_sex varchar(100) NULL, 5 st

3.创建Manager类,演示对TestUser进行增删改查功能

接上一篇文章 创建NHibernateHelper帮助类,生成sessionFactory http://www.cnblogs.com/fzxiaoyi/p/8443587.html 创建个新的类Manager,演示对TestUser进行增删改查功能 编写代码如下: using MySQLDateBase.Model; using System; using System.Collections.Generic; using System.Linq; using System.Text; us

SpringBoot快速上手——《二》:SpringBoot集成SSM,实现增删改查功能

SpringBoot集成SSM,实现增删改查功能 github源码:https://github.com/xivinChen/SpringBoot 一.先介绍创建模块的另一种方式 1.点击Maven -> 勾选Create from archetype -> 选择 maven-archetype-quickstart 有时会需要点击 自动导入 2.工程目录 可以看到,这样创建的模块是相对干净的,需要我们手动的编写程序启动入口类.需要配置时还得创建配置文件.下一步见证. 3.完善模块 添加依赖,

web项目总结——通过jsp+servlet实现对oracle的增删改查功能

1.DAO模式 分包:依次建立 entity:实体包,放的是跟oracle数据库中表结构相对应的对象的属性,也就是这个对象有什么 dao:增删改查接口,实现增删改查的具体方法 service:同dao,也是一个接口,一个接口的实现类,方法什么的都跟dao差不多 servlet:新建servlet类,继承HttpServlet类,一个方法建立一个servlet类,根据不同的方法选择使用doGet().doPost()方法 .services()既包含doGet 又包含doPost 新建jsp页面

Mock.js简易教程,脱离后端独立开发,实现增删改查功能

在我们的生产实际中,后端的接口往往是较晚才会出来,并且还要写接口文档,于是我们的前端的许多开发都要等到接口给我们才能进行,这样对于我们前端来说显得十分的被动,于是有没有可以制造假数据来模拟后端接口呢,答案是肯定的.应该有人通过编写json文件来模拟后台数据,但是很局限,比如增删改查这些接口怎么实现呢,于是今天我们来介绍一款非常强大的插件Mock.js,可以非常方便的模拟后端的数据,也可以轻松的实现增删改查这些操作. 1.一个简单的例子: Mock.mock('http://123.com',{