热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

学会使用SQLite存储数据和删除数据等基本操作

首先还是写一个XML界面:<?xmlversion1.0encodingutf-8?><LinearLayoutxmlns:androidhttp:sche

首先还是写一个XML界面:

"1.0" encoding="utf-8"?>
"http://schemas.android.com/apk/res/android"
android:layout_width
="match_parent"
android:layout_height
="match_parent"
android:orientation
="vertical">
<EditText
android:id
="@+id/bookname"
android:hint
="输入名称"
android:layout_width
="fill_parent"
android:layout_height
="wrap_content"

>

<EditText
android:id
="@+id/author"
android:hint
="输入密码"
android:layout_width
="fill_parent"
android:layout_height
="wrap_content"
>

<ListView
android:id
="@+id/bookslist"

android:layout_width
="match_parent"
android:layout_height
="wrap_content"
>

2.书写Java代码实现功能:

  1 package com.example.zhoushasha.sqlitedatabasedemo;
2
3 import android.support.v7.app.AppCompatActivity;
4 import android.os.Bundle;
5 import android.app.Activity;
6 import android.content.Context;
7 import android.database.Cursor;
8 import android.os.Bundle;
9 import android.view.Menu;
10 import android.view.MenuItem;
11 import android.view.View;
12 import android.view.ViewGroup;
13 import android.widget.AdapterView;
14 import android.widget.BaseAdapter;
15 import android.widget.EditText;
16 import android.widget.ListView;
17 import android.widget.TextView;
18 import android.widget.Toast;
19 public class MainActivity extends AppCompatActivity implements AdapterView.OnItemClickListener {
20 private BooksDB mBooksDB;
21 private Cursor mCursor;
22 private EditText BookName;
23 private EditText BookAuthor;
24 private ListView BooksList;
25
26 private int BOOK_ID = 0;
27 protected final static int MENU_ADD = Menu.FIRST;
28 protected final static int MENU_DELETE = Menu.FIRST + 1;
29 protected final static int MENU_UPDATE = Menu.FIRST + 2;
30
31 public void onCreate(Bundle savedInstanceState) {
32 super.onCreate(savedInstanceState);
33 setContentView(R.layout.layout);
34 setUpViews();
35 }
36
37 public void setUpViews() {
38 mBooksDB = new BooksDB(this);
39 mCursor = mBooksDB.select();
40
41 BookName =(EditText)findViewById(R.id.bookname);
42 BookAuthor = (EditText) findViewById(R.id.author);
43 BooksList = (ListView) findViewById(R.id.bookslist);
44
45 BooksList.setAdapter(new BooksListAdapter(this, mCursor));
46 BooksList.setOnItemClickListener(this);
47 }
48
49 @Override
50 public boolean onCreateOptionsMenu(Menu menu) {
51 super.onCreateOptionsMenu(menu);
52
53 menu.add(Menu.NONE, MENU_ADD, 0, "ADD");
54 menu.add(Menu.NONE, MENU_DELETE, 0, "DELETE");
55 menu.add(Menu.NONE, MENU_DELETE, 0, "UPDATE");
56 return true;
57 }
58
59 public boolean onOptionsItemSelected(MenuItem item) {
60 super.onOptionsItemSelected(item);
61 switch (item.getItemId()) {
62 case MENU_ADD:
63 add();
64 break;
65 case MENU_DELETE:
66 delete();
67 break;
68 case MENU_UPDATE:
69 update();
70 break;
71 }
72 return true;
73 }
74
75 public void add() {
76 String bookname = BookName.getText().toString();
77 String author = BookAuthor.getText().toString();
78 //书名和作者都不能为空,或者退出
79 if (bookname.equals("") || author.equals("")) {
80 return;
81 }
82 mBooksDB.insert(bookname, author);
83 mCursor.requery();
84 BooksList.invalidateViews();
85 BookName.setText("");
86 BookAuthor.setText("");
87 Toast.makeText(this, "Add Successed!", Toast.LENGTH_SHORT).show();
88 }
89
90 public void delete() {
91 if (BOOK_ID == 0) {
92 return;
93 }
94 mBooksDB.delete(BOOK_ID);
95 mCursor.requery();
96 BooksList.invalidateViews();
97 BookName.setText("");
98 BookAuthor.setText("");
99 Toast.makeText(this, "Delete Successed!", Toast.LENGTH_SHORT).show();
100 }
101
102 public void update() {
103 String bookname = BookName.getText().toString();
104 String author = BookAuthor.getText().toString();
105 //书名和作者都不能为空,或者退出
106 if (bookname.equals("") || author.equals("")) {
107 return;
108 }
109 mBooksDB.update(BOOK_ID, bookname, author);
110 mCursor.requery();
111 BooksList.invalidateViews();
112 BookName.setText("");
113 BookAuthor.setText("");
114 Toast.makeText(this, "Update Successed!", Toast.LENGTH_SHORT).show();
115 }
116
117 @Override
118 public void onItemClick(AdapterView parent, View view, int position, long id) {
119
120 mCursor.moveToPosition(position);
121 BOOK_ID = mCursor.getInt(0);
122 BookName.setText(mCursor.getString(1));
123 BookAuthor.setText(mCursor.getString(2));
124
125 }
126
127 public class BooksListAdapter extends BaseAdapter {
128 private Context mContext;
129 private Cursor mCursor;
130
131 public BooksListAdapter(Context context, Cursor cursor) {
132
133 mCOntext= context;
134 mCursor = cursor;
135 }
136
137 @Override
138 public int getCount() {
139 return mCursor.getCount();
140 }
141
142 @Override
143 public Object getItem(int position) {
144 return null;
145 }
146
147 @Override
148 public long getItemId(int position) {
149 return 0;
150 }
151
152 @Override
153 public View getView(int position, View convertView, ViewGroup parent) {
154 TextView mTextView = new TextView(mContext);
155 mCursor.moveToPosition(position);
156 mTextView.setText(mCursor.getString(1) + "___" + mCursor.getString(2));
157 return mTextView;
158 }
159
160 }
161 }

3.创建一个新类bookDB.java类继承:

package com.example.zhoushasha.sqlitedatabasedemo;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

public class BooksDB extends SQLiteOpenHelper {
private final static String DATABASE_NAME = "BOOKS.db";
private final static int DATABASE_VERSION = 1;
private final static String TABLE_NAME = "books_table";
public final static String BOOK_ID = "book_id";
public final static String BOOK_NAME = "book_name";
public final static String BOOK_AUTHOR = "book_author";

public BooksDB(Context context) {
// TODO Auto-generated constructor stub
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
//创建table
@Override
public void onCreate(SQLiteDatabase db) {
String sql
= "CREATE TABLE " + TABLE_NAME + " (" + BOOK_ID
+ " INTEGER primary key autoincrement, " + BOOK_NAME + " text, "+ BOOK_AUTHOR +" text);";
db.execSQL(sql);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
String sql
= "DROP TABLE IF EXISTS " + TABLE_NAME;
db.execSQL(sql);
onCreate(db);
}

public Cursor select() {
SQLiteDatabase db
= this.getReadableDatabase();
Cursor cursor
= db
.query(TABLE_NAME,
null, null, null, null, null, null);
return cursor;
}
//增加操作
public long insert(String bookname,String author)
{
SQLiteDatabase db
= this.getWritableDatabase();
/* ContentValues */
ContentValues cv
= new ContentValues();
cv.put(BOOK_NAME, bookname);
cv.put(BOOK_AUTHOR, author);
long row = db.insert(TABLE_NAME, null, cv);
return row;
}
//删除操作
public void delete(int id)
{
SQLiteDatabase db
= this.getWritableDatabase();
String
where = BOOK_ID + " = ?";
String[] whereValue
={ Integer.toString(id) };
db.delete(TABLE_NAME,
where, whereValue);
}
//修改操作
public void update(int id, String bookname,String author)
{
SQLiteDatabase db
= this.getWritableDatabase();
String
where = BOOK_ID + " = ?";
String[] whereValue
= { Integer.toString(id) };

ContentValues cv
= new ContentValues();
cv.put(BOOK_NAME, bookname);
cv.put(BOOK_AUTHOR, author);
db.update(TABLE_NAME, cv,
where, whereValue);
}
}

 


推荐阅读
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 带添加按钮的GridView,item的删除事件
    先上图片效果;gridView无数据时显示添加按钮,有数据时,第一格显示添加按钮,后面显示数据:布局文件:addr_manage.xml<?xmlve ... [详细]
  • 本文介绍了使用kotlin实现动画效果的方法,包括上下移动、放大缩小、旋转等功能。通过代码示例演示了如何使用ObjectAnimator和AnimatorSet来实现动画效果,并提供了实现抖动效果的代码。同时还介绍了如何使用translationY和translationX来实现上下和左右移动的效果。最后还提供了一个anim_small.xml文件的代码示例,可以用来实现放大缩小的效果。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 本文讲述了如何通过代码在Android中更改Recycler视图项的背景颜色。通过在onBindViewHolder方法中设置条件判断,可以实现根据条件改变背景颜色的效果。同时,还介绍了如何修改底部边框颜色以及提供了RecyclerView Fragment layout.xml和项目布局文件的示例代码。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
    本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • 本文介绍了Android中的assets目录和raw目录的共同点和区别,包括获取资源的方法、目录结构的限制以及列出资源的能力。同时,还解释了raw目录中资源文件生成的ID,并说明了这些目录的使用方法。 ... [详细]
  • 使用圣杯布局模式实现网站首页的内容布局
    本文介绍了使用圣杯布局模式实现网站首页的内容布局的方法,包括HTML部分代码和实例。同时还提供了公司新闻、最新产品、关于我们、联系我们等页面的布局示例。商品展示区包括了车里子和农家生态土鸡蛋等产品的价格信息。 ... [详细]
  • 今日份分享:Flutter自定义之旋转木马
    今日份分享:Flutter自定义之旋转木马-先上图,带你回到童年时光:效果分析子布局按照圆形顺序放置且平分角度子布局旋转、支持手势滑动旋转、快速滑动抬手继续旋转、自动旋转支持X轴旋 ... [详细]
  • 今天就跟大家聊聊有关怎么在Android应用中实现一个换肤功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根 ... [详细]
  • SmartRefreshLayout自定义头部刷新和底部加载
    1.添加依赖implementation‘com.scwang.smartrefresh:SmartRefreshLayout:1.0.3’implementation‘com.s ... [详细]
  • 详解Android  自定义UI模板设计_由浅入深
    学习安卓已有一些日子,前段时间整理了不少笔记,但是发现笔记不变分享与携带。今天开始整理博客,全当是与大家分享交流与自身学习理解的过程吧。结合最近在做的一个新闻类app及学习中的问题,一点一点整理一下, ... [详细]
author-avatar
DreamFly72
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有