`
yzxqml
  • 浏览: 134912 次
  • 性别: Icon_minigender_1
  • 来自: 广西
文章分类
社区版块
存档分类
最新评论

安卓 SQLite数据库操作实例

阅读更多

前段时间写了个安卓平台下SQLite数据库操作的实例 ,一直没得时间总结 ,今天把它弄出来了。

在Android 运行时环境包含了完整的 SQLite。

首先介绍一下SQLite这个数据库:

 

SQLite,是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如 Tcl、C#、PHP、Java等,还有ODBC接口,同样比起Mysql、PostgreSQL这两款开源世界著名的数据库管理系统来讲,它的处理速度比他们都快。

 

有一点相对其他数据库来说比较特殊的是:SQLite是无类型的. 这意味着你可以保存任何类型的数据到你所想要保存的任何表的任何列中,意思就是说话你可以在创建数据库表的时候任意定义数据类型,却不影响实际使用时的数据存储。

 

举个例子说就是你可以在创建表时定义username字段为varchar类型,但是实时使用时你可以向这个字段存入1、2.5、2012-6-6.。。这样的整型,单精,以及时间等其他类型,在SQLite里没有这种限制。

 

但是有一种情况例外:当字段类型为  ”Integer Primary Key” 时,就是定义表主键,这个就只能是integer类型。和普通数据库相同 。

 

SQLite 不支持一些标准的 SQL 功能,特别是外键约束(FOREIGN KEY constrains),嵌套 transcaction 和 RIGHT OUTER JOIN 和 FULL OUTER JOIN, 还有一些 ALTER TABLE 功能。

 

 

需要注意一点: SQLite不支持存储过程!

 

我这里就简单介绍,如需要可自行去了解关于SQLite的更多知识,

 

然后是我的Demo(一个简单的完成数据库增删查改操作):

 

首先是项目目录结构:


 

 

 

在本项目中我们使用JUnit测试,就要在AndroidManifest.xml配置JUnit

 

    AndroidManifest.xml 

 

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="org.yzsoft.sqlitedemo.test"
    android:versionCode="1"
    android:versionName="1.0" >

    <!-- 为了方便测试,我直接把上面包位置改成我项目的测试包下 -->
    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="15" />

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >

        <!--
  因为我们开发项目的时候,包会比较多,所以最好在下面这个activity的配置(  android:name="org.yzsoft.sqlitedemo.activity.MainActivity" )这句这里打上完整的    包名.类名 
  ,虽然可以直接用  .类名,但是这个.类名是建立在
  <manifest xmlns:android="http://schemas.android.com/apk/res/android"     package="org.yzsoft.sqlitedemo.test" 
  之上的,用package+.类名也刚好可以组合成完整路径。但是我们保险一点写完整去。 
        -->
        <activity
            android:name="org.yzsoft.sqlitedemo.activity.MainActivity"
            android:label="@string/title_activity_main" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <!-- JUnit要加这句 -->
        <uses-library android:name="android.test.runner" />
    </application>
    <!-- JUnit还要加这段 (android:targetPackage测试类所在包名 ) -->
    <instrumentation
        android:name="android.test.InstrumentationTestRunner"
        android:label="Test Unit Tests"
        android:targetPackage="org.yzsoft.sqlitedemo.test" >
    </instrumentation>

</manifest>
 

 

 

 

1、MainActivity.java(因为本项目中使用JUnit进行测试,就不需要Activity了,留着不用写它)

 

 

package org.yzsoft.sqlitedemo.activity;

import org.yzsoft.sqlitedemo.util.R;
import org.yzsoft.sqlitedemo.util.R.layout;
import org.yzsoft.sqlitedemo.util.R.menu;

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;

public class MainActivity extends Activity {

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.activity_main, menu);
        return true;
    }
}
 

 

 

 

2、DBOpenHandler.java

 

 

package org.yzsoft.sqlitedemo.util;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;

public class DBOpenHandler extends SQLiteOpenHelper {

	/**
	 * 
	 * @param context
	 *            上下文
	 * @param name
	 *            数据库名
	 * @param factory
	 *            可选的数据库游标工厂类,当查询(query)被提交时,该对象会被调用来实例化一个游标。默认为null。
	 * @param version
	 *            数据库版本号
	 */
	public DBOpenHandler(Context context, String name, CursorFactory factory, int version) {
		super(context, name, factory, version);
	}

	@Override
	public void onCreate(SQLiteDatabase db) {// 覆写onCreate方法,当数据库创建时就用SQL命令创建一个表
		// 创建一个t_users表,id主键,自动增长,字符类型的username和pass;
		db.execSQL("create table t_users(id integer primary key autoincrement,username varchar(200),pass varchar(200) )");

	}

	@Override
	public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
		// TODO Auto-generated method stub

	}

}
 

 

3、TUsers.java(实体类,习惯了WEB开发,总会加个实体类,方便)

 

 

package org.yzsoft.sqlitedemo.vo;

public class TUsers {
private int id ;
private String username;
private String pass;
public int getId() {
	return id;
}
public void setId(int id) {
	this.id = id;
}
public String getUsername() {
	return username;
}
public void setUsername(String username) {
	this.username = username;
}
public String getPass() {
	return pass;
}
public void setPass(String pass) {
	this.pass = pass;
}
}
 

 

4、SQLiteDAOImpl.java(数据库操作实现类)

 

 

package org.yzsoft.sqlitedemo.util;

import java.util.ArrayList;
import java.util.List;
import org.yzsoft.sqlitedemo.vo.TUsers;

import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;

public class SQLiteDAOImpl {
	private DBOpenHandler dbOpenHandler;

	public SQLiteDAOImpl(Context context) {
		this.dbOpenHandler = new DBOpenHandler(context, "dbtest.db", null, 1);
	}

	public void save(TUsers tusers) {// 插入记录
		SQLiteDatabase db = dbOpenHandler.getWritableDatabase();// 取得数据库操作
		db.execSQL("insert into t_users (username,pass) values(?,?)", new Object[] { tusers.getUsername(), tusers.getPass() });
		db.close();// 记得关闭数据库操作
	}

	public void delete(Integer id) {// 删除纪录
		SQLiteDatabase db = dbOpenHandler.getWritableDatabase();
		db.execSQL("delete from t_users where id=?", new Object[] { id.toString() });
		db.close();
	}

	public void update(TUsers tusers) {// 修改纪录
		SQLiteDatabase db = dbOpenHandler.getWritableDatabase();
		db.execSQL("update t_users set username=?,pass=? where" + " id=?", new Object[] { tusers.getUsername(), tusers.getPass(), tusers.getId() });
		db.close();
	}

	public TUsers find(Integer id) {// 根据ID查找纪录
		TUsers tusers = null;
		SQLiteDatabase db = dbOpenHandler.getReadableDatabase();
		// 用游标Cursor接收从数据库检索到的数据
		Cursor cursor = db.rawQuery("select * from t_users where id=?", new String[] { id.toString() });
		if (cursor.moveToFirst()) {// 依次取出数据
			tusers = new TUsers();
			tusers.setId(cursor.getInt(cursor.getColumnIndex("id")));
			tusers.setUsername(cursor.getString(cursor.getColumnIndex("username")));
			tusers.setPass(cursor.getString(cursor.getColumnIndex("pass")));

		}
		db.close();
		return tusers;
	}

	public List<TUsers> findAll() {// 查询所有记录
		List<TUsers> lists = new ArrayList<TUsers>();
		TUsers tusers = null;
		SQLiteDatabase db = dbOpenHandler.getReadableDatabase();
		// Cursor cursor=db.rawQuery("select * from t_users limit ?,?", new
		// String[]{offset.toString(),maxLength.toString()});
		// //这里支持类型MYSQL的limit分页操作

		Cursor cursor = db.rawQuery("select * from t_users ", null);
		while (cursor.moveToNext()) {
			tusers = new TUsers();
			tusers.setId(cursor.getInt(cursor.getColumnIndex("id")));
			tusers.setUsername(cursor.getString(cursor.getColumnIndex("username")));
			tusers.setPass(cursor.getString(cursor.getColumnIndex("pass")));
			lists.add(tusers);
		}
		db.close();
		return lists;
	}

	public long getCount() {//统计所有记录数
		SQLiteDatabase db = dbOpenHandler.getReadableDatabase();
		Cursor cursor = db.rawQuery("select count(*) from t_users ", null);
		cursor.moveToFirst();
		db.close();
		return cursor.getLong(0);
	}

}
 

 

 

5、TUsersTest.java(JUnit测试类)

 

 

package org.yzsoft.sqlitedemo.test;

import java.util.List;

import org.yzsoft.sqlitedemo.util.DBOpenHandler;
import org.yzsoft.sqlitedemo.util.SQLiteDAOImpl;
import org.yzsoft.sqlitedemo.vo.TUsers;

import android.test.AndroidTestCase;
import android.util.Log;

public class TUsersTest extends AndroidTestCase {
	private static final String TAG = "这个是测试类";// 准备好TAG标识用于LOG输出,方便我们用LogCat进行调试

	public void testCreate() {
		DBOpenHandler dbHandler = new DBOpenHandler(this.getContext(), "dbtest.db", null, 1);// 创建数据库文件
		dbHandler.getWritableDatabase();
	}

	public void testSave() throws Throwable {
		SQLiteDAOImpl p = new SQLiteDAOImpl(this.getContext());
		TUsers tuser = new TUsers();
		tuser.setUsername("用户");
		tuser.setPass("密码");
		p.save(tuser);
		Log.i(TAG, "插入成功");// 用日志记录一个我们自定义的输出。可以在LogCat窗口中查看,方便调试
	}

	public void testUpate() throws Throwable {
		SQLiteDAOImpl p = new SQLiteDAOImpl(this.getContext());
		TUsers tuser = p.find(1);
		tuser.setUsername("张三");
		p.update(tuser);
		Log.i(TAG, "修改成功");
	}

	public void testDelete() throws Throwable {
		SQLiteDAOImpl p = new SQLiteDAOImpl(this.getContext());
		p.delete(2);
		Log.i(TAG, "删除成功");
	}

	public void testFind() throws Throwable {
		SQLiteDAOImpl p = new SQLiteDAOImpl(this.getContext());
		TUsers tuser = p.find(1);
		Log.i(TAG, tuser.getUsername() + "   用户名");
	}

	public void testGetCount() throws Throwable {
		SQLiteDAOImpl p = new SQLiteDAOImpl(this.getContext());
		Log.i(TAG, p.getCount() + "   总记录数");
	}

	public void testFindAll() throws Throwable {
		SQLiteDAOImpl p = new SQLiteDAOImpl(this.getContext());
		List<TUsers> tusers = p.findAll();
		for (TUsers tuser : tusers) {
			Log.i(TAG, tuser.getUsername() + "   用户名");
		}
	}
}
 

然后是测试中的一些截图:

 




 

 

 

 

 

 

最后我们把File Exploer中data/data/项目包名/databases/dbtest.db 导出来,用Navicat Premium等数据库管理工具查看里面的数据:


 

导出来看看:


 

虽然安卓平台中SQLite是个小型的本地数据库,但是有些地方使用起来会比文件存储更方便,本文只是对它作一个简单的操作实例 ,有这方面兴趣的童鞋可以自己去深入研究。也希望大家能多交流交流~~~~

 

 

最最后~附上项目源码:

 

 

 

 

  • 大小: 32 KB
  • 大小: 28.5 KB
  • 大小: 35.8 KB
  • 大小: 36.1 KB
  • 大小: 35.3 KB
  • 大小: 35.8 KB
  • 大小: 39.2 KB
  • 大小: 27.3 KB
  • 大小: 25.2 KB
分享到:
评论
3 楼 linlif 2016-04-08  
fujiaxuan1989 写道
TUsersTest.java(JUnit测试类)怎么调用啊?求解答,谢谢.

兄弟知道怎么调用了吗?
2 楼 linlif 2016-04-08  
菜鸟同问TUsersTest.java怎么调用?
1 楼 fujiaxuan1989 2015-12-01  
TUsersTest.java(JUnit测试类)怎么调用啊?求解答,谢谢.

相关推荐

    Android之Sqlite数据库操作实例

    本实例将深入探讨如何在Android中使用SQLite数据库进行基本的操作,包括创建数据库、创建表、插入数据、查询数据以及更新和删除数据。 首先,我们来了解SQLite在Android中的使用基础。Android系统会为每个应用程序...

    Android SQLite数据库操作Demo

    在这个"Android SQLite数据库操作Demo"中,我们将探讨如何在Android应用中创建、查询、更新和删除SQLite数据库的数据。 1. **数据库初始化** 在Android中,我们通常通过扩展SQLiteOpenHelper类来初始化SQLite...

    android sqlite数据库实例

    本实例主要探讨如何在Android应用中进行SQLite数据库的增、删、查、改(CRUD)操作。 首先,我们需要创建一个SQLite数据库。在Android中,我们通过继承`SQLiteOpenHelper`类来实现。`SQLiteOpenHelper`提供了创建、...

    Android开发中的SQLite数据库的增删改查工具类

    在Android开发中,SQLite数据库是应用进行本地数据...综上所述,SQLiteManager和DBSOpenHelper是Android开发中实现SQLite数据库操作的核心工具,它们结合使用能有效管理和操作本地数据,满足各种应用的本地存储需求。

    SQLite数据库操作demo

    这个"SQLite数据库操作demo"旨在提供一个基础的示例,帮助初学者了解如何在Android环境中进行SQLite数据库的创建、查询、更新和删除等基本操作。 首先,Android中的SQLite数据库操作通常涉及以下步骤: 1. **创建...

    安卓SQLite数据库相关-android读取本地.db文件实现不变数据本地化.rar

    本教程将围绕“安卓SQLite数据库相关-android读取本地.db文件实现不变数据本地化”这一主题,探讨如何在Android应用中读取和使用本地SQLite数据库文件,以实现数据的本地化存储。 首先,要在Android应用中使用...

    Qt中SQlite数据库加密SqliteCipher 操作实例,打开多个数据库,附着数据库跨库查询.zip

    在本文中,我们将深入探讨如何在Qt环境中使用SQLite数据库,并特别关注SQLiteCipher的加密功能,以及如何打开多个数据库和执行跨库查询。SQLiteCipher是一种针对SQLite数据库的加密解决方案,它提供了一种安全的方法...

    android sqlite数据库 demo code

    在"android sqlite数据库 demo code"中,我们可以看到一个简单的Android应用示例,该示例演示了如何使用SQLite数据库进行数据的增删改查操作。下面将详细介绍这些关键知识点: 1. **SQLiteOpenHelper**: 这是...

    Android SQLite数据库相关实例.rar

    Android SQLite数据库相关实例源码,代码中的每一个intent都会带一个Bundle型的extras数据。需要对position和id进行一个很好的区分。position指的是点击的这个ViewItem在当前ListView中的位置,每一个和ViewItem绑定...

    AndroidSqlite数据库操作封装SQLiteUtils.zip

    一个简单的基于Android的Sqlite数据库的操作封装,它有如下的好处:便捷地创建表和增添表字段灵活的数据类型处理通过操作对象来insert或者update表记录支持多种查询方式,支持多表自定义的复杂查询,支持分页查询支持...

    Android数据库SQLite详解

    4. 在应用中,通过`getWritableDatabase()`或`getReadableDatabase()`获取数据库实例。 5. 使用`SQLiteDatabase`对象执行CRUD操作,如`execSQL()`执行任意SQL语句,`insert()`, `update()`, `delete()`, 和 `query()...

    android 操作sqlite数据库源码

    通过这个源码实例,开发者可以学习到如何在Android应用中有效地操作SQLite数据库,理解基本的数据操作流程以及如何处理数据库版本变更。这不仅对于初学者来说是宝贵的实践资源,对于经验丰富的开发者也有助于复习和...

    android sqlite数据库 增加、删除、修改,查询系统功能实现

    以上就是Android中SQLite数据库的基本操作。在实际应用中,通常会封装成DAO(Data Access Object)类,提供更方便的操作接口。SQLiteDemo这个压缩包文件很可能包含了实现这些功能的完整示例代码,可以作为参考学习,...

    Android 绿豆通讯录【SQLite数据库】

     Android 绿豆通讯录( SQLite数据库 + ListView数据展示控件 ) https://blog.csdn.net/weixin_44949135/article/details/106029404 采用 SQLite数据库 + ListView数据展示控件,可将用户添加的所有信息,分条...

    android数据库操作实例

    本实例主要探讨的是如何在Android系统中使用SQLite数据库进行操作。SQLite是Android内置的轻量级数据库,适用于移动设备,支持基本的SQL语法。 首先,让我们了解Android中的SQLite数据库基本概念。SQLite数据库通过...

    实验十 使用SQLite数据库存储数据

    "实验十 使用SQLite数据库存储数据"是一个旨在帮助开发者掌握如何在Android应用中集成和操作SQLite数据库的实践练习。 SQLite数据库在Android中的使用主要包括以下几个关键知识点: 1. **SQLiteOpenHelper**: 这是...

    android操作数据库Sqlite源代码

    以上是基于Android操作SQLite数据库的一些核心概念和源代码组织方式。实际开发中,还需要考虑数据同步、数据备份、数据加密等高级功能,以及性能优化,如批量插入、使用索引等。学习并理解这些知识点,将有助于你更...

    Android 操作SQLite数据库实例

    在这个“Android操作SQLite数据库实例”中,我们将深入探讨如何在Android应用中创建、查询、更新和删除SQLite数据库的数据。 首先,我们需要在Android项目中添加SQLiteOpenHelper的子类,这个类是用来帮助我们管理...

Global site tag (gtag.js) - Google Analytics