自定义ContentProvider
2016-03-22 17:07
711 查看
1.继承ContentProvider
2.主界面
package com.fsg.thinkpad.application;
import android.content.ContentValues;
import android.database.Cursor;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
public class MainActivity extends AppCompatActivity {
private static final String TAG = "MainActivity";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
//noinspection SimplifiableIfStatement
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
public void onClickWriteDB(View view){
ContentValues values=new ContentValues();
values.put("name","java");
getContentResolver().insert(MyProvider.URI, values);
values.put("name", "c");
getContentResolver().insert(MyProvider.URI, values);
values.put("name", "c++");
getContentResolver().insert(MyProvider.URI, values);
values.put("name","python");
getContentResolver().insert(MyProvider.URI,values);
}
public void onClickReadDB(View view){
Cursor cursor=getContentResolver().query(MyProvider.URI, null, null, null, null);
while (cursor.moveToNext()){
Log.i(TAG,cursor.getString(cursor.getColumnIndex("name")));
}
cursor.close();
}
}
3.布局文件
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">
<TextView android:text="@string/hello_world" android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/textView" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="写入数据库"
android:onClick="onClickWriteDB"
android:id="@+id/button"
android:layout_below="@+id/textView"
android:layout_centerHorizontal="true"
android:layout_marginTop="88dp" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="查询数据库"
android:onClick="onClickReadDB"
android:id="@+id/button2"
android:layout_below="@+id/button"
android:layout_alignLeft="@+id/button"
android:layout_alignStart="@+id/button"
android:layout_marginTop="125dp" />
</RelativeLayout>
package com.fsg.thinkpad.application; import android.content.ContentProvider; import android.content.ContentValues; import android.content.Context; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.net.Uri; /** * Created by ThinkPad on 2016/2/28. */ public class MyProvider extends ContentProvider { public static final Uri URI=Uri.parse("content://com.fsg.thinkpad.application"); SQLiteDatabase sqLiteDatabase; @Override public boolean onCreate() { sqLiteDatabase=getContext().openOrCreateDatabase("mycp.db", Context.MODE_PRIVATE,null); sqLiteDatabase.execSQL("create table if not exists tab(" + "_id integer primary key autoincrement," + "name text);"); return true; } @Override public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) { Cursor cursor=sqLiteDatabase.query("tab",null,null,null,null,null,null); return cursor; } @Override public String getType(Uri uri) { return null; } @Override public Uri insert(Uri uri, ContentValues values) { sqLiteDatabase.insert("tab",null,values); return null; } @Override public int delete(Uri uri, String selection, String[] selectionArgs) { return 0; } @Override public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) { return 0; } }
2.主界面
package com.fsg.thinkpad.application;
import android.content.ContentValues;
import android.database.Cursor;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
public class MainActivity extends AppCompatActivity {
private static final String TAG = "MainActivity";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
//noinspection SimplifiableIfStatement
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
public void onClickWriteDB(View view){
ContentValues values=new ContentValues();
values.put("name","java");
getContentResolver().insert(MyProvider.URI, values);
values.put("name", "c");
getContentResolver().insert(MyProvider.URI, values);
values.put("name", "c++");
getContentResolver().insert(MyProvider.URI, values);
values.put("name","python");
getContentResolver().insert(MyProvider.URI,values);
}
public void onClickReadDB(View view){
Cursor cursor=getContentResolver().query(MyProvider.URI, null, null, null, null);
while (cursor.moveToNext()){
Log.i(TAG,cursor.getString(cursor.getColumnIndex("name")));
}
cursor.close();
}
}
3.布局文件
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">
<TextView android:text="@string/hello_world" android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/textView" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="写入数据库"
android:onClick="onClickWriteDB"
android:id="@+id/button"
android:layout_below="@+id/textView"
android:layout_centerHorizontal="true"
android:layout_marginTop="88dp" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="查询数据库"
android:onClick="onClickReadDB"
android:id="@+id/button2"
android:layout_below="@+id/button"
android:layout_alignLeft="@+id/button"
android:layout_alignStart="@+id/button"
android:layout_marginTop="125dp" />
</RelativeLayout>
相关文章推荐
- 韩顺平老师讲诉如何学习PHP
- 韩顺平老师讲诉如何学习PHP
- php的预定义数组
- 1.1.4 A+B for Input-Output Practice (V)
- A+B for Input-Output Practice (IV)
- 1.1.3 A+B for Input-Output Practice (III)
- Ubuntu Webstorm/PhpStorm创建桌面快捷启动和菜单文字变粗解决
- phpstudy2016最新版本mysql无法使用innodb的问题解决
- php中将数据加入到文件中
- php判断键值在数组中是否存在
- PHP获取多个checkbox的值
- PHP转换SQLite数据库为MySQL
- thinkphp-许愿墙-3
- 数据条数过大时,分片采集
- Zend加密服务器配置以及加密工具的使用
- PHP快速排序
- PHP二分查找
- PHP选择排序
- PHP explode() 函数
- PHP判断设备