第六章 数据存储

1.文件     一般不用。

2.数据库  几百k  存储联系人信息。

3.sp            键值对 存储一些密码,地址之类的。

4.sd卡。


1.文件

数据从内存中写入硬盘。先缓冲下 ,在转化 ,再输出。
FileOutputStream out=openFileOutput("data",Context.MODE.PRIVATE);   得到字节流 文件对象。
OutputStreamWriter outsw=new OutputStreamWriter(out);  转换流 。
BufferedWriter bufferw=new BufferedWriter(outsw); 带有缓冲区的字符输出流   
bufferw.write("data to save content");        将文本写入文件中。






从文件中读取数据  放入sb中。
StringBuilder sb=new StringBuilder();
FileInputStream in=openFileInput("data");
InputStreamReader reader=new InputStreamReader(in);   转换流 
String line=BufferedReader.readerline();           一行一行读取
while(line!=null)
{
sb.append(line);
}




if(!TextUtils.isEmpty(str))
{
edit.setText(str);
edit.setSelection(str.length());//光标移动到文本的末尾
}
。   
数据从内存中写入硬盘时,顺序是,缓冲流->转化流->文件流;
而缓冲流是字符流,本例中的文件流out是字节流,所以是字符流到字节流的桥梁;
OutputStreamWriter/InputStreamReader 是转换流
字符流与字节流的判断标准:根据名字的最后个单词。如果是Writer/Reader则是字符流,
若是InputStream/OutputStream则是字节流。因此,转换流本身是字符流。


BufferedReader,为字符输入流增加了缓冲区的功能
FileOutputStream,是用来操作文件的字节输出流,File代表操作的目的,OutputStream代表这是个输出的字节流


缓冲流是字符流

3.sp中


4.数据库

SQLiteOpenHelper 帮助类,借助这个类就可以非常简单地对数据库进行创建和升级 

命令行:sqlite3

SQLite 不像其他的数据库拥有众多繁杂的数据类型,它的数据类型很简单,integer 表示整型,real 表示浮点型,text 表示文本类型,blob 表示二进制类型 

create table Book(
id integer primary key autoincrement,
author text,
price real,
pages integer,
name  text
)


//SQLiteOpenHelper的子类 覆盖父类的方法,只会执行一次
public void onCreate(SQLiteDatabase db){
db.execSQL(str2);
db.execSQL(str);
}




public void onUpgrade(SQLitedatabase db,int oldVersion,int newVersion)
{
db.execSQL("drop table if exists Book");
db.execSQL("drop table if exists Category");
onCreat(db);//再这里重新调用onCreate方法 在实例化的时候更改newVersion


}




构建出 SQLiteOpenHelper 的实例之后,再调用它的 getReadableDatabase()或 getWritableDatabase()方 法就能够创建数据库


getReadableDatabase()和 getWritableDatabase()。
这两个方法都可以创建或打开一个现有的数据库(如果数据库已存在 则直接打开,否则创建一个新的数据库)






对数据库的操作就是crud。 create retrieve update delete 
              添加  insert select update  delete


db.insert("book",null,contentValues);
db.update("book",contentValues,"name=?",new String[]{"the davinci code"});
?是一个占位符,可以通过第四个参数
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值