Android记事本开发之SQLite数据库实现

package com.jk.service;

/**
 * 完成数据库的创建和版本更新
 */
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;

public class DbHelper extends SQLiteOpenHelper {
	public DbHelper(Context context, String name, CursorFactory factory,int version) {
		super(context, name, factory, version);
	}

	public DbHelper(Context context) {
		super(context, "diary.db",null,1);
	}

	@Override
	public void onCreate(SQLiteDatabase db) {
		String sql = "CREATE TABLE Diary "
			+ "(diaryId integer primary key autoincrement, title varchar(20),body varchar(1000),time varchar(40))";
	    db.execSQL(sql);
	}

	@Override
	public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
		//String sql="ALTER TABLE diary ADD body varchar(1000) null";
       //db.execSQL(sql);
		System.out.println("DataBase Updated!!");
	}

}
package com.jk.service;
import com.jk.Diary;
import java.util.ArrayList;
import java.util.List;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;

/**
 * 完成对数据库的增删改查操作
 * @author jkxqj
 */
public class DiaryAdapter {
	private DbHelper dbOpenHelper;

	 public DiaryAdapter(Context context) {
		 dbOpenHelper = new DbHelper(context);
		}

	 public void save(Diary diary) {

           /*
            getWritableDatabase和getReadableDatabase()方法在磁盘空间没满的情况下一样
	    其中getWritableDatabase() 方法以读写方式打开数据库,一旦数据库的磁盘空间满了,
	    数据库就只能读而不能写,倘若使用的是getWritableDatabase() 方法就会出错。
	    getReadableDatabase()方法则是先以读写方式打开数据库,如果数据库的磁盘空间满了,
	    就会打开失败,当打开失败后会继续尝试以只读方式打开数据库。如果该问题成功解决,
	    则只读数据库对象就会关闭,然后返回一个可读写的数据库对象。
	 */

			SQLiteDatabase db = dbOpenHelper.getWritableDatabase();

			/* SQLiteDatabase db2=dbOpenHelper.getWritableDatabase(); */// db==db2

			String sql = "insert into Diary(title,body,time) values(?,?,?)";   // 防止潜在 的bug
			db.execSQL(sql, new Object[] { diary.getTitle(), diary.getBody(),diary.getTime()});
			db.close();
		}

		public void update(Diary diary) {
			SQLiteDatabase db = dbOpenHelper.getWritableDatabase();
			String sql = "update Diary set title=?,body=? where diaryId=?";
			db.execSQL(sql, new Object[] { diary.getTitle(), diary.getBody(),diary.getId() });
			db.close();
		}

		public void delete(Integer id) {
			SQLiteDatabase db = dbOpenHelper.getWritableDatabase();
			String sql = "delete from Diary where diaryId=?";
			db.execSQL(sql, new Object[] { id });
			db.close();
		}

		public Diary find(Integer id) {
			SQLiteDatabase db = dbOpenHelper.getReadableDatabase();
			String sql = "select * from Diary where diaryId=?";
			Cursor cursor = db.rawQuery(sql, new String[] { id.toString() });
			if (cursor.moveToFirst()) {     //将游标移到第一条记录,若成功说明存在记录
				int diaryId = cursor.getInt(cursor.getColumnIndex("diaryId"));
				String title = cursor.getString(cursor.getColumnIndex("title"));
				String body = cursor.getString(cursor.getColumnIndex("body"));
				String time = cursor.getString(cursor.getColumnIndex("time"));
				return new Diary(diaryId, title, body,time);
			}
			return null;
		}

		public List<Diary> getScrollData(int offset, int maxResult) {
			List<Diary> Diarys = new ArrayList<Diary>();
			SQLiteDatabase db = dbOpenHelper.getReadableDatabase();
			// offset指偏移量,maxResult指最大结果集
			String sql = "select * from Diary limit ?,?";
			Cursor cursor = db.rawQuery(sql, new String[] { String.valueOf(offset),
					String.valueOf(maxResult) });
			while (cursor.moveToNext()) {//游标移到下一个说明数据没读完
				int diaryId = cursor.getInt(cursor.getColumnIndex("diaryId"));
				String title = cursor.getString(cursor.getColumnIndex("title"));
				String body = cursor.getString(cursor.getColumnIndex("body"));
				String time = cursor.getString(cursor.getColumnIndex("time"));
				Diarys.add(new Diary(diaryId, title, body,time));
			}
			db.close();
			cursor.close();
			return Diarys;
		}

		public Cursor getCursorScrollData(int offset, int maxResult) {
			SQLiteDatabase db = dbOpenHelper.getReadableDatabase();
			// offset指偏移量,maxResult指最大结果集
			String sql = "select diaryId as _id,title, body,time from Diary limit ?,?";//SimpleCursorAdapter需要有_id这个字段
			Cursor cursor = db.rawQuery(sql, new String[] { String.valueOf(offset),String.valueOf(maxResult) });
			return cursor;
		}

		public long getCount() {
			SQLiteDatabase db = dbOpenHelper.getWritableDatabase();
			String sql = "select count(*) from Diary";
			Cursor cursor = db.rawQuery(sql,null);
			cursor.moveToFirst();
			db.close();
			long i = cursor.getLong(0);
			cursor.close();
			return i;
		}
}
时间: 2024-10-18 16:26:05

Android记事本开发之SQLite数据库实现的相关文章

android开发之sqlite数据库升级

转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/39151617 在上一篇文章中,我们学习了LitePal的基本用法,体验了使用框架来进行创建表操作的便利.然而大家都知道,创建表只是数据库操作中最基本的一步而已,我们在一开始创建的表结构,随着需求的变更,到了后期是极有可能需要修改的.因此,升级表的操作对于任何一个项目也是至关重要的,那么今天我们就一起来学习一下,在Android传统开发当中升级表的方式,以及使用LitePal来进行

Android安全开发之Provider组件安全

Android安全开发之Provider组件安全 作者:伊樵.呆狐@阿里聚安全 一.Content Provider组件简介 Content Provider组件是Android应用的重要组件之一,管理对数据的访问,主要用于不同的应用程序之间实现数据共享的功能.Content Provider的数据源不止包括SQLite数据库,还可以是文件数据.通过将数据储存层和应用层分离,Content Provider为各种数据源提供了一个通用的接口. 创建一个自己的Content Provider需要继承

Android API开发之SMS短信服务处理和获取联系人的方法_Android

本文实例讲述了Android API开发之SMS短信服务处理和获取联系人的方法.分享给大家供大家参考,具体如下: Android API支持开发可以发送和接收SMS消息的应用程序.目前我们开发过程中使用的Android模拟器还不支持发送SMS,但它可以接收SMS.现在我们来探索一下Android对SMS的支持,我们将会构建一个小小的应用程序来监听移动设备(或模拟器)上接收到的SMS消息,并将它显示出来. 我们来定义一个Intent接收器来处理SMS接收事件: package com.wissen

Android API开发之SMS短信服务处理和获取联系人的方法

本文实例讲述了Android API开发之SMS短信服务处理和获取联系人的方法.分享给大家供大家参考,具体如下: Android API支持开发可以发送和接收SMS消息的应用程序.目前我们开发过程中使用的Android模拟器还不支持发送SMS,但它可以接收SMS.现在我们来探索一下Android对SMS的支持,我们将会构建一个小小的应用程序来监听移动设备(或模拟器)上接收到的SMS消息,并将它显示出来. 我们来定义一个Intent接收器来处理SMS接收事件: package com.wissen

android 从ftp下载sqlite数据库后覆盖原有数据库,为什么不能运行?

问题描述 android 从ftp下载sqlite数据库后覆盖原有数据库,为什么不能运行? android的sqlite数据库,存在data/data/packagename/databases/下, 用org.apache.commons.net.ftp.FTPClient 上传数据库到ftp,再下载下来后,为什么提示损坏,打不开? 我测试过,ftp上的文件是正确的,下载也成功了,文件有更新,文件的大小和ftp上的也是一样的.但是为什么打不开呢?用sqlexpert打开sqlite,提示dat

Android编程开发之Spinner控件用法实例分析_Android

本文实例讲述了Android编程开发之Spinner控件用法.分享给大家供大家参考,具体如下: 下拉列表 Spinner,Spinner是一个每次只能选择所有项的一个项的控件.它的项来自于与之相关联的适配器中. Spinner的使用,可以极大提高用户的体验性.当需要用户选择的时候,可以提供一个下拉列表将所有可选的项列出来.供用户选择. 一.使用数组作为数据源 布局文件: <RelativeLayout xmlns:android="http://schemas.android.com/ap

Android编程开发之Spinner组件用法_Android

本文实例讲述了Android编程开发之Spinner组件用法.分享给大家供大家参考,具体如下: Spinner组件组要用显示一个下拉列表,在使用中需要用到适配器Adapter,下面是一个该组件的使用示例 首先是布局文件main.xml: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res

Android安全开发之ZIP文件目录遍历

Android安全开发之ZIP文件目录遍历 作者:伊樵.呆狐.舟海@阿里聚安全 1.ZIP文件目录遍历简介 因为ZIP压缩包文件中允许存在"../"的字符串,攻击者可以利用多个"../"在解压时改变ZIP包中某个文件的存放位置,覆盖掉应用原有的文件.如果被覆盖掉的文件是动态链接so.dex或者odex文件,轻则产生本地拒绝服务漏洞,影响应用的可用性,重则可能造成任意代码执行漏洞,危害用户的设备安全和信息安全.比如近段时间发现的"寄生兽"漏洞.海豚

app-关于android APP开发中SQLITE数据库的问题

问题描述 关于android APP开发中SQLITE数据库的问题 代码如下,首先请问我写的这段创建数据库的代码有没有错误?然后把这个类的文件放在哪里才对啊,目前程序一打开就是程序已经停止运行,APP的第一个ACTIVITY我设置的就是判断这个库中的某个表中有没有数据.我现在感觉就是程序打开,这个库还没有创建,是不存在的,所以运行不了.请大神指教下我.或者说怎么让APP一开始运行的第一步就是运行以下的代码来创建这个数据库.求指教. //数据库创建类 package com.captain.dao