https://github.com/itgoyo/todo
ToDo
https://github.com/itgoyo/todo
Last synced: 3 months ago
JSON representation
ToDo
- Host: GitHub
- URL: https://github.com/itgoyo/todo
- Owner: itgoyo
- Created: 2017-01-22T01:14:19.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2017-08-15T01:13:32.000Z (almost 8 years ago)
- Last Synced: 2025-01-08T08:41:22.481Z (5 months ago)
- Homepage:
- Size: 5.86 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Todo
### 每日计划
2017-2-27 23-24《Android第一行代码》 第六章 **文件存储**
## 一、文件存储默认存储路径:/data/data//files
文件操作模式:MODE_PRIVATE(默认):覆盖、MODE_APPEND[1] 写入文件
```java
public void save(){
String data = "save something here";
FileOutputStream out = null;
ButteredWriter writer = null;
try{
out = openFileOutput("data",Context.MODE_PRIVATE);
writer = new ButteredWriter(new OutputSreamWriter(out));
writer.write(data);
}catch(IOException e){
e.printStackTrace();
}finally{
try{
if(writer!=null){
writer.close();
}
}catch(IOException e){
e.printStackTrace();
}
}
```[2] 读取文件
```java
public String load(){
FileInputStream in = null;
ButteredReader reader = null;
StringBuilder builder = new StringBuilder();
try{
in = openFileInput("data");
reader = new ButteredReader(new InputStreamReader(in));
String line= "";
while((line = reader.readline()) != null){
builder.append();
}
}catch(IOException e){
e.printStackTrace();
}finally{
if(reader != null){
try{
reader.close();
}catch(IOException e){
e.printStackTrace();
}
}
}
}
```## 二、SharePreferences
默认存储路径:/data/data//shared_prefs
操作模式:MODE_PRIVATE(默认):只有当前的应用程序才能对文件进行读写、
MODE_MULTI_PROCESS:用于多个进程对同一个SharedPreferences进行读写。
### 获取SharedPreferences对象的方法
- Context的getSharedPreferences()方法,参数一是文件名,参数二是操作模式
- Activity的getPreferences()方法,参数为操作模式,使用当前应用程序包名为文件名
- PreferenceManager的getDefaultSharedPreferences()静态方法,接收Context参数,使用当前应用程序包名为文件名### 存储数据
- 调用SharedPreferences对象的edit()方法获取一个SharedPreferences.Editor对象
- 向Editor对象中添加数据putBoolean、putString等
- 调用commit()方法提交数据```java
SharedPreferences.Editor editor = getSharedPreferences("data",MODE_PRIVATE).edit();
editor.putString("name","ZhangSan");
editor.putInt("age",12);
editor.putBoolean("isMarried",false);
editor.commit();
```### 从SharedPreferences文件中读取数据
```java
SharedPreferences pref = getSharedPreferences("data",MODE_PRIVATE);
String name = pref.getString("name");
int age = pref.getInt("age");
boolean isMarried = pref.getBoolean("isMarried");
```
## 三、SQLite- integer 整型
- real 浮点型
- text 文本类型
- blob 二进制类型```java
public class MyDatabaseHelper extends SQLiteOpenHelper{
public static final String CREATE_BOOK = "create table book ( "
+ " id integer primary key autoincrement,"
+ " author text,"
+ "price real,"
+ "pages integer,"
+ "name text)";
private Context context;
public MyDatabaseHelper (Context context, String name, CursorFactory factory, int version) {
super(context, name, factory, version);
this.context = context;
}@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(CREATE_BOOK);
}//当打开数据库时传入的版本号与当前的版本号不同时会调用该方法
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {}
}
```在MainActivity中
```java
MyDatabaseHelper helper = new MyDatabaseHelper(this,"BookStore.db",null,1);
//检测到没有BookStore这个数据库,会创建该数据库并调用MyDatabaseHelper中的onCreated方法。
helper.getWritableDatabase();
```
### 升级数据库
```java
public class MyDatabaseHelper extends SQLiteOpenHelper{
......
//当打开数据库时传入的版本号与当前的版本号不同时会调用该方法
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("drop table if exists Book");
onCreate(db):
}
}```
在MainActivity中只需将version改为大于原来版本号即可。
```java
MyDatabaseHelper helper = new MyDatabaseHelper(this,"BookStore.db",null,2);
helper.getWritableDatabase();
```### 向数据库添加数据
insert()方法,参数一表名,参数二是在未指定添加数据的情况下给某些可为空的列自动赋值为NULL,设置为null即可,参数三是ContentValues对象。
```java
SQLiteDatabase db = helper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("name","The Book Name");
values.put("author","chen");
values.put("pages",100);
values.put("price",200);
db.insert("Book",null,values);```
### 更新数据库中的数据
update()方法,参数一是表名,参数二是ContentValues对象,参数三、四是去约束更新某一行或某几行的数据,不指定默认更新所有。
```java
SQLiteDatabase db = helper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("price",120);
db.update("Book",values,"name= ?",new String[]{"The Book Name"});
```### 从数据库中删除数据
delete()方法,参数一是表名,参数二、三是去约束删除某一行或某几行的数据,不指定默认删除所有。
```java
SQLiteDatabase db = helper.getWritableDatabase();
db.delete("Book","pages> ?",new String[]{"100"});```
### 查询数据库中的数据
query()方法,参数一是表名,参数二是指定查询哪几列,默认全部,参数三、四是去约束查询某一行或某几行的数据,不指定默认查询所有,参数五是用于指定需要去group by的列,参数六是对group by的数据进一步的过滤,参数七是查询结果的排序方式
```java
SQLiteDatabase db = helper.getWritableDatabase();
Cursor cursor = db.query("Book",null,null,null,null,null,null);
if(cursor.moveToFirst()){
do{
String name = cursor.getString(cursor.getColumnIndex("name");
String author = cursor.getString(cursor.getColumnIndex("author");
int pages = cursor.getString(cursor.getColumnIndex("pages");
double price = cursor.getString(cursor.getColumnIndex("price");
}while(cursor.moveToNext());
}
cursor.close():
```### 使用SQL语句操作数据库
```java
//添加数据
db.execSQL("insert into Book(name,author,pages,price) values(?,?,?,?) "
,new String[]{"The Book Name","chen",100,20});
//更新数据
db.execSQL("update Book set price = ? where name = ?",new String[]
{"10","The Book Name"});
//删除数据
db.execSQL("delete from Book where pages > ?",new String[]{"100"});
//查询数据
db.execSQL("select * from Book",null);
```### 使用事务操作
```java
SQLiteDatabase db = helper.getWritableDatabase();
db.beginTransaction(); //开启事务
try{
......
db.insert("Book",null,values);
db.setTransactionSuccessful(); //事务成功执行
}catch(SQLException e){
e.printStackTrace();
}finally{
db.endTransaction(); //结束事务
}
```## 四、Contert Provider
ContentProvider主要用于不同的程序之间实现数据共享的功能。
- 访问其他应用程序中的数据
工具类ContentResolver,提供了一系列方法对数据进行CRUD操作。
### ContentResolver的使用方法
```java
/包名为com.example.app的表table1访问路径
Uri uri = Uri.parse("content://com.example.app.provider/table1");
```1、内容URI
内容URI是由权限和路径组成的,权限是用于区分不同的应用程序,一般是以包名来命名。路径是用于区分同一个应用程序的不同表。2、使用Uri对象进行数据操作
- 查询
```java
Cursor cursor = getContentResolver().query(uri,null,null,null,null);
if(cursor != null){
while(cursor.moveToNext()){
String column1 = cursor.getString(cursor.getColumnIndex("column1"));
String column2 = cursor.getString(cursor.getColumnIndex("column2"));
}
cursor.close();
}
```- 插入
```java
ContentValues values = new ContentValues();
values.put("column1","text");
values.put("column2",1);∏
getContentResolver().insert(uri,values);
```## 五、网络存储
## 五、网络存储
2017.3.2 01:10
《黑客与画家》 p102 mark
2017.3.3 23:19
《黑客与画家》 p204 mark
第十三章《书呆子的复仇》
2017-3-12
《俞敏洪:在痛苦的世界中尽力而为》
command+shift+. (即可显示隐藏的文件)
2017.8.15 -2017-10.15
学习前端知识
2017.10.16-2018.1.16
学习服务器知识