person类属性有Intenger id,String name,Intenger  age,相应的构造方法和set get方法。

package com.xh.tx.dao;

import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.util.Log;

import com.xh.tx.bean.Person;
import com.xh.tx.utils.MySQLiteHelper;

public class PersonDao1
{
private static final String TAG = "PersonDao1";
private MySQLiteHelper helper;

  public PersonDao1(Context context)
  {
    helper = new MySQLiteHelper(context, null, null, -1);//前者创建的时候版本已经固定了,后面的-1没作用,与前面的用Eclipse创建数据库文章相结合
  }
  //增加数据
  public void savePerson(Person p)
  {
    SQLiteDatabase db = helper.getWritableDatabase();
    if(db.isOpen())
    {
      //nullColumnHack 如果数据库里面的name字段设计的时候不允许为空,但是你传递过来的参数是空
      // 如果不设置这个nullColumnHack参数那么就会报错
      // 如果你设置nullColumnHack这个参数的值为name那么不会报错
      ContentValues values = new ContentValues();
      values.put("name", p.getName());
      values.put("age", p.getAge());
      Long id = db.insert("person", null, values);
      Log.d(TAG, "================:" + id);
      db.close();
    }
  }

  //删除数据
  public void deletePerson(Integer id)
  {
    SQLiteDatabase db = helper.getWritableDatabase();
    if(db.isOpen())
    {
      //select * from person where id=? and name = ?;
      String whereClause = "_id=?";
      String[] whereArgs = new String[]{String.valueOf(id)};
      int _id = db.delete("person", whereClause, whereArgs);
      Log.d(TAG, "================:" + _id);
      db.close();
    }
  }

  //修改数据
  public void updatePerson(Person p)
  {
    SQLiteDatabase db = helper.getWritableDatabase();
    if(db.isOpen())
    {
      ContentValues values = new ContentValues();
      values.put("name", "xintx");
      values.put("age", "2");
      String whereClause = "_id=?";
      String[] whereArgs = new String[]{String.valueOf(p.get_id())};
      db.update("peson", values, whereClause, whereArgs);

      db.close();
    }
  }

  //查询单个数据
  public void queryItem(Integer id)
  {
    SQLiteDatabase db = helper.getReadableDatabase();
    if(db.isOpen())
    {
      String[] columns = new String[]{"_id","name","age"};
      String selection = "_id=?";
      String[] selectionArgs = new String[]{String.valueOf(id)};
      String groupBy = null; //按什么什么分组
      String having = null; //如果select里面包含了组函数的时候,不能用where去查询 就只有用having
      String orderBy = null; //按什么排序 order by id desc;

      Cursor cursor = db.query("person", columns, selection, selectionArgs, groupBy, having, orderBy);
      if(null != cursor && cursor.moveToFirst())
      {
        Integer _id = cursor.getInt(0);
        String name = cursor.getString(1);
        Integer age = cursor.getInt(2);
        Log.d(TAG, "_id=" + _id + " name=" + name + " age = " + age);

        cursor.close()

        db.close();
      }
    }
  }

  //查询所有数据

      public List<Person> queryAll() {

      List<Person> list = null;
      db = helper.getReadableDatabase();
      if (db.isOpen()) {
        list = new ArrayList<Person>();
        String[] columns = new String[] { "_id", "name", "age" };
        String selection = null;
        String selectionArgs[] = null;
        String groupBy = null;
        String having = null;
        String orderBy = null;
        Cursor cursor = db.query("person", columns, selection, selectionArgs, groupBy, having, orderBy);
        while (cursor != null && cursor.moveToNext()) {
          Integer _id = cursor.getInt(0);
          String name = cursor.getString(1);
          Integer age = cursor.getInt(2);
          list.add(new Person(_id, name, age));
        }
        cursor.close();
        db.close();
      }
     return list;
   }

}

通过API函数来控制SQLite数据库增删改查的更多相关文章

  1. 通过Sql语句控制SQLite数据库增删改查

    person类属性有Intenger id,String name,Intenger  age,相应的构造方法和set get方法. package com.xh.tx.dao; import jav ...

  2. (转)SQLite数据库增删改查操作

    原文:http://www.cnblogs.com/linjiqin/archive/2011/05/26/2059182.html SQLite数据库增删改查操作 一.使用嵌入式关系型SQLite数 ...

  3. Android SQLite 数据库 增删改查操作

    Android SQLite 数据库 增删改查操作 转载▼ 一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库--SQLite,SQLite3支持NU ...

  4. IOS sqlite数据库增删改查

    1.简单介绍 简单封装sqlite数据库操作类 BaseDB 用于完毕对sqlite的增删改查.使用前先导入libsqlite3.0.dylib库 2.BaseDB.h // // BaseDB.h ...

  5. 使用C#书写SQLite数据库增删改查语句(以及插入byte[]时遇到的问题总结)

    在没有使用SQLite这种轻量级的数据库之前,只使用过Sqlserver2008进行数据的增删改查,公司使用的是大型的ORACLE数据库,还没有真正的会使用它.那时候觉得数据库很庞大,然而遇到SQLi ...

  6. SQLite数据库增删改查操作

    一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库——SQLite,SQLite3支持NULL.INTEGER.REAL(浮点数字).TEXT(字符串 ...

  7. Android SQLite数据库增删改查操作

    一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库——SQLite,SQLite3支持NULL.INTEGER.REAL(浮点数字). TEXT(字符 ...

  8. SQLite数据库增删改查

    一:SQLite数据库简介: SQLite是一种轻量级的关系型数据库,官网:http://www.sqlite.org/. SQLite数据库文件存在于移动设备的一下目录中:data->data ...

  9. 转:ios Sqlite数据库增删改查基本操作

    研究了几天的数据库,终于把它给搞出来了.Sqlite是ios上最常用的数据库之一,大家还是有必要了解一下的.这是仿照网上的一个例子做的,有些部分写的不好,我稍作了修改,以讲解为主,主要让大家能够明白如 ...

随机推荐

  1. Codeforces 626G Raffles 【贪心】【线段树】

    题意: 给n个奖池,t张彩票,q次操作. 每个奖池的奖金为pi. 每个奖池现有的彩票的数量为ai,保证ai>=1: q次操作,每次有两种,第i个奖池的现有彩票数量加一,或减一. 不允许投票的数量 ...

  2. poj 2109 Power of Cryptography

    点击打开链接 Power of Cryptography Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 16388   Ac ...

  3. 扩大View的点击范围

    扩大View的点击范围本人知道的有两种方法,在不影响界面效果的前提下: 1.在View的外面添加一个透明容器 2.就是本文要说的,代码如下 : public void addToParentArea( ...

  4. cocos2d-lua 3.5 ios搭建步骤

    xcode搭建cocos2d-lua是最简单的,不用 配置一系列环境变量,只把xcode安装好就可以 步骤一:去官网下载quick-3.5,然后打开命令行工具 步骤二:cd进入/Users/song/ ...

  5. 三分钟部署Laxcus大数据管理系统

    Laxcus是Laxcus大数据实验室历时五年,全体系自主设计研发的国内首套大数据管理系统.能够支撑百万台级计算机节点,提供EB量级存储和计算能力,兼容SQL和关系数据库.最新的2.x版本已经实现对当 ...

  6. "开发路上踩过的坑要一个个填起来————持续更新······(7月30日)"

    欢迎转载,请注明出处! https://gii16.github.io/learnmore/2016/07/29/problem.html 踩过的坑及解决方案记录在此篇博文中! 个人理解,如有偏颇,欢 ...

  7. Xcode去除某种类型的警告

      首先来看下当有警告时,怎么找到警告类型,在某条警告上,右键—>Reveal in Log     下面 [ ] 中间就是警告信息     去除警告信息的几种方式:   一.使用编译器提供的宏 ...

  8. AJAX(学习笔记一)

    1:什么是AJAX? AJAX是一组英文单词的简写,这组英文单词是 :Asynchronous JavaScript and XML ,翻译成中文的意思是: 异步的JavaScript 和 XML.什 ...

  9. python和php对比

    对php比较熟悉,最近开始学些python,总是搞混,特记录下来,用于熟悉python:1.python数组和php不同,php相对简单统一,即array(包括普通数组和关联数组两部分),python ...

  10. LoadRunner用户行为模拟器 《第三篇》

    用户行为模拟器简称VU,VU通过运行VU脚本模拟了用户对软件的操作行为.VU是基于网络协议的.很明显,被测服务器是通过各种各样的网络协议与客户端打交道的.VU要“骗过”被测服务器,当然就要遵守这些协议 ...