SQLite&&SharedPreferences&&IO读写Sdcard学习笔记

SQLite

轻量级的、嵌入式的、关系型数据库

Android、IOS等广泛使用的的数据库系统

SQLite数据库之中可以方便的使用SQL语句,实现数据的增加、修改、删除、查询等操作

SQLiteOpenHelper:负责创建、打开、更新、关闭数据库和创建数据表

SQLiteDataBase:执行SQL语句、对数据表的增删改查

存储文件名,数据将保存在/data/data/程序的包名称/databases/xxxx.db中

使用SQLiteDataBase存储数据

  1. 1.    打开或创建test.db数据库 

SQLiteDatabase db = openOrCreateDatabase("test.db", Context.MODE_PRIVATE, null);

db.execSQL("DROP TABLE IF EXISTS person");

  1. 2.    创建表  person

db.execSQL("CREATE TABLE person (_id INTEGER PRIMARY KEY AUTOINCREMENT, _name VARCHAR, _age SMALLINT)");

  1. 3.    插入数据 

//方法【一】

db.execSQL("INSERT INTO person VALUES (NULL, ?, ?)", new Object[]{"mar", 1});

//方法【二】ContentValues以键值对的形式存放数据

ContentValues cv = new ContentValues();

cv.put("_name","joy");

cv.put("_age", 2);

db.insert("person", null, cv);  //插入ContentValues中的数据

  1. 4.    修改数据 【键值对的方式】

cv = new ContentValues();

cv.put("_age", 35);

db.update("person", cv, "name = ?", new String[]{"joy"});

  1. 5.    查询数据

//方法【一】 rawQuery

Cursor c = db.rawQuery("SELECT * FROM person WHERE age >= ?", new String[]{"33"});

//方法【二】执行query方法

Cursor c=db.query("users", new String[]{"_id","_name","_pwd"},

"_name=?",new String[]{"user01"},null,null,null);

while (c.moveToNext()) {

int id = c.getInt(c.getColumnIndex("_id"));

String name = c.getString(c.getColumnIndex("_name"));

int age = c.getInt(c.getColumnIndex("_age"));

Log.d("db", "_id=>" + id + ", name=>" + name + ", age=>" + age);

}

c.close();//关闭结果集

  1. 6.    删除数据 

db.delete("person", "age < ?", new String[]{"35"});//

db.delete("Test","WHERE _id="+0,null);

db.execSQL("delete from 表名 where 条件");

  1. 7.    关闭当前数据库 

db.close();

  1. 8.    删除数据库  test.db

deleteDatabase("test.db");

SharedPreferences

一种轻量级的数据保持方式,以键值对的方式将数据存入的xml文件中,通过key从文件中取出数据

获取SharedPreferences的两种方式:

  1. 调用Context对象的getSharedPreferences()方法
  2. 调用Activity对象的getPreferences()方法

两种方式的区别:

  • 调用Context对象的getSharedPreferences()方法获得的SharedPreferences对象可以被同一应用程序下的其他组件共享.
  • 调用Activity对象的getPreferences()方法获得的SharedPreferences对象只能在该Activity中使用.

SharedPreferences sp=super.getSharedPreferences("app_param", Context.MODE_PRIVATE);

存储文件名,数据将保存在/data/data/base package/shared_prefs/app_param.xml中

定义文件的操作模式

  1. 当前应用操作:              Context.MODE_PRIVATE

为默认操作模式,代表该文件是私有数据,只能被应用本身访问,在该模式下,写入的内容会覆盖原文件的内容

  1. 当前应用操作,追加模式:Context.MODE_APPEND

模式会检查文件是否存在,存在就往文件追加内容,否则就创建新文件.

  1. 能被其他应用读:           Context.MODE_WORLD_READABLE
  2. 能被其他应用写:           Context.MODE_WORLD_WRITEABLE

读写SD卡

使用SharedPreferences可以方便的完成数据的存储功能,但是其只能保存一些很简单的数据,如果想存储更多类型的数据,则可以使用文件的存储操作

实现步骤:

  1. 1.    加入读写SD卡权限

<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

  1. 2.    判断SD卡是否存在【无论是读还是写,都要判断】

Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED

  1. 3.    读写文件

存入数据---putXXX(key,value)

SharedPreferences sp=super.getSharedPreferences("app_param", Context.MODE_PRIVATE);

SharedPreferences.Editor editor=sp.edit();

editor.putString("use","tom");

editor.putInt("age", 1); //默认值 1

editor.commit();

取出数据----getXXX(key,default)

SharedPreferences sp=super.getSharedPreferences("app_param", Context.MODE_PRIVATE);

sp.getInt("use",0);//默认值 0

IO操作实现Sdcard存取操作

存数据

private int save(String fileName,NewsItem item){

Log.d("io","save()");

int ret=0;

//Environment.getExternalStorageDirectory()拿目录  Environment.MEDIA_MOUNTED已加载

if (!Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)) {

return -1;

}

ObjectOutputStream oos=null;

//super.getFilesDir();//系统路径

String filePath=Environment.getExternalStorageDirectory().toString()

+File.separator+fileName;//File.separator路径

File file=new File(filePath);//创建文件,用于判断文件是否存在

File parentFile=file.getParentFile();

if (!parentFile.exists()) {//父文件夹不存在

parentFile.mkdir();//创建文件所在目录

}

try {

oos=new ObjectOutputStream(new BufferedOutputStream(new FileOutputStream(file)));

oos.writeObject(item);

ret=1;

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}finally{

try {

oos.flush();

if (oos!=null)oos.close();

} catch (IOException e) {

e.printStackTrace();

}

}

return ret;

}

取数据

private NewsItem read(String fileName){

Log.d("io","read()");

NewsItem item=null;      if(!Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){//如果sdcard存在

return null;

}

String filePath=Environment.getExternalStorageDirectory().toString()

+File.separator+fileName;//File.separator路径

File file=new File(filePath);

if (!file.exists()) {

return null;

}

ObjectInputStream ois=null;

try {

ois=new ObjectInputStream(new BufferedInputStream(new FileInputStream(file)));

item=(NewsItem)ois.readObject();

} catch (StreamCorruptedException e) {

e.printStackTrace();

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

} catch (ClassNotFoundException e) {

e.printStackTrace();

}finally{

try {

ois.close();

} catch (IOException e) {

e.printStackTrace();

}

}

return item;

}

时间: 2024-10-01 03:38:57

SQLite&&SharedPreferences&&IO读写Sdcard学习笔记的相关文章

kernel中对文件的读写【学习笔记】【原创】

/*1. 头文件 */ #include <linux/init.h> #include <linux/module.h> #include <linux/moduleparam.h> #include <linux/kernel.h> #include <linux/list.h> #include <linux/fs.h> #include <linux/uaccess.h> MODULE_PARM_DESC(ivar

树莓派学习笔记——Python SQLite查询历史温度

0 前言 本文通过Python SQLite查询树莓派CPU的温度历史数据,在前面的博文中已经介绍了树莓派CPU温度获取,SQLite操作和利用Python插入历史数据,下面再介绍如何查询数据,本文主要分为三部分,第一部分为查询所有温度记录,第二部分获得最近一小时数据,第三部分为把获得结果格式化为字典类型. [相关博文] [树莓派学习笔记--索引博文]--更多博文请关注. [树莓派学习笔记--获取树莓派CPU温度] [树莓派学习笔记--定时向yeelink上传树莓派CPU温度] [树莓派学习笔记

nodejs学习笔记之安装、入门

由于项目需要,最近开始学习nodejs.在学习过程中,记录一些必要的操作和应该注意的点. 首先是如何安装nodejs环境?(我用的是windows 7环境,所以主要是windows 7的例子.如果想看linux下的安装可以参考http://www.cnblogs.com/meteoric_cry/archive/2013/01/04/2844481.html) 1. nodejs提供了一些安装程序,可以去官网(http://nodejs.org/download/)按照自己的机器进行下载,下载完

SQLite 学习笔记

SQLite 学习笔记. 一.SQLite 安装    访问http://www.sqlite.org/download.html下载对应的文件.    1.在 Windows 上安装 SQLite.需要下载 sqlite-shell-win32-*.zip 和 sqlite-dll-win32-*.zip 压缩文件.        创建文件夹 C:\sqlite,并在此文件夹下解压上面两个压缩文件,将得到 sqlite3.def.sqlite3.dll 和 sqlite3.exe 文件.   

Java IO学习笔记:概念与原理

Java IO学习笔记:概念与原理 一.概念 Java中对文件的操作是以流的方式进行的.流是Java内存中的一组有序数据序列.Java将数据从源(文件.内存.键盘.网络)读入到内存 中,形成了流,然后将这些流还可以写到另外的目的地(文件.内存.控制台.网络),之所以称为流,是因为这个数据序列在不同时刻所操作的是源的不同部分. 二.分类 流的分类,Java的流分类比较丰富,刚接触的人看了后会感觉很晕.流分类的方式很多: 1.按照输入的方向分,输入流和输出流,输入输出的参照对象是Java程序. 2.

SQLite介绍、学习笔记、性能测试

SQLite介绍.学习笔记.性能测试 哪些人,哪些公司或软件在用SQLite: Nokia's Symbian,Mozilla,Abobe,Google,阿里旺旺,飞信,Chrome,FireFox可见SQLite的稳定性及性能是不会有什么问题的,详细列表请参见:http://www.sqlite.org/famous.html. 网上关于SQLite的介绍一抓一大把,总结起来,他有如下特点: SQLite优点及适应场合: 轻量级绿色组件单一文件跨平台查询效率极高使用事务插入速度极快支持limi

Lua学习笔记8:文件读写

lua中文件读写经常在游戏配置中用到,比如客户端的音效音乐开关等. Lua官方API文档:点这里 I/O库为文件操作提供4个主要函数:io.open(),io.read(),io.write和io.close(). io.open(文件路径,打开方式):以指定方式打开一个文件,打开成功返回一个文件句柄,失败返回nil和错误描述. 可以传入以下六种打开方式: "r":读模式(默认): "w":写模式: "a":附加模式: "r+"

sqlite学习笔记8:C语言中使用sqlite之创建表

前面已经说了如何打开和关闭数据库,这次要说得是如何执行SQL语句,来创建一张表. 要用的的函数: sqlite3_exec(sqlite3* db, const char *sql, sqlite_callback callback, void *data, char **errmsg) 参数: db:已经打开的数据库实例 sql:SQL语句,是一个字符串 callback:是一个回调函数 data:做为回调函数的第一个参数 errmsg:用于带回错误信息 该回调函数有两种返回值类型. 1.返回

【DAY12】第十二天集合&泛型&IO学习笔记

hash:散列 ------------------ Hashset集合内部是通过HashMap进行实现的.使用的是HashMap中key部分. 对象在添加进集合中时,首选会对hashcode进行处理(hashcode右移16位和 自身做异或运算)得到一个经过处理的hash值,然后该值和集合的容量进行 &运算,得到介于0和集合容量值之间一个数字.该数字表示着数组的下标. 也就是该元素应该存放在哪个元素中. Map与Collection -------------- Map与Collection在