已阅读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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 綦江县农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)及答案详解(必刷)
- 龙岩市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)及答案详解(网校专用)
- 辽宁省农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)及答案详解(考点梳理)
- 长沙市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)及答案详解(典优)
- 海南州农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)及答案详解(典优)
- 2026年嘉峪关市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)附答案详解(模拟题)
- 滨州市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)含答案详解(综合卷)
- 保山市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)及完整答案详解1套
- 成都市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)及完整答案详解1套
- 锡林郭勒盟农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)及参考答案详解
- (人教PEP2024版)英语三年级上册全册大单元教学设计
- 托业培训课件
- 中央空调系统改造项目可行性研究报告
- GB/T 33745-2025物联网术语
- 2025至2030年中国汽车滚装码头行业市场分析研究及未来趋势研判报告
- 4输变电工程施工质量验收统一表式(电缆工程电气专业)-2024年版
- 二人买卖手表合同范本
- 医保口腔门诊管理制度
- 医疗实验室的信息化管理与效率提升
- 消防中控考试题及答案
- 建筑环境与能源应用工程专业毕业设计指南
评论
0/150
提交评论