SQLite在Android程序中的使用方法,SQLite的增删查改方法
Sqlite:
1.一款用来实现本地数据存储的轻量级数据管理工具,是众多用来实现数据库管理的工具之一。
2.Android已经将SQLite的代码功能吸收在它的系统中,我们可以直接在Android程序中使用SQLite的语句来创建数据库,并实现数据库的增删查改
SQLite的简单使用方法:
如何获得一个数据库的class模板,并设定数据库里的数据结构:
自己新建一个类,继承SQLiteOpenHelper,并重写构造方法,oncreate(),onUpgrade()
自定义类的代码实现方法和构造方法的原始模板解析:
public class Database extends SQLiteOpenHelper {
public Database(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
super(context, name, factory, version);
//Context
//String name "创建数据库的名字"
//SQLiteDatabase.CursorFactory factory "在数据库中查找是的光标(相当于数组中的下标)"
// int Version "数据库的版本信息"
} @Override
public void onCreate(SQLiteDatabase db) {
//在创建数据库的时候调用
} @Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
//每次启动数据库会检测数据库的版本信息,如果版本有变动就会执行此方法
}
}
用来实现数据库的自定义类的具体代码:
public class Data extends SQLiteOpenHelper
public Data(Context context) { //简单起见,直接指定了数据库的名字为DATA,光标信息为null,版本为1
//所以在自定义的类的构造方法中只有Context参数
//在调用父类构造方法的时候,给定固定的参数来简化数据库创建
super(context,"DATA", null, 1);
} @Override
public void onCreate(SQLiteDatabase db) {
//创建数据库建构内容的语句,具体解析在下文整理
db.execSQL("CREATE TABLE user("+
"_id INTEGER PRIMARY KEY AUTOINCREMENT," +
"name TEXT DEFAULT \"\"," +
"sex TEXT DEFAULT \"\")");
//以上的语句给出了一个名为user的数据库结构对象,里面包含INTERGER类型的_id信息,并自增
//TEXT数据类型的name
//text数据类型的sex
} @Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
//由于给出了版本参数信息为固定的1,所以不会执行数据库更新操作
}
}
自己重写了数据库的模板后,如何实现数据库的使用和管理:
1.利用自定义的数据库类来新建一个数据库对象,
2.再通过新建的数据库得到可读的数据库对象和可写的数据库对象,
新建ContentValues对象向获得的可写数据库中添加内容,实现代码:
Private Data data = new Data(this);
private SQLiteDatabase dbWriter = db.getWritableDatabase();
ContentValues cv = new ContentValues();
cv.put("name",etName.getText().toString());
cv.put("sex",etSex.getText().toString());
//insert方法的三个参数的意义分别是:插入数据表的名称,插入数据表的位置信息,插入的对象
dbWriter.insert("user",null,cv);
//每次使用完数据库之后,记得关闭数据库,类似I/O的关闭
dbWrite.close();
注:位置信息这里填的是null,具体运行方式尚不清楚,但看到这里的时候,有时间去研究一下
通过获得的可读数据库对象,在目标数据库中进行查找的方法实现代码:
SQLiteDatabase DB = db.getReadableDatabase();
//新建一个光标对象,指明在“user”数据表中查找,后面的参数是一系列限制条件,
//全部为null意味输出所有user中的数据
Cursor c = DB.query("user",null,null,null,null,null,null);
//当光标仍然能够向下一行运行的时候,执行数据库的读取操作
while (c.moveToNext()){
String name=c.getString(c.getColumnIndex("name"));
String sex=c.getString(c.getColumnIndex("sex"));
Toast.makeText(getApplicationContext(),name+"--"+sex,Toast.LENGTH_SHORT).show();
}
SQLite在Android程序中的使用方法,SQLite的增删查改方法的更多相关文章
- 在Android程序中使用已有的SQLite数据库
已经将这篇文章迁移至 Code问答,你也能够到这里查看这篇文章,请多多关注我的新技术博客CodeWenDa.com 在中文搜索中,没有找到一篇比較好的关于怎样在Android应用中使用自己事先创建好的 ...
- SSH框架的多表查询(方法二)增删查改
必须声明本文章==>http://www.cnblogs.com/zhu520/p/7773133.html 一:在前一个方法(http://www.cnblogs.com/zhu520/p ...
- python下sqlite增删查改方法(转)
sqlite读写 #coding=utf-8 import sqlite3 import os #创建数据库和游标 if os.path.exists(' test.db'): conn=sqli ...
- 如何在Vue中使用Mockjs模拟数据的增删查改
之前一直使用json-server在前端开发时,搭建本地数据接口测试,但有时又需要将做好的项目放于 github page上做项目演示.在本地时,json server很好使用,但一旦放在github ...
- 6.在MVC中使用泛型仓储模式和依赖注入实现增删查改
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-the-generic-repository-pat ...
- 4.在MVC中使用仓储模式进行增删查改
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-using-the-repository-pattern-in-mvc/ 系列目录: ...
- 5.在MVC中使用泛型仓储模式和工作单元来进行增删查改
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-the-generic-repository-pat ...
- 在MVC中使用泛型仓储模式和工作单元来进行增删查改
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-the-generic-repository-pat ...
- 在MVC中使用泛型仓储模式和依赖注入实现增删查改
标签: 原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-the-generic-repository ...
随机推荐
- 北大poj- 1006
生理周期 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 133189 Accepted: 42577 Descripti ...
- FCC JS基础算法题(2):Check for Palindromes(检查回文字符串)
题目描述: 如果给定的字符串是回文,返回true,反之,返回false.如果一个字符串忽略标点符号.大小写和空格,正着读和反着读一模一样,那么这个字符串就是palindrome(回文).注意你需要去掉 ...
- Fedora 23 U盘启动出现“Failed to load ldlinux.c32”解决 ZT
利用UltraISO制作了Fedora 23的U盘启动,开机F12键USB启动时出现 1 2 Failed to load ldlinux.c32 Boot failed: please chan ...
- 改善Python程序的条条建议
1:引论 建议1.理解Pythonic概念—-详见Python中的<Python之禅> 建议2.编写Pythonic代码 避免不规范代码,比如只用大小写区分变量.使用容易混淆的变量名. ...
- React Native 调用 Web3(1.x) 的正确姿势
1 创建项目 react-native init lm1 cd lm1 2 安装依赖包 yarn add node-libs-browser 3 创建 rn-cli.config.js 脚本 cons ...
- Python学习笔记第二十七周(Bootstrap)
目录: 全局样式 一.栅格系统 二.表单 三.按钮 四.导航 五.按钮组 六.面板 七.表格 八.分页 九.排版 十.图片 十一.辅助类 十二.响应式工具 组件 内容: 前言: 首先通过https: ...
- JavaBasic_11
Object默认的实现是比较对象的地址 Object默认的实现是比较对象的地址局部内部类 局部位置内部类:局部是指方法体中 1.可以直接访问外部类的成员(这个特征是所有内部类所共有) 2.可以创建内部 ...
- python 的排名,已经python的简单介绍
我在今天看了一篇文章,是简书的全网程序猿写的,Java已经退出神坛,python稳居第一. python是由龟叔写的,它在英文的意思是蟒蛇. 根据编程语言流行指数排行榜2019年2月的榜单 据了解,目 ...
- 《从Lucene到Elasticsearch:全文检索实战》学习笔记三
今天我给大家讲讲倒排索引. 索引是构成搜索引擎的核心技术之一,它在日常生活中是非常常见的,比如我看一本书的时候,我首先会看书的目录,通过目录可以快速定位到具体章节的页码,加快对内容的查询速度. 文档通 ...
- kafka-producer kerberos 原理和配置
kerberos简单介绍 kerberos这一名词来源于希腊神话“三个头的狗---地狱之门守护者”后来沿用作为安全认证的概念,该系统设计上 采用客户端/服务器结构与DES(Data Encryptio ...