android中数据库操作是非常常见了,我们会经常用到,操作的方法也有很多种形式,这里我就把最常见的两种形式记录下来了,以备以后用到方便查看。我就不写注释和解释了,因为android数据库的操作和其它数据库操作本质上都是一样的,大同小异。需要的一些基本解释都在代码中,直接上代码了。

简单的代码文件目录:

首先这个类是数据库帮助类,DBHelper.java,代码如下:

package net.loonggg.db;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper; /**
* 数据库帮助类,继承android自带的SQLiteOpenHelper 主要用于数据库的创建与更新
*
* @author loonggg
*
*/
public class DBHelper extends SQLiteOpenHelper { public DBHelper(Context context) {
super(context, DBInfo.DB.DB_NAME, null, DBInfo.DB.DB_VERSION);
} @Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(DBInfo.Table.USER_INFO_CREATE);
} @Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL(DBInfo.Table.USER_INFO_DROP);
onCreate(db);
} }

其次是数据库信息类,DBInfo.java,代码如下:

package net.loonggg.db;

/**
* 数据库信息类,主要是保存一些数据库的版本,名字,及数据库表的创建语句和表的信息等,通过这个类记录,方便操作
*
* @author loonggg
*
*/
public class DBInfo {
/**
* 数据库信息
*
* @author loonggg
*
*/
public static class DB {
// 数据库名称
public static final String DB_NAME = "test.db";
// 数据库的版本号
public static final int DB_VERSION = 1;
} /**
* 数据库表的信息
*
* @author loonggg
*
*/
public static class Table {
public static final String USER_INFO_TB_NAME = "user_table";
public static final String USER_INFO_CREATE = "CREATE TABLE IF NOT EXISTS "
+ USER_INFO_TB_NAME
+ " ( _id INTEGER PRIMARY KEY,userId text,userName text)";
public static final String USER_INFO_DROP = "DROP TABLE"
+ USER_INFO_TB_NAME;
}
}

再次是数据库操作类,DBService.java,代码如下:

package net.loonggg.service;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List; import net.loonggg.db.DBHelper;
import net.loonggg.db.DBInfo.Table;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase; /**
* 数据库操作类,这个类主要的功能是:存放数据库操作的一些方法 这里有一些例子:包含数据库的增删改查,分别有两种方法的操作,各有优缺点,都在解释中
*
* @author loonggg
*
*/
public class DBService {
private DBHelper dbHelper = null; public DBService(Context context) {
dbHelper = new DBHelper(context);
} /**
* 添加一条记录到数据库
*
* @param id
* @param name
*/
public void add(String id, String name) {
SQLiteDatabase db = dbHelper.getWritableDatabase();
// 不好之处:无返回值,无法判断是否插入成功
db.execSQL("insert into user_table (userId,userName) values (?,?)",
new Object[] { id, name });
db.close();
} public long addAndroid(String id, String name) {
SQLiteDatabase db = dbHelper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("userId", id);
values.put("userName", name);
// 好处:有返回值
long result = db.insert(Table.USER_INFO_TB_NAME, null, values);// 返回值是插入的是第几行,大于0代表添加成功
db.close();
return result;
} /**
* 查询某条记录是否存在
*
* @param name
* @return
*/
public boolean find(String name) {
SQLiteDatabase db = dbHelper.getReadableDatabase();
Cursor cursor = db.rawQuery(
"select * from user_table where userName = ?",
new String[] { name });
boolean result = cursor.moveToNext();
db.close();
return result;
} public boolean findAndroid(String name) {
SQLiteDatabase db = dbHelper.getReadableDatabase();
Cursor cursor = db.query(Table.USER_INFO_TB_NAME, null, "userName = ?",
new String[] { name }, null, null, null);
boolean result = cursor.moveToNext();// true代表查找到了
db.close();
return result;
} /**
* 修改一条记录
*
* @param id
* @param name
*/
public void update(String id, String name) {
SQLiteDatabase db = dbHelper.getWritableDatabase();
// 缺点无返回值
db.execSQL("update user_table set userName = ? where userId = ?",
new Object[] { name, id });
db.close();
} public int updateAndroid(String id, String name) {
SQLiteDatabase db = dbHelper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("userName", name);
// 返回值大于0代表修改更新成功
int result = db.update(Table.USER_INFO_TB_NAME, values, "userId = ?",
new String[] { id });
db.close();
return result;
} /**
* 删除一条记录
*
* @param name
*/
public void delete(String name) {
SQLiteDatabase db = dbHelper.getWritableDatabase();
db.execSQL("delete from user_table where userName = ?",
new String[] { name });
db.close();
} public int deleteAndroid(String name) {
SQLiteDatabase db = dbHelper.getWritableDatabase();
int result = db.delete(Table.USER_INFO_TB_NAME, "userName = ?",
new String[] { name });// 返回值为受影响的行数,大于0代表成功
db.close();
return result;
} /**
* 返回所有的数据库信息
*
* @return
*/
public List<HashMap<String, String>> findAll() {
List<HashMap<String, String>> list = null;
SQLiteDatabase db = dbHelper.getReadableDatabase();
Cursor cursor = db.rawQuery("select * from user_table", null);
if (cursor.getCount() > 0) {
list = new ArrayList<HashMap<String, String>>();
while (cursor.moveToNext()) {
String id = cursor.getString(cursor.getColumnIndex("userId"));
String name = cursor.getString(cursor
.getColumnIndex("userName"));
HashMap<String, String> map = new HashMap<String, String>();
map.put("id", id);
map.put("name", name);
list.add(map);
}
}
cursor.close();
db.close();
return list;
} public List<HashMap<String, String>> findAllAndroid() {
List<HashMap<String, String>> list = null;
SQLiteDatabase db = dbHelper.getReadableDatabase();
Cursor cursor = db.query(Table.USER_INFO_TB_NAME, new String[] {
"userId", "userName" }, null, null, null, null, null);
if (cursor.getCount() > 0) {
list = new ArrayList<HashMap<String, String>>();
while (cursor.moveToNext()) {
String id = cursor.getString(cursor.getColumnIndex("userId"));
String name = cursor.getString(cursor
.getColumnIndex("userName"));
HashMap<String, String> map = new HashMap<String, String>();
map.put("id", id);
map.put("name", name);
list.add(map);
}
}
cursor.close();
db.close();
return list;
} }

最后是MainActivity,简单的调用了一下,这些操作,代码如下:

package net.loonggg.test;

import net.loonggg.service.DBService;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button; public class MainActivity extends Activity {
private Button queryOne;
private Button insert;
private Button update;
private Button delete;
private Button findAll;
private DBService service; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
queryOne = (Button) findViewById(R.id.queryOne);
insert = (Button) findViewById(R.id.insert);
update = (Button) findViewById(R.id.update);
delete = (Button) findViewById(R.id.delete);
findAll = (Button) findViewById(R.id.findAll);
queryOne.setOnClickListener(new ButtonListener());
insert.setOnClickListener(new ButtonListener());
update.setOnClickListener(new ButtonListener());
delete.setOnClickListener(new ButtonListener());
findAll.setOnClickListener(new ButtonListener());
service = new DBService(this);
} class ButtonListener implements View.OnClickListener { @Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.queryOne:
// service.find("loonggg");
service.findAndroid("loonggg");
break;
case R.id.insert:
// service.add("1", "loonggg");
service.addAndroid("2", "heihei");
break;
case R.id.update:
// service.update("1", "timmy");
service.updateAndroid("1", "haha");
break;
case R.id.delete:
// service.delete("timmy");
service.deleteAndroid("heihei");
break;
case R.id.findAll:
// service.findAll();
service.findAllAndroid();
break; default:
break;
}
}
} }

还有MainActivity对应的布局文件,activity_main.xml:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" > <Button
android:id="@+id/queryOne"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="查询一条记录" /> <Button
android:id="@+id/insert"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="添加" /> <Button
android:id="@+id/update"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="修改" /> <Button
android:id="@+id/delete"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="删除" /> <Button
android:id="@+id/findAll"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="查询全部" /> </LinearLayout>

到这里就介绍完了,这些代码并不高深,之所以记录下来,是留着以后用到的时候方便查看,当然这个代码对于初学者,还是非常有帮助的。

转载请说明出处:http://blog.csdn.net/loongggdroid/article/details/17463777

Android学习记录(2)—Android中数据库的常见操作的更多相关文章

  1. Android学习记录(3)—Android中ContentProvider的基本原理学习总结

    一.ContentProvider简介        当应用继承ContentProvider类,并重写该类用于提供数据和存储数据的方法,就可以向其他应用共享其数据.虽然使用其他方法也可以对外共享数据 ...

  2. 九、Android学习第八天——广播机制与WIFI网络操作(转)

    (转自:http://wenku.baidu.com/view/af39b3164431b90d6c85c72f.html) 九.Android学习第八天——广播机制与WIFI网络操作 今天熟悉了An ...

  3. 【Android学习入门】Android studio基本设置

    1.背景设置 依次选择File->Settings-->Appearance & Behaviour->Apprearance,然后勾选 show line number. ...

  4. 【代码学习】MYSQL数据库的常见操作

    ---恢复内容开始--- ============================== MYSQL数据库的常见操作 ============================== 一.mysql的连接与 ...

  5. MySQL数据库的常见操作(七)

    MySQL数据库的常见操作 1.创建数据库 2.创建重名的数据库以及如何查看警告信息 3.设置数据库的编码方式(默认为utf8) 4.修改和查看数据库的编码方式 5.删除数据库 6.6.删除已经删除了 ...

  6. 【代码总结】MYSQL数据库的常见操作

    ============================== MYSQL数据库的常见操作 ============================== 一.mysql的连接与关闭 -h:指定所连接的服 ...

  7. Android学习记录:SQLite数据库、res中raw的文件调用

    SQLite数据库是一种轻量级的关系型数据库. 在android中保存数据或调用数据库可以利用SQLite. android中提供了几个类来管理SQLite数据库 SQLiteDatabass类用来对 ...

  8. Android学习记录(6)—将java中的多线程下载移植到Android中(即多线程下载在Android中的使用)③

    在这一节中,我们就来讲多线程下载以及断点续传在android中怎么使用,前两节是为本节做准备的,没有看前两节的同学,最好看完前面的两篇文章再来看这篇.其实在android端的应用和java基本上是差不 ...

  9. Android学习记录(7)—Intent中显示意图和隐式意图的用法

    Intent(意图)主要是解决Android应用的各项组件之间的通讯. Intent负责对应用中一次操作的动作.动作涉及数据.附加数据进行描述,Android则根据此Intent的描述,负责找到对应的 ...

随机推荐

  1. SINAMICS S120 Parking axis设置,安转拆除或屏蔽电机

    1) P897 Parking axis selection 此参数可以连接到周期通讯的报文中(PZD) 2) 标准报文111中,已经连接此参数

  2. Mysql在字符串类型的日期上加上10分钟并和如今的日期做比較

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/ufo2910628/article/details/32092869 SELECT id FROM ...

  3. 找父节点和子节点个数(Poj1634)

    题目链接:http://poj.org/problem?id=1634 思路:按照工资从小到大排好,找到最近的那个身高较高的人. 有一点要注意的是,这里有个根节点,大boss,他的id是0,因此,我这 ...

  4. [Pytorch] pytorch笔记 <一>

    pytorch笔记 - torchvision.utils.make_grid torchvision.utils.make_grid torchvision.utils.make_grid(tens ...

  5. c#中的 MessageBox 弹出提示框的用法

    MessageBox.Show(<字符串str> Text, <字符串str> Title, <整型int> nType,MessageBoxIcon); 例:Me ...

  6. 【转】css行高line-height的一些深入理解及应用

    一.前言 前两天在腾讯ISD团队博客上看到一篇翻译的文章“深入理解css 行高”,是个不错的文章,学到了不少东西,建议您看看. 这里,我也要讲讲我对line-height的一些理解,所讲解的东西绝大多 ...

  7. 卷积神经网络CNN在自然语言处理的应用

    摘要:CNN作为当今绝大多数计算机视觉系统的核心技术,在图像分类领域做出了巨大贡献.本文从计算机视觉的用例开始,介绍CNN及其在自然语言处理中的优势和发挥的作用. 当我们听到卷积神经网络(Convol ...

  8. 使用nssm将bat文件注册为windows service (eg:solr, nodejs)

    nssm下载:http://pan.baidu.com/s/1sjAEevj _install.bat @echo off Set BasePath=D:\Tools %BasePath%\nssm- ...

  9. cordova创建工程添加插件

    创建工程 phonegap创建工程 代码 用以创建自己需要的  工程名   ; 报名  ;类名 ; 应用名 cordova create hello com.example.hello HelloWo ...

  10. Q&A - Nginx是做什么的?tomcat结合Nginx使用小结

    相信很多人都听过nginx,这个小巧的东西慢慢地在吞食apache和IIS的份额.那究竟它有什么作用呢?可能很多人未必了解. 说到反向代理,可能很多人都听说,但具体什么是反向代理,很多人估计就不清楚了 ...