




已阅读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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 别墅装修设计合同模板
- 购物中心家电产品专区承包经营合同
- 农村基础设施改造项目质量保证补充协议
- 网约车司机加盟平台安全驾驶责任协议
- 艺术展览馆软装设计制作与运营合同
- 抖音网红合作权益补充协议
- 网络直播行业网红助手兼职劳动合同
- 塑料粒子供应与客户忠诚度提升合作合同
- 培训机构兼职讲师兼职收入分配与结算合同
- 虚拟现实动作捕捉技术网络直播租赁合作协议
- 用地理知识介绍美国
- 2024-2025年高考生物一轮复习知识点讲解专题3-2细胞呼吸含解析
- 2024年版猪场员工劳动合同模板3篇
- 《生物制品连续制造指南》
- 保卫管理员三级练习题
- 湖北荆州市监利市畅惠交通投资有限公司招聘笔试冲刺题2024
- 食品配送行业安全生产管理制度
- 土力学知到智慧树章节测试课后答案2024年秋青岛理工大学
- 手术室护理疑难病例讨论
- 国家秘密载体的管理要求
- 硫酸安全使用管理及使用制度(4篇)
评论
0/150
提交评论