Android记事本开发之SQLite数据库实现
2023-09-11 14:16:04 时间
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!!");
Android数据库Sqlite的基本用法及升级策略 SQLite是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入 式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持 Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如Tcl、PHP、Java、C++、.Net等,还有ODBC接口,同样比起 Mysql、PostgreSQL这两款开源世界著名的数据库管理系统来讲,它的处理速度比他们都快。
Android Sqlite数据库升级——kotlin 对于android开发同学来说,数据库相关操作是我们日常操作之一,相应的数据库的升级操作就必不可少了。这里我总结下数据库升级时需要注意的事项。 Android中数据库操作的核心类是SqliteOpenHelper,这个类有两个方法,onCreate和onUpgrade。onCreate方法只会调用一次,onUpgrade方法会在版本号增加之后触发。 数据库升级的操作过程中,我们需要处理的情况有两种,第一种是数据库从低版本升级上来的,第二种是新安装app的用户。
【Android】7.0复杂数据的存储SQLite(内置数据库)Room框架 常用的数据库 sqlserver oracle mysql Android嵌入式数据库SQLite SQLite数据库支持SQL语法和ACID事务,适用于存储大量的关系型数据 eg:qq的聊天列表 学习强国的新闻
Android-SQLite数据库实例 使用SQLite保存数据 SQL的基本语法 数据库帮助器SQLiteOpenHelper 继承SQLiteOpenHelper类,重写onCreate、onUpgrade、onOpen方法 打开数据库表 关闭数据库 各参数说明 项目实例:SQLiteDemo.zip
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;
Android数据库Sqlite的基本用法及升级策略 SQLite是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入 式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持 Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如Tcl、PHP、Java、C++、.Net等,还有ODBC接口,同样比起 Mysql、PostgreSQL这两款开源世界著名的数据库管理系统来讲,它的处理速度比他们都快。
Android Sqlite数据库升级——kotlin 对于android开发同学来说,数据库相关操作是我们日常操作之一,相应的数据库的升级操作就必不可少了。这里我总结下数据库升级时需要注意的事项。 Android中数据库操作的核心类是SqliteOpenHelper,这个类有两个方法,onCreate和onUpgrade。onCreate方法只会调用一次,onUpgrade方法会在版本号增加之后触发。 数据库升级的操作过程中,我们需要处理的情况有两种,第一种是数据库从低版本升级上来的,第二种是新安装app的用户。
【Android】7.0复杂数据的存储SQLite(内置数据库)Room框架 常用的数据库 sqlserver oracle mysql Android嵌入式数据库SQLite SQLite数据库支持SQL语法和ACID事务,适用于存储大量的关系型数据 eg:qq的聊天列表 学习强国的新闻
Android-SQLite数据库实例 使用SQLite保存数据 SQL的基本语法 数据库帮助器SQLiteOpenHelper 继承SQLiteOpenHelper类,重写onCreate、onUpgrade、onOpen方法 打开数据库表 关闭数据库 各参数说明 项目实例:SQLiteDemo.zip
相关文章
- Android studio 2.0--android增量更新的那些事
- Android实现SQLite数据库的增、删、改、查的操作
- android ndk-build 编译静态库libxx.a 以及Android studio openssl 静态库配置(cmake)
- Android SQLite使用事务来确保所有语句都以原子方式执行及保证数据完整性一次执行多条语句示例
- Android在未root手机获取应用内置的SQLite数据库到电脑上处理的方法(数据库备份与恢复-支持SDK30+)
- Android UI 自定义控件大全
- Android中数据库Sqlite的性能优化
- 关于android的字体大小
- android开发中的数据库SQLite的使用
- Android之ListView,AsyncTask,GridView,CardView,本地数据存储,SQLite数据库
- Android 读写位于SD卡上的sqlite数据库文件错误问题
- Android-ImageView的属性android:scaleType作用
- C#/Sqlite-单机Window 程序 sqlite 数据库实现
- Android Data Binding使用笔记
- 《Android游戏开发详解》——第1章,第1.6节函数(在Java中称为“方法”更好)
- Android+Jquery Mobile学习系列(1)-开发环境
- android编译系统的makefile文件Android.mk写法如下
- android开发 socket接收图片并保存
- android学习-数据存储(一)-----SQLite源码分析
- android学习-进程/线程管理-完整
- Android Studio升级或更新项目,经常造访的“Could not find com.android.tools.build :gradle: x.x.x”的原因分析
- Android系统的“程序异常退出”[转]
- Android数据库之 Sqlite
- Android程序猿必掌握的sqlite数据库连表查询
- Android UncaughtExceptionHandler 记录异常并重启程序