




已阅读5页,还剩1页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
ContentValues利用ContentValues来代替原来SQL语句进行数据库的操作。ContentValues存储值都只能是基本类型。SimpleCursorAdapterSimpleCursorAdapter类和ListView配合进行ListView的显示。封装SQLiteDatabase,让访问数据更加方便和安全。重点方法介绍:renderListView()package com.eoeAndroid.SQLite;import android.app.ListActivity;import android.content.Intent;import android.database.Cursor;import android.os.Bundle;import android.view.Menu;import android.view.MenuItem;import android.view.View;import android.widget.ListView;import android.widget.SimpleCursorAdapter;/* author jinyan* */public class ActivityMain extends ListActivity private static final int ACTIVITY_CREATE = 0;private static final int ACTIVITY_EDIT = 1;private static final int INSERT_ID = Menu.FIRST;private static final int DELETE_ID = Menu.FIRST + 1;private DiaryDbAdapter mDbHelper;private Cursor mDiaryCursor;Overridepublic void onCreate(Bundle savedInstanceState) super.onCreate(savedInstanceState);setContentView(R.layout.diary_list);mDbHelper = new DiaryDbAdapter(this);mDbHelper.open();renderListView();private void renderListView() mDiaryCursor = mDbHelper.getAllNotes();startManagingCursor(mDiaryCursor);String from = new String DiaryDbAdapter.KEY_TITLE,DiaryDbAdapter.KEY_CREATED ;int to = new int R.id.text1, R.id.created ;SimpleCursorAdapter notes = new SimpleCursorAdapter(this,R.layout.diary_row, mDiaryCursor, from, to);setListAdapter(notes);Overridepublic boolean onCreateOptionsMenu(Menu menu) super.onCreateOptionsMenu(menu);menu.add(0, INSERT_ID, 0, R.string.menu_insert);menu.add(0, DELETE_ID, 0, R.string.menu_delete);return true;Overridepublic boolean onMenuItemSelected(int featureId, MenuItem item) switch (item.getItemId() case INSERT_ID:createDiary();return true;case DELETE_ID:mDbHelper.deleteDiary(getListView().getSelectedItemId();renderListView();return true;return super.onMenuItemSelected(featureId, item);private void createDiary() Intent i = new Intent(this, ActivityDiaryEdit.class);startActivityForResult(i, ACTIVITY_CREATE);Override/ 需要对position和id进行一个很好的区分/ position指的是点击的这个ViewItem在当前ListView中的位置/ 每一个和ViewItem绑定的数据,肯定都有一个id,通过这个id可以找到那条数据。protected void onListItemClick(ListView l, View v, int position, long id) super.onListItemClick(l, v, position, id);Cursor c = mDiaryCursor;c.moveToPosition(position);Intent i = new Intent(this, ActivityDiaryEdit.class);i.putExtra(DiaryDbAdapter.KEY_ROWID, id);i.putExtra(DiaryDbAdapter.KEY_TITLE, c.getString(c.getColumnIndexOrThrow(DiaryDbAdapter.KEY_TITLE);i.putExtra(DiaryDbAdapter.KEY_BODY, c.getString(c.getColumnIndexOrThrow(DiaryDbAdapter.KEY_BODY);startActivityForResult(i, ACTIVITY_EDIT);Overrideprotected void onActivityResult(int requestCode, int resultCode,Intent intent) super.onActivityResult(requestCode, resultCode, intent);renderListView();package com.eoeAndroid.SQLite;import java.util.Calendar;import java.util.Date;import android.content.ContentValues;import android.content.Context;import android.database.Cursor;import android.database.SQLException;import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteOpenHelper;import android.util.Log;public class DiaryDbAdapter public static final String KEY_TITLE = title;public static final String KEY_BODY = body;public static final String KEY_ROWID = _id;public static final String KEY_CREATED = created;private static final String TAG = DiaryDbAdapter;private DatabaseHelper mDbHelper;private SQLiteDatabase mDb;private static final String DATABASE_CREATE = create table diary (_id integer primary key autoincrement, + title text not null, body text not null, created text not null);private static final String DATABASE_NAME = database;private static final String DATABASE_TABLE = diary;private static final int DATABASE_VERSION = 1;private final Context mCtx;private static class DatabaseHelper extends SQLiteOpenHelper DatabaseHelper(Context context) super(context, DATABASE_NAME, null, DATABASE_VERSION);Overridepublic void onCreate(SQLiteDatabase db) db.execSQL(DATABASE_CREATE);Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) db.execSQL(DROP TABLE IF EXISTS diary);onCreate(db);public DiaryDbAdapter(Context ctx) this.mCtx = ctx;public DiaryDbAdapter open() throws SQLException mDbHelper = new DatabaseHelper(mCtx);mDb = mDbHelper.getWritableDatabase();return this;public void closeclose() mDbHelper.close();public long createDiary(String title, String body) ContentValues initialValues = new ContentValues();initialValues.put(KEY_TITLE, title);initialValues.put(KEY_BODY, body);Calendar calendar = Calendar.getInstance();String created = calendar.get(Calendar.YEAR) + 年+ calendar.get(Calendar.MONTH) + 月+ calendar.get(Calendar.DAY_OF_MONTH) + 日+ calendar.get(Calendar.HOUR_OF_DAY) + 时+ calendar.get(Calendar.MINUTE) + 分;initialValues.put(KEY_CREATED, created);return mDb.insert(DATABASE_TABLE, null, initialValues);public boolean deleteDiary(long rowId) return mDb.delete(DATABASE_TABLE, KEY_ROWID + = + rowId, null) 0;public Cursor getAllNotes() return mDb.query(DATABASE_TABLE, new String KEY_ROWID, KEY_TITLE,KEY_BODY, KEY_CREATED , null, null, null, null, null);public Cursor getDiary(long rowId) throws SQLException Cursor mCursor =mDb.query(true, DATABASE_TABLE, new String KEY_ROWID, KEY_TITLE,KEY_BODY, KEY_CREATED , KEY_ROWID + = + rowId, null, null,null, null, null);if (mCursor != null) mCursor.moveToFirst();return mCursor;public boolean updateDiary(long rowId, String title, String body) ContentValues args = new ContentValues();args.put(KEY_TITLE, title);args.put(KEY_BODY, body);Calendar calendar = Calendar.getInstance();String cr
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年教育机构人才流失原因分析及吸引机制创新报告
- 物业收费权转让合同范本
- 渔货代卖合同协议书模板
- 高校与美团配送合同范本
- 续签合同时让签竞业协议
- 鲜玉米采购标准合同范本
- 电力局承包劳务合同范本
- 香蕉收购协议书模板模板
- 海底捞如何解除合同协议
- 电梯安装加工合同协议书
- 智能小区业主委员会职责与科技应用
- 2025年上半年湖北黄冈黄梅县乡镇综合执法中心招聘工作人员15人易考易错模拟试题(共500题)试卷后附参考答案
- 招标代理机构选取突发情况应急处理预案
- 2025版家族信托遗产分配与管理执行合同3篇
- 吊车牵引放线跨越公路及停电千伏线路方案
- 2024年中国养老产业商学研究报告-银发经济专题
- 边坡太陡申请变更坡比的说明
- 2024年餐饮部半年度工作总结
- 检修工岗位职业危害防治操作规程(4篇)
- 新零售无人便利店开发与运营支持方案
- 高教版2023年中职教科书《语文》(基础模块)下册教案全册
评论
0/150
提交评论