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

简介: package com.jk.service;/** * 完成数据库的创建和版本更新 */import android.content.Context;import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteDatabase.CursorFactory;import
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;
		}
}


目录
相关文章
|
5天前
|
JavaScript 搜索推荐 Android开发
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
26 8
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
|
17天前
|
前端开发 Java Shell
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
123 20
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
15天前
|
Dart 前端开发 Android开发
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
37 4
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
30天前
|
缓存 前端开发 Android开发
【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
80 12
【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
|
1天前
|
安全 Android开发 iOS开发
escrcpy:【技术党必看】Android开发,Escrcpy 让你无线投屏新体验!图形界面掌控 Android,30-120fps 超流畅!🔥
escrcpy 是一款基于 Scrcpy 的开源项目,使用 Electron 构建,提供图形化界面来显示和控制 Android 设备。它支持 USB 和 Wi-Fi 连接,帧率可达 30-120fps,延迟低至 35-70ms,启动迅速且画质清晰。escrcpy 拥有丰富的功能,包括自动化任务、多设备管理、反向网络共享、批量操作等,无需注册账号或广告干扰。适用于游戏直播、办公协作和教育演示等多种场景,是一款轻量级、高性能的 Android 控制工具。
|
1月前
|
Dart 前端开发 Android开发
【02】写一个注册页面以及配置打包选项打包安卓apk测试—开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【02】写一个注册页面以及配置打包选项打包安卓apk测试—开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
36 1
【02】写一个注册页面以及配置打包选项打包安卓apk测试—开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
1月前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
58 2
|
2月前
|
存储 前端开发 关系型数据库
鸿蒙开发:实现键值数据库存储
对于数据量比较的小的,我们直接选择轻量级的用户首选项方式即可,而对于数据量比较大的情况下,直接可以使用数据库,而对于相对来说,比较大的数据,我们就可以使用键值型数据库方式
104 2
|
XML Android开发 数据格式
Android记事本开发之界面设计
不得不提一下ADT自带的手机截屏很方便,就在DDMS里可以找到。 main.xml &lt;?xml version="1.0" encoding="utf-8"?&gt; &lt;LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="v
1462 0
|
Android开发 索引 数据库
Android记事本开发
数据库实现部分          界面设计 package com.jk; import java.util.List; import android.app.AlertDialog; import android.app.ListActivity; import android.content.Context; import android.content.DialogInterfa
1011 0

热门文章

最新文章