Android 记事本NotePad

这篇文章详细描述了在Android应用中使用SQLite数据库进行便签操作的方法,包括添加新便签、获取单个便签、更新和删除便签。内容涉及onUpgrade方法升级数据库版本,以及在NoteNew活动中对数据库的CRUD操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

}

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

// Drop older table if existed

db.execSQL("DROP TABLE IF EXISTS " + NOTE_TABLE_NAME);

// Create tables again

onCreate(db);

}

// Add new note

public int addNote(Note note) {

SQLiteDatabase db = this.getWritableDatabase();

ContentValues values = new ContentValues();

values.put(NOTE_COL_TITLE, note.getTitle());

values.put(NOTE_COL_CONTENT, note.getContent());

values.put(NOTE_COL_CREATED, note.getCreated());

values.put(NOTE_COL_MODIFIED, note.getModified());

// Insert to database

long rowId = db.insert(NOTE_TABLE_NAME, null, values);

// Close the database

db.close();

return (int) rowId;

}

// Get one note

public Note getNote(int id) {

SQLiteDatabase db = this.getReadableDatabase();

Cursor cursor = db.query(NOTE_TABLE_NAME, NOTE_COL_PROJECTION,

NOTE_COL_ID + “=?”, new String[] { String.valueOf(id) }, null,

null, null, null);

if (cursor != null)

cursor.moveToFirst();

Note note = new Note(cursor.getInt(0), cursor.getString(1),

cursor.getString(2), cursor.getLong(3), cursor.getLong(4));

return note;

}

// Get all notes

public List getAllNotes() {

List noteList = new ArrayList();

String selectQuery = "SELECT * FROM " + NOTE_TABLE_NAME;

SQLiteDatabase db = this.getWritableDatabase();

Cursor cursor = db.rawQuery(selectQuery, null);

// looping through all rows and adding to list

if (cursor.moveToFirst()) {

do {

Note note = new Note(cursor.getInt(0), cursor.getString(1),

cursor.getString(2), cursor.getLong(3),

cursor.getLong(4));

noteList.add(note);

} while (cursor.moveToNext());

}

// return contact list

return noteList;

}

public Cursor getAllNotesCursor() {

String selectQuery = "SELECT * FROM " + NOTE_TABLE_NAME;

SQLiteDatabase db = this.getReadableDatabase();

Cursor cursor = db.rawQuery(selectQuery, null);

return cursor;

}

public int updateNote(Note note) {

SQLiteDatabase db = this.getWritableDatabase();

ContentValues values = new ContentValues();

values.put(NOTE_COL_TITLE, note.getTitle());

values.put(NOTE_COL_CONTENT, note.getContent());

values.put(NOTE_COL_CREATED, note.getCreated());

values.put(NOTE_COL_MODIFIED, note.getModified());

return db.update(NOTE_TABLE_NAME, values,

NOTE_COL_ID + “=?”, new String[] { String.valueOf(note.getId()) });

}

public void deleteNote(int noteId) {

SQLiteDatabase db = this.getWritableDatabase();

db.delete(NOTE_TABLE_NAME, NOTE_COL_ID + “=?”,new String[] { String.valueOf(noteId) } );

db.close();

}

public void deleteAllNotes() {

SQLiteDatabase db = this.getWritableDatabase();

db.delete(NOTE_TABLE_NAME, null, null);

db.close();

}

}

新建和修改便签:

package com.zms.notepad;

import android.app.Activity;

import android.content.Intent;

import android.os.Bundle;

import android.view.Menu;

import android.view.MenuItem;

import android.view.View;

import android.widget.Button;

import android.widget.EditText;

import android.widget.Toast;

/**

  • Created by AlexZhou on 2015/2/3.

  • 11:14

*/

public class NoteNew extends Activity {

private EditText etTitle; //便签标题

private EditText etContent; //便签内容

private Button btnCancel;

private Button btnSave;

private int _noteId; //便签ID

private NoteDbHelper _db;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.note_new);

etTitle = (EditText) findViewById(R.id.etTitle);

etContent = (EditText) findViewById(R.id.etContent);

btnCancel = (Button) findViewById(R.id.btnCancel);

btnSave = (Button) findViewById(R.id.btnSave);

btnCancel.setOnClickListener(new OnClickListenerImp());

btnSave.setOnClickListener(new OnClickListenerImp());

_db = new NoteDbHelper(this);

Intent intent = getIntent();

_noteId = intent.getIntExtra(NoteList.EXTRA_NOTE_ID, -1);

if (_noteId > 0) {

Note note = _db.getNote(_noteId);

etTitle.setText(note.getTitle());

etContent.setText(note.getContent());

}

}

private class OnClickListenerImp implements View.OnClickListener {

@Override

public void onClick(View v) {

if (v == btnCancel) {

Toast.makeText(NoteNew.this, “天启提示:放弃新建便签”, Toast.LENGTH_SHORT).show();

finish();

} else if (v == btnSave) {

String titleVoid = etTitle.getText().toString();

String contentVoid = etContent.getText().toString();

if (titleVoid.equals(“”) || contentVoid.equals(“”)) {

Toast.makeText(NoteNew.this, “天启提示:标题或内容为空”, Toast.LENGTH_SHORT).show();

} else {

ToDatabase(); //插入数据库

Toast.makeText(NoteNew.this, “天启提示:便签保存成功”, Toast.LENGTH_SHORT).show();

finish();

}

}

}

}

@Override

public boolean onCreateOptionsMenu(Menu menu) {

getMenuInflater().inflate(R.menu.note_new_menu, menu);

return true;

}

@Override

public boolean onOptionsItemSelected(MenuItem item) {

int id = item.getItemId();

if (id == R.id.action_exit) {

Intent intent = new Intent(Intent.ACTION_MAIN);

intent.addCategory(Intent.CATEGORY_HOME);

intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);

startActivity(intent);

android.os.Process.killProcess(android.os.Process.myPid());

return true;

} else if (id == R.id.action_about) {

Intent intent = new Intent(this, About.class);

startActivity(intent);

return true;

}

return super.onOptionsItemSelected(item);

}

public final int ToDatabase() {

String title = etTitle.getText().toString();

String content = etContent.getText().toString();

int newNoteId = -1;

if (_noteId > 0) {

Note note = _db.getNote(_noteId);

note.setTitle(title);

note.setContent(content);

note.setModified(Long.valueOf(System.currentTimeMillis()));

_db.updateNote(note);

} else {

Note newNote = new Note(title, content);

newNoteId = _db.addNote(newNote);

架构师筑基包括哪些内容

我花了将近半个月时间将:深入 Java 泛型.、注解深入浅出、并发编程.、数据传输与序列化、Java 虚拟机原理、反射与类加载、高效 IO、Kotlin项目实战等等Android架构师筑基必备技能整合成了一套系统知识笔记PDF,相信看完这份文档,你将会对这些Android架构师筑基必备技能有着更深入、更系统的理解。

由于文档内容过多,为了避免影响到大家的阅读体验,在此只以截图展示部分内容

注:资料与上面思维导图一起看会更容易学习哦!每个点每个细节分支,都有对应的目录内容与知识点!



这份资料就包含了所有Android初级架构师所需的所有知识!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

大家的阅读体验,在此只以截图展示部分内容**

注:资料与上面思维导图一起看会更容易学习哦!每个点每个细节分支,都有对应的目录内容与知识点!

[外链图片转存中…(img-frFNOxtt-1714332372342)]
[外链图片转存中…(img-IJPipcfg-1714332372343)]
这份资料就包含了所有Android初级架构师所需的所有知识!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值