android sqlite 示例,android SQLite数据库使用示例

数据库的操作,需用到数据库类SQLiteDatabase,重写管理员类SQLiteOpenHelper,用Cursor查询数据

一、操作数据库的辅助类,包含打开、关闭、增删改查方法

//自定义的数据库的接口,其中包含SQLiteHelper

public class NotesDbAdapter

{

//创建数据库所需语句及相关字符串

private static final String DATABASE_NAME = "note.db";

private static final int DATABASE_VERSION = 1;

private static final String DATABASE_TABLE = "note";

private static final String DATABASE_CREATE =

"create table note("

+"_id INTEGER PRIMARY KEY,"

+"note TEXT,"

+"date TEXT,"

+"created INTEGER,"

+"modified INTEGER"

+");";

//数据库对象

private SQLiteDatabase db;

//定义数据库管理员类

private static class DatabaseHelper extends

SQLiteOpenHelper

{

public DatabaseHelper(Context context) {

super(context, DATABASE_NAME, null, DATABASE_VERSION);

// TODO Auto-generated constructor stub

}

@Override

public void onCreate(SQLiteDatabase db) {

// TODO Auto-generated method stub

db.execSQL(DATABASE_CREATE);

}

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int

newVersion) {

// TODO Auto-generated method stub

db.execSQL("DROP TABLE IF EXISTS "+DATABASE_TABLE);

onCreate(db);

}

}

//抽象界面

private Context mCtx =

null;

//数据库管理员对象

private DatabaseHelper dbHelper ;

//数据库各列名称

public static final String KEY_ROWID = "_id";

public static final String KEY_NOTE = "note";

public static final String KEY_DATE = "date";

public static final String KEY_CREATED = "created";

public NotesDbAdapter(Context ctx) {

this.mCtx = ctx;

}

//打开数据库

public NotesDbAdapter open () throws SQLException {

dbHelper = new DatabaseHelper(mCtx);

db = dbHelper.getWritableDatabase();

return this;

}

//关闭数据库

public void close() {

dbHelper.close();

}

//查询所有项目,返回一个Cursor

public Cursor getall()

{

return db.query(DATABASE_TABLE,

new String[] {KEY_ROWID, KEY_NOTE, KEY_DATE,

KEY_CREATED},

null, null, null, null, null);

}

// 新增一项

public long create(String Note,String mDate) {

Date now = new Date();

ContentValues args = new ContentValues();

args.put(KEY_NOTE, Note);

args.put(KEY_DATE, mDate);

args.put(KEY_CREATED, now.getTime());

return db.insert(DATABASE_TABLE, null, args);

}

//删除一项

public boolean delete(long rowId) {

return db.delete(DATABASE_TABLE, KEY_ROWID + "=" + rowId, null)

> 0;

}

//查询一项

public Cursor get(long rowId) throws SQLException

{

Cursor mCursor = db.query(true,

DATABASE_TABLE,

new String[] {KEY_ROWID, KEY_NOTE, KEY_DATE,

KEY_CREATED},

KEY_ROWID + "=" + rowId,

null, null, null, null, null);

if (mCursor != null) {

mCursor.moveToFirst();

}

return mCursor;

}

//修改一项

public boolean update(long rowId, String note,String

date)

{

ContentValues args = new ContentValues();

args.put(KEY_NOTE, note);

args.put(KEY_DATE, date);

return db.update(DATABASE_TABLE, args, KEY_ROWID + "=" + rowId,

null) > 0;

}

}

二、在主类中通过写好的辅助类操作数据库

private NotesDbAdapter mDbHelper;

private Cursor mNotesCursor;

//用自定义的数据库接口提供的方法打开数据库

mDbHelper = new NotesDbAdapter(this);

mDbHelper.open();

//获取cursor,当需要表中数据时再通过cursor访问

mNotesCursor = mDbHelper.getall();

startManagingCursor(mNotesCursor);

//实例化各list存储数据库各列内容

aryListNoteContent=new

ArrayList();

aryListNoteDate=new

ArrayList();

aryListNoteID=new

ArrayList();

linkListNoteIcon=new

LinkedList();

//先用Cursor获取内容,装入ArrayList,最后关闭cursor

try

{

if(mNotesCursor.moveToFirst())

{

do

{

//获取数据库rowID,以便操作数据库

String noteId=mNotesCursor.getString(0);

String noteContent=mNotesCursor.getString(1);

String noteDate=mNotesCursor.getString(2);

aryListNoteID.add(noteId);

aryListNoteContent.add(noteContent);

aryListNoteDate.add(noteDate);

linkListNoteIcon.add(getApplicationContext().getResources().getDrawable(R.drawable.icon));

}while(mNotesCursor.moveToNext());

}

} catch (Exception e) {

// TODO Auto-generated catch block

e.printStackTrace();

}finally

{

mNotesCursor.close();

}

//删除一项

String RowId=aryListNoteID.get(info.position);

mDbHelper.delete(Long.parseLong(RowId));

//新增一项

mDbHelper.create(String,String);

//查询一项

//若该行id不为空,返回该行cursor,根据cursor读取内容,读取完毕关闭cursor

if (mRowId != null) {

Cursor cursor = mDbHelper.get(mRowId);

startManagingCursor(cursor);

try

{

mEditText.setText(cursor.getString(

cursor.getColumnIndexOrThrow(NotesDbAdapter.KEY_NOTE)

));

} catch (IllegalArgumentExceptione) {

// TODO Auto-generated catch block

e.printStackTrace();

}finally

{

cursor.close();

}

}

//修改一项

mDbHelper.update(mRowId, String,String);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/566245.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++虚基类

C虚基类 1.1虚基类的作用:如果一个派生类有多个直接基类,而且这些直接基类又有一个共同的基类,则在最终的派生类中会保留该间接共同基类的多份同名成员。所以为了解决这个问题,C提供虚基类的方法,使得在继承间接共同基…

android清除图案锁 位置,安卓手机清除锁屏密码、锁屏图案的教程

来源:安卓网2014-01-21/12:15本文分享一个安卓手机清除锁屏密码以及锁屏图案的几种方法和详细教程。如果锁屏密码、或者图形锁屏密码忘记了怎么办,怎么清除呢?下面小编整理了3种安卓手机清除锁屏图案密码的方法。↓↓↓准备工作:1.确保已经安…

C++多态性

C多态 1.1多态性(polymorphism)是面向对象程序设计的一个重要特征。1.2从系统实现的角度看,多态性分两类:静态多态性与动态多态性。静态多态性是通过函数重载(运算符重载也是函数重载)来实现的。它又称为编译时多态。动态多样性是在程序运行过程中才动态…

ue4 android vulkan,在Android用vulkan完成蓝绿幕扣像

效果图(1080P处理)因为摄像头开启自动曝光,画面变动时,亮度变化导致扣像在转动时如上。这个demo主要测试二点,一是测试ndk camera集成效果,二是本项目对接外部实现的vulkan层是否方便,用于以后移植GPUImage里的实现。我简化了在an…

C++静态关联与动态关联

1.1确认具体对象的过程叫关联(binding),在这里指把一个函数与类对象捆绑在一起,建立关联。 1.2什么是静态关联? 函数重载和通过对象名调用的虚函数,在编译时即可确定其调用的虚函数属于哪一个类,其过程称为静态关联&…

html5 规定输入字段,HTML5 Input属性详解

本篇教程探讨了HTML5 Input属性详解&#xff0c;希望阅读本篇文章以后大家有所收获&#xff0c;帮助大家HTML5CSS3从入门到精通 。<value 属性value 属性规定输入字段的初始值&#xff1a;readonly 属性readonly 属性规定输入字段为只读(不能修改)&#xff1a;readonly 属性…

html5程序自动登录,Jtro的技术分享:网页调起unity的exe程序并自动登录

思路是这样&#xff1a;通过一个额外的exe文件来实现登录&#xff0c;并保存一个token文件&#xff0c;然后在unity的项目提交数据的时候读取这个token向服务器发送数据。下面是具体的方法&#xff1a;s这个需要用到WPF来编写&#xff0c;首先打开VS2017&#xff0c;选择创建WP…

C++纯虚函数与抽象类

纯虚函数 1.1纯虚函数是在声明虚函数时被“初始化”为0的函数。声明纯虚函数的一般形式为&#xff1a;virtual 函数类型 函数名 (参数列表) 0;如 virtual float area() const 0;1.2纯虚函数没有函数体&#xff0c;而且这是一个声明语句后面应有分号。1.3纯虚函数最后面的“0”并…

html 图片防盗链,【反防盗链】介绍一个对付图片防盗链的方法

悲催的声明&#xff1a;由于腾讯也采用了防盗链技术&#xff0c;本文方法已经失效了&#xff01;当我们想在文章里引用某张图片时&#xff0c;如果对方设置了防盗链&#xff0c;我们看到的将是404或forbidden或其他图片&#xff0c;而不是想要的那张图片&#xff0c;为此&#…

C++文件操作与文件流

文件的概念 1.1文件是程序设计中一个重要的概念&#xff0c;所谓“文件”&#xff0c;一般指存储在外部介质上数据的集合。1.2外存文件包括磁盘文件&#xff0c;光盘文件&#xff0c;和U盘文件。1.3对用户来说常用的文件类型有两大类&#xff0c;一类是程序文件&#xff0c;如C…

html字体阴影怎么设置6,css怎么设置字体阴影

css设置字体阴影的方法&#xff1a;使用代码【text-shadow:3px 3px 3px #00f;】&#xff0c;【text-shadow】属性应用于阴影文本&#xff0c;语法为【text-shadow: h-shadow v-shadow blur color;】。本教程操作环境&#xff1a;windows10系统、css3版&#xff0c;该方法适用于…

PCL入门

pcl的入门 本博客主要是对外文的翻译&#xff0c;及其他资料的一些整理。 pcl 分割成好几个模块的库 Filters(滤波器) Features(特征) Keypoints(关键点) Registration(注册) KdTree:k-dimension tree(k维的树) OcTree(八叉树) Segmetation(分割) Sample Consensus(采…

台式电脑怎么看计算机型号,怎么查看台式机的型号

电脑配置有很多&#xff0c;很多人在买电脑总是觉得配置和商家说的不是一样的&#xff0c;下面就让小编教大家台式机怎么查看型号和配置。查看台式机型号和配置的方法金山卫士查看首先打开自己电脑的安全卫士软件&#xff0c;其实卫士都有这种功能的&#xff0c;我这里实用的是…

pcl的初步使用(ROS)

ROS里面已经预装好了pcl&#xff0c;和一些与pcl之间的转换&#xff0c;我们接下来看看如何在ros里面使用pcl.。 总的来说&#xff0c;PCL包含了一个很重要得到数据结构&#xff0c;叫PointCloud&#xff0c;这是一个模板类&#xff0c;把点的类型作为模板参数。 下面是最重要…

四川大学计算机学硕分数线,川大计算机考研分数线

川大计算机考研分数线&#xff1f;2016高考志愿填写&#xff0c;高考考生家长有开端着手预备吗 厚学网收拾了对于普通高校招生填写志愿的有关诀窍&#xff0c;供考生和家长参阅。绝密:高考填报志愿有技巧!志愿填报需要注意的细节问题&#xff1a;语种有限制在咱们要学习的外语语…

pcl里面的3D特征

我这里不介绍pcl里面的类的命名规范&#xff0c;及点的类型。为什么呢?pcl里面类的命名规范&#xff0c;比较繁琐&#xff0c;而且主要是针对要对pcl这个库要开源的人士&#xff0c;而pcl里面的点的类型太多&#xff0c;足够满足你的要求。所以我们要走一条具有中国特色的pcl主…

html本地缓存未查看信息,不同用户看到了相同的信息-一次web系统缓存问题的解决...

最近负责的系统总是出现奇怪的缓存问题&#xff0c;在这里简单记录一下碰到的问题和踩到的坑。问题&#xff1a;用户反映使用不同账号A&#xff0c;B登录时&#xff0c;都出现账号A的页面信息(未邮寄账单提示)。如下所示&#xff1a;图1&#xff1a;未邮寄账单提示一 session缓…

pcl里面的法线估计

法线估计是一个很重要的特征&#xff0c;常常在被使用在很多计算机视觉的应用里面&#xff0c;比如可以用来推出光源的位置&#xff0c;通过阴影与其他视觉影响。 给一个几何表面&#xff0c;去推断给定点的法线方向&#xff0c;即垂直向量的方向往往是不容易的。然而&#xf…

pcl通过积分图来进行法线预测

首先&#xff0c;我们来看一下什么是积分图&#xff0c;我查了一下wiki&#xff0c;发现它的定义是这样的。 A summed area table is a data structure and algorithm for quickly and efficiently generating the sum of values in a rectangular subset of a grid. In the i…