热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Android的数据存储--SQLite

Android内嵌了功能比其他手机操作系统强大的关系型数据库sqlite3,我们在大学时候学的SQL语句基本都可以使用,我们自己创建的数据可以用adbshell来操作。具体路径是datadata

Android内嵌了功能比其他手机操作系统强大的关系型数据库sqlite3,我们在大学时候学的SQL语句基本都可以使用,

我们自己创建的数据可以用adb shell来操作。具体路径是/data/data/package_name/databases。

下面给出一个小例子代码:(增删改查操作)

首先把测试环境搭好,,在配置文件中AndroidManifest.xml中引入下面的语句申请相应的功能模块

 
       

 

建立一个Person类 

package com.example.domain;

public class Person {
private Integer id;
private String nameString;
private String phone;

public Person() {

}

public Person( String nameString, String phone) {
this.nameString = nameString;
this.phOne= phone;
}

public Person(Integer id, String nameString, String phone) {
this.id = id;
this.nameString = nameString;
this.phOne= phone;
}

public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getNameString() {
return nameString;
}
public void setNameString(String nameString) {
this.nameString = nameString;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phOne= phone;
}

@Override
public String toString() {
return "Person [id=" + id + ", nameString=" + nameString + ", phOne="
+ phone + "]";
}



}


在业务层创建:

package com.example.service;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;

public class DBOpenHelper extends SQLiteOpenHelper {

public DBOpenHelper(Context context) {
//采用系统默认的游标 最后一个不要为零
super(context, "itcast.db", null, 2);
}

//数据库第一个被创建的时候调用的
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("create table person (personid integer primary key autoincrement, name varchar(20))");
}

//数据库的版本号变更的时候才调用的函数
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("alter table person add phone varchar(12) null");
}

}
注意:两个函数的区别,调用域不同。

建立PersonService :

package com.example.service;

import java.util.ArrayList;
import java.util.List;

import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;

import com.example.domain.Person;


public class PersonService {
private DBOpenHelper dbOpenHelper;

public PersonService(Context context) {
// 以上下文对象进行传入
this.dbOpenHelper = new DBOpenHelper(context);
}

/*
* 添加记录
*
* @param person
*/
public void save(Person person) {
SQLiteDatabase db = dbOpenHelper.getWritableDatabase();
// 采用占位符的思想屏蔽掉字符串的特出性。。保证安全性
db.execSQL("insert into person(name,phone) values (?,?)", new Object[] {
person.getNameString(), person.getPhone() });
}

public void delete(Integer id) {
SQLiteDatabase db = dbOpenHelper.getWritableDatabase();
// 采用占位符的思想屏蔽掉字符串的特出性。。保证安全性
db.execSQL("delete from person where persOnid=?", new Object[] { id });

}

public void update(Person person) {
SQLiteDatabase db = dbOpenHelper.getWritableDatabase();
// 采用占位符的思想屏蔽掉字符串的特出性。。保证安全性
db.execSQL("update person set name=?,phOne=? where persOnid=?",
new Object[] { person.getNameString(), person.getPhone(),
person.getId() });

}

public Person find(Integer id) {
// 区别:不满,,就一样,,如果存储空间满了,只能读不能写
SQLiteDatabase db = dbOpenHelper.getReadableDatabase();
// Cursor可以动态的查询结果,随机访问
Cursor cursor = db.rawQuery("select * from person where persOnid=?",
new String[] { id.toString() });
if (cursor.moveToFirst()) {
int persOnid= cursor.getInt(cursor.getColumnIndex("personid"));
String name = cursor.getString(cursor.getColumnIndex("name"));
String phOne= cursor.getString(cursor.getColumnIndex("phone"));
return new Person(personid, name, phone);
}
cursor.close();
return null;
}

// 数据分页
/*@param offset 跳过前面多少页
* @param maxResult 每页获取到多少条记录
*
* */
public List getScrollDate(int offset, int maxResult) {
List persOns= new ArrayList();

SQLiteDatabase db = dbOpenHelper.getReadableDatabase();
// Cursor可以动态的查询结果,随机访问
Cursor cursor = db.rawQuery(
"select * from person order by personid asc limit ?,?",
new String[] { String.valueOf(offset),
String.valueOf(maxResult) });
while (cursor.moveToNext()) {
int persOnid= cursor.getInt(cursor.getColumnIndex("personid"));
String name = cursor.getString(cursor.getColumnIndex("name"));
String phOne= cursor.getString(cursor.getColumnIndex("phone"));
persons.add(new Person(personid, name, phone));

}
cursor.close();
return persons;
}
//获取总记录
public long getCount() {
SQLiteDatabase db = dbOpenHelper.getReadableDatabase();
// Cursor可以动态的查询结果,随机访问
Cursor cursor = db.rawQuery("select count(*) from person ", null);
cursor.moveToFirst();
long result = cursor.getLong(0);
return result;
}

}

下面建立测试类进行测试:

package com.example.test;

import java.util.List;

import com.example.domain.Person;
import com.example.service.DBOpenHelper;
import com.example.service.PersonService;

import android.os.DropBoxManager;
import android.test.AndroidTestCase;
import android.util.Log;

public class PersonServiceTest extends AndroidTestCase {
private static final String TAG="PersonServiceTest";

public void testCreateDB() throws Exception{
//传入上下文对象
DBOpenHelper dbOpenHelper=new DBOpenHelper(getContext());
//此方法自动创建数据库
dbOpenHelper.getWritableDatabase();
}
public void testSave()throws Exception{
PersonService service =new PersonService(this.getContext());
for(int i=0;i<20;i++){
Person person=new Person("zhangxx"+i,"18363857200"+i);
service.save(person);

}

}
public void testDelete()throws Exception{
PersonService service =new PersonService(this.getContext());
service.delete(21);

}
public void testUpdate()throws Exception{
PersonService service =new PersonService(this.getContext());
Person person=service.find(1);
person.setNameString("zhaoxiaoxiao");
service.update(person);

}
public void testFind()throws Exception{
PersonService service =new PersonService(this.getContext());
Person person=service.find(1);
Log.i(TAG, person.toString());
}
public void testScrollData()throws Exception{
PersonService service =new PersonService(this.getContext());
List persOns=service.getScrollDate(0, 5);
for(Person p:persons){
Log.i(TAG, p.toString());
}
}
public void testCount()throws Exception {
PersonService service =new PersonService(this.getContext());
long result=service.getCount();
//技巧,,返回的是字符串
Log.i(TAG, result+"");
}
}


在测试类中 PersonService service =new PersonService(this.getContext());这句话不能被提取到方法之外生成共鸣,因为只有在初始化之后才会产生上下文对象。


推荐阅读
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • YOLOv7基于自己的数据集从零构建模型完整训练、推理计算超详细教程
    本文介绍了关于人工智能、神经网络和深度学习的知识点,并提供了YOLOv7基于自己的数据集从零构建模型完整训练、推理计算的详细教程。文章还提到了郑州最低生活保障的话题。对于从事目标检测任务的人来说,YOLO是一个熟悉的模型。文章还提到了yolov4和yolov6的相关内容,以及选择模型的优化思路。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • web.py开发web 第八章 Formalchemy 服务端验证方法
    本文介绍了在web.py开发中使用Formalchemy进行服务端表单数据验证的方法。以User表单为例,详细说明了对各字段的验证要求,包括必填、长度限制、唯一性等。同时介绍了如何自定义验证方法来实现验证唯一性和两个密码是否相等的功能。该文提供了相关代码示例。 ... [详细]
author-avatar
981378224_014f95
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有