Android下数据库第一种方式增删改查

    1.创建一个帮助类的对象,调用getReadableDatabase方法,返回一个SqliteDatebase对象



    2.使用SqliteDatebase对象调用execSql()做增删改,调用rawQuery方法做查询。


    特点:增删改没有返回值,不能判断sql语句是否执行成功。sql语句手动写,容易写错







    private MySqliteOpenHelper mySqliteOpenHelper;

    public InfoDao(Context context){

        //创建一个帮助类对象

        mySqliteOpenHelper = new MySqliteOpenHelper(context);



        

    }



    public void add(InfoBean bean){



        //执行sql语句需要sqliteDatabase对象

        //调用getReadableDatabase方法,来初始化数据库的创建

        SQLiteDatabase     db = mySqliteOpenHelper.getReadableDatabase();

        //sql:sql语句,  bindArgs:sql语句中占位符的值

        db.execSQL("insert into info(name,phone) values(?,?);", new Object[]{bean.name,bean.phone});

        //关闭数据库对象

        db.close();

    }



    public void del(String name){





        //执行sql语句需要sqliteDatabase对象

        //调用getReadableDatabase方法,来初始化数据库的创建

        SQLiteDatabase db = mySqliteOpenHelper.getReadableDatabase();

        //sql:sql语句,  bindArgs:sql语句中占位符的值

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

        //关闭数据库对象

        db.close();



    }

    public void update(InfoBean bean){



        //执行sql语句需要sqliteDatabase对象

        //调用getReadableDatabase方法,来初始化数据库的创建

        SQLiteDatabase db = mySqliteOpenHelper.getReadableDatabase();

        //sql:sql语句,  bindArgs:sql语句中占位符的值

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

        //关闭数据库对象

        db.close();



    }

    public void query(String name){

        

        //执行sql语句需要sqliteDatabase对象

        //调用getReadableDatabase方法,来初始化数据库的创建

        SQLiteDatabase db = mySqliteOpenHelper.getReadableDatabase();

        //sql:sql语句,  selectionArgs:查询条件占位符的值,返回一个cursor对象

        Cursor cursor = db.rawQuery("select _id, name,phone from info where name = ?", new String []{name});

        //解析Cursor中的数据

        if(cursor != null && cursor.getCount() >0){//判断cursor中是否存在数据

            

            //循环遍历结果集,获取每一行的内容

            while(cursor.moveToNext()){//条件,游标能否定位到下一行

                //获取数据

                int id = cursor.getInt(0);

                String name_str = cursor.getString(1);

                String phone = cursor.getString(2);

                System.out.println("_id:"+id+";name:"+name_str+";phone:"+phone);

            }

            cursor.close();//关闭结果集

            

        }

        //关闭数据库对象

        db.close();



    }

Android下另外一种增删改查方式 

    

    1.创建一个帮助类的对象,调用getReadableDatabase方法,返回一个SqliteDatebase对象



    2.使用SqliteDatebase对象调用insert,update,delete ,query方法做增删改查。


     特点:增删改有了返回值,可以判断sql语句是否执行成功,但是查询不够灵活,不能做多表查询。所以在公司一般人增删改喜欢用第二种方式,查询用第一种方式。


    private MySqliteOpenHelper mySqliteOpenHelper;

    public InfoDao(Context context){

        //创建一个帮助类对象

        mySqliteOpenHelper = new MySqliteOpenHelper(context);

    }



    public boolean add(InfoBean bean){



        //执行sql语句需要sqliteDatabase对象

        //调用getReadableDatabase方法,来初始化数据库的创建

        SQLiteDatabase     db = mySqliteOpenHelper.getReadableDatabase();

        

        

        ContentValues values = new ContentValues();//是用map封装的对象,用来存放值

        values.put("name", bean.name);

        values.put("phone", bean.phone);

        

        //table: 表名 , nullColumnHack:可以为空,标示添加一个空行, values:数据一行的值 , 返回值:代表添加这个新行的Id ,-1代表添加失败

        long result = db.insert("info", null, values);//底层是在拼装sql语句

    

        //关闭数据库对象

        db.close();

        

        if(result != -1){//-1代表添加失败

            return true;

        }else{

            return false;

        }

    }



    public int del(String name){



        //执行sql语句需要sqliteDatabase对象

        //调用getReadableDatabase方法,来初始化数据库的创建

        SQLiteDatabase db = mySqliteOpenHelper.getReadableDatabase();

        

        //table :表名, whereClause: 删除条件, whereArgs:条件的占位符的参数 ; 返回值:成功删除多少行

        int result = db.delete("info", "name = ?", new String[]{name});

        //关闭数据库对象

        db.close();

        

        return result;



    }

    public int update(InfoBean bean){



        //执行sql语句需要sqliteDatabase对象

        //调用getReadableDatabase方法,来初始化数据库的创建

        SQLiteDatabase db = mySqliteOpenHelper.getReadableDatabase();

        ContentValues values = new ContentValues();//是用map封装的对象,用来存放值

        values.put("phone", bean.phone);

        //table:表名, values:更新的值, whereClause:更新的条件, whereArgs:更新条件的占位符的值,返回值:成功修改多少行

        int result = db.update("info", values, "name = ?", new String[]{bean.name});

        //关闭数据库对象

        db.close();

        return result;



    }

    public void query(String name){

    

        //执行sql语句需要sqliteDatabase对象

        //调用getReadableDatabase方法,来初始化数据库的创建

        SQLiteDatabase db = mySqliteOpenHelper.getReadableDatabase();

        

        //table:表名, columns:查询的列名,如果null代表查询所有列; selection:查询条件, selectionArgs:条件占位符的参数值,

        //groupBy:按什么字段分组, having:分组的条件, orderBy:按什么字段排序

        Cursor cursor = db.query("info", new String[]{"_id","name","phone"}, "name = ?", new String[]{name}, null, null, "_id desc");

        //解析Cursor中的数据

        if(cursor != null && cursor.getCount() >0){//判断cursor中是否存在数据

            

            //循环遍历结果集,获取每一行的内容

            while(cursor.moveToNext()){//条件,游标能否定位到下一行

                //获取数据

                int id = cursor.getInt(0);

                String name_str = cursor.getString(1);

                String phone = cursor.getString(2);

                System.out.println("_id:"+id+";name:"+name_str+";phone:"+phone);

                

                

            }

            cursor.close();//关闭结果集

            

        }

        //关闭数据库对象

        db.close();



    }

Android下数据库操作——增删改查的更多相关文章

  1. Android学习---数据库的增删改查(sqlite CRUD)

    上一篇文章介绍了sqlite数据库的创建,以及数据的访问,本文将主要介绍数据库的增删改查. 下面直接看代码: MyDBHelper.java(创建数据库,添加一列phone) package com. ...

  2. [Android] SQLite数据库之增删改查基础操作

        在编程中常常会遇到数据库的操作,而Android系统内置了SQLite,它是一款轻型数据库,遵守事务ACID的关系型数据库管理系统,它占用的资源非常低,可以支持Windows/Linux/Un ...

  3. Yii数据库操作增删改查-[增加\查询\更新\删除 AR模式]

    在Yii的开发中常常需要去使用Yii的增删改查方法,这些方法又可以多次变化和组合,带来全方位的实现对数据库的处理,下面对这些方法做一些简单的整理和梳理,有遗漏或是BUG,敬请指出.灰常感谢!!! 一. ...

  4. Django数据库操作(增删改查)

    Django数据库操作(增删改查) 创建数据库中的一个表 class Business(models.Model): #自动创建ID列 caption = models.CharField(max_l ...

  5. spring框架学习之--数据库操作增删改查

    基于spring的NamedParameterJdbcTemplate操作数据库 首先在 resources 文件夹下添加数据库配置文件jdbc.properties 配置常用的数据库信息 consu ...

  6. 安卓 Android 简单数据库(增删改查)

    <Button android:id="@+id/delete_btn" android:layout_width="wrap_content" andr ...

  7. SpringBoot 数据库操作 增删改查

    1.pom添加依赖 <!--数据库相关配置--> <dependency> <groupId>org.springframework.boot</groupI ...

  8. Yii2.0数据库操作增删改查详解

    1.简单查询: one(): 根据查询结果返回查询的第一条记录. all(): 根据查询结果返回所有记录. count(): 返回记录的数量. sum(): 返回指定列的总数. average():  ...

  9. django数据库操作-增删改查-多对多关系以及一对多(外键)关系

    一.一对多(外键) 例子:一个作者对应多本书,一本书只有一个作者 model代码: class Person(models.Model); name = models.CharField('作者姓名' ...

随机推荐

  1. Spring企业级程序设计 • 【第7章 Spring框架整合】

    全部章节   >>>> 本章目录 7.1 模型数据解析及控制器返回值 7.1.1 SSM框架环境搭建 7.1.1 ModelAndView多种用法 7.1.2 整合MyBati ...

  2. 图像数据到网格数据-3——实现Cuberille算法

    前言 这是本博客网格生成算法系列的第三篇,第一篇里面介绍了最为流行的MarchingCubes算法,第二篇中使用新三角形表来对MC算法进行了简化改进,形成了SMC算法.而这篇将介绍一种新的不同与MC算 ...

  3. [学习笔记] Oracle创建用户、分配权限、设置角色

    创建用户 create user student --用户名 identified by "123456" --密码 default tablespace USERS --表空间名 ...

  4. xftp 6 的 使用

    1.前言 xftp是个向云服务器linux系统传输文件的软件,装载在window系统 简单易用 2.下载 官方下载地址:https://www.netsarang.com/zh/xftp-downlo ...

  5. C#进阶——从应用上理解异步编程的作用(async / await)

    欢迎来到学习摆脱又加深内卷篇 下面是学习异步编程的应用 1.首先,我们建一个winfrom的项目,界面如下: 2.然后先写一个耗时函数: /// <summary> /// 耗时工作 // ...

  6. 关于APP设计规范和一些图层命名

    首先,本人大学计算机专业出身,学过编程,工作的时候做过 产品经理,设计师,前端工程师,对工作的流程都有一些见解. 现在主攻前端工程师,做Web APP.今天收到设计师的设计稿,一看图层分类,这让我感觉 ...

  7. kibana7.x安装配置操作elasticsearch

    什么是Kibana? Kibana是一个基于Node.js的Elasticsearch索引库数据统计工具,可以利用Elasticsearch的聚合功能,生成各种图表,如柱形图,线状图,饼图等. 而且还 ...

  8. 数组内sizeof与strlen的区别

    1.数组在内存中是连续存放的,地址呈4个字节递增 2.数组的定义需要初始化,否则输出会已随机值输出 3.strlen()和sizeof()之间无关联:strlen():是求字符串长度的----只能针对 ...

  9. 《剑指offer》面试题11. 旋转数组的最小数字

    问题描述 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转.输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素.例如,数组 [3,4,5,1,2] 为 [1,2,3,4,5] 的 ...

  10. 《剑指offer》面试题67. 把字符串转换成整数

    问题描述 写一个函数 StrToInt,实现把字符串转换成整数这个功能.不能使用 atoi 或者其他类似的库函数.   首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止. ...