`
xifangyuhui
  • 浏览: 188660 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Android之SQLite学习

阅读更多

SQLite介绍

 

SQLite是轻量级的、嵌入式的、关系型数据库,目前已经在iPhone、Android等手机系统中使用,SQLite可移植性好,很容易使用,很小,高效而且可靠。SQLite嵌入到使用它的应用程序中,它们共用相同的进程空间,而不是单独的一个进程。从外部看,它并不像一个RDBMS,但在进程内部,它却是完整的,自包含的数据库引擎。

 

在android中当需要操作SQLite数据库的时候需要得到一个SQLiteOpenHelper对象,而SQLiteOpenHelper是一个抽象类,用户需要继承这个类,并实现该类中的一些方法。

1、继承SQLiteOpenHelper之后就拥有了以下两个方法:

getReadableDatabase() 创建或者打开一个查询数据库

getWritableDatabase()创建或者打开一个可写数据库

他们都会返回SQLiteDatabase对象,用户通过得到的SQLiteDatabase对象进行后续操作

2、同时用户还可以覆盖以下回调函数,再对数据库进行操作的时候回调以下方法:

onCreate(SQLiteDatabase):在数据库第一次创建的时候会调用这个方法,一般我们在这个方法里边创建数据库表。 
onUpgrade(SQLiteDatabase,int,int):当数据库需要修改的时候,Android系统会主动的调用这个方法。一般我们在这个方法里边删除数据库表,并建立新的数据库表,当然是否还需要做其他的操作,完全取决于应用程序的需求。 
onOpen(SQLiteDatabase):这是当打开数据库时的回调函数,一般也不会用到。

需要注意:

1、在SQLiteOepnHelper的子类当中,必须有以下该构造函数

 

public DatabaseHelper(Context context, String name, CursorFactory factory,

int version) {

//必须通过super调用父类当中的构造函数

super(context, name, factory, version);

}

 

为了方便,也可以创建其它的构造函数,含二个参数或者三个参数的。

2、函数public void onCreate(SQLiteDatabase db)是在调用getReadableDatabase()或者是getWritableDatabase()第一次创建数据库的时候执行,实际上是在第一次得到SQLiteDatabse对象的时候,才会调用这个方法.

 

public void onCreate(SQLiteDatabase db) {

System.out.println("create a Database");

//execSQL函数用于执行SQL语句

db.execSQL("create table user(id int,name varchar(20))");

}

 

在向数据库的表中插入记录时,需要先将数据包含在一个ContentValues中,向该对象当中插入键值对,其中键是列名,值是希望插入到这一列的值,值必须和数据库当中的数据类型一致。接着调用Databasehelper的getWritableDatabase方法来获得可以写入的Databasehelper对象,再向其中insert记录。注意调用DatabaseHelper对象的insert,update或者query方法的参数的传递。

另外执行query方法后,返回的是一个Cursor游标,游标最开始指向的是记录集合中第一行的上一行,因此首先需要先调用cursor.next()将游标移动到记录集合的第一行,接着再获取数据即可。

 

 

public class SQLiteActivity extends Activity {
    /** Called when the activity is first created. */
	private Button createButton;
	private Button insertButton;
	private Button updateButton;
	private Button updateRecordButton;
	private Button queryButton;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        createButton = (Button)findViewById(R.id.createDatabase);
        updateButton = (Button)findViewById(R.id.updateDatabase);
        insertButton = (Button)findViewById(R.id.insert);
        updateRecordButton = (Button)findViewById(R.id.update);
        queryButton = (Button)findViewById(R.id.query);
        createButton.setOnClickListener(new CreateListener());
        updateButton.setOnClickListener(new UpdateListener());
        insertButton.setOnClickListener(new InsertListener());
        updateRecordButton.setOnClickListener(new UpdateRecordListener());
        queryButton.setOnClickListener(new QueryListener());
    }
    class CreateListener implements OnClickListener{
		@Override
		public void onClick(View v) {
			//创建一个DatabaseHelper对象
			DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db");
			//只有调用了DatabaseHelper对象的getReadableDatabase()方法,或者是getWritableDatabase()方法之后,才会创建,或打开一个数据库
			SQLiteDatabase db = dbHelper.getReadableDatabase();
		}
    }
    class UpdateListener implements OnClickListener{

		@Override
		public void onClick(View v) {
			DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db",2);
			SQLiteDatabase db = dbHelper.getReadableDatabase();
		}
    	
    }
    class InsertListener implements OnClickListener{

		@Override
		public void onClick(View v) {
			//生成ContentValues对象
			ContentValues values = new ContentValues();
			//想该对象当中插入键值对,其中键是列名,值是希望插入到这一列的值,值必须和数据库当中的数据类型一致
			values.put("id", 1);
			values.put("name","zhangsan");
			DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db",2);
			SQLiteDatabase db = dbHelper.getWritableDatabase();
			//调用insert方法,就可以将数据插入到数据库当中
			db.insert("user", null, values);
		}
    }
    //更新操作就相当于执行SQL语句当中的update语句
    //UPDATE table_name SET XXCOL=XXX WHERE XXCOL=XX...
    class UpdateRecordListener implements OnClickListener{

		@Override
		public void onClick(View arg0) {
			// TODO Auto-generated method stub
			//得到一个可写的SQLiteDatabase对象
			DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db");
			SQLiteDatabase db = dbHelper.getWritableDatabase();
			ContentValues values = new ContentValues();
			values.put("name", "zhangsanfeng");
			//第一个参数是要更新的表名
			//第二个参数是一个ContentValeus对象
			//第三个参数是where子句
			db.update("user", values, "id=?", new String[]{"1"});
		}
    }
    class QueryListener implements OnClickListener{

		@Override
		public void onClick(View v) {
			System.out.println("aaa------------------");
			Log.d("myDebug", "myFirstDebugMsg");
			
			DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db");
			SQLiteDatabase db = dbHelper.getReadableDatabase();
			Cursor cursor = db.query("user", new String[]{"id","name"}, "id=?", new String[]{"1"}, null, null, null);
			while(cursor.moveToNext()){
				String name = cursor.getString(cursor.getColumnIndex("name"));
				System.out.println("query--->" + name);
			}
		}
    }
    
}
 

 

0
0
分享到:
评论

相关推荐

    Android SQLite学习工具

    这篇博客“Android SQLite学习工具”可能详细介绍了如何在Android环境中使用SQLite进行数据操作,并提供了一个实用的SQLite管理工具——sqlite3.exe。 SQLite数据库在Android中的应用主要包括创建数据库、创建表、...

    android之sqlite实现增删改查

    "Android之SQLite实现增删改查" Android平台中,SQLite是一种轻量级的关系型数据库,广泛应用于移动应用开发中。在本例子中,我们将学习如何使用SQLite来实现增删改查操作。 标题解释 "Android之SQLite实现增删改...

    android-sqlite-encrypt

    同时,该库兼容Android的SQLiteOpenHelper,允许开发者使用熟悉的API进行数据库操作,降低了学习和使用的难度。 在实际应用中,"android-sqlite-encrypt"还可以与其他安全措施结合,如使用安全的密钥存储机制(如...

    Android基于Sqlite的学生信息管理系统.zip

    《Android基于SQLite的学生信息管理系统详解》 在信息技术日益发达的今天,信息管理系统的应用已经渗透...这样的系统不仅简化了教育机构的日常管理工作,也为学习者提供了深入了解Android开发和数据库管理的实践平台。

    android数据库SQLite学习笔记.pdf

    android数据库SQLite学习笔记.pdf

    android学习之SQLite总结(1)

    LiveData是Android架构组件之一,用于实现数据的观察者模式,确保UI实时更新。Room是SQLite的抽象层,提供了更高级别的API,简化了数据库操作,并自动处理线程同步。 8. **事务处理**: SQLite支持事务,可以确保...

    基于Android+SQLite开发医院收费管理系统应用程序【100013180】

    总结,基于Android+SQLite开发的医院收费管理系统是一个综合性的项目,涵盖了移动应用开发、数据库设计、用户界面构建等多个方面,对于学习和提升Android开发技能具有很高的实践价值。通过这个系统,开发者不仅可以...

    Android+sqlite

    总的来说,这个Android+SQLite的人员管理系统项目是学习移动应用开发和数据库操作的一个好案例。它涵盖了Android的基本组件使用、SQLite数据库操作、数据持久化、用户交互等核心知识点,对于初学者来说,既能提升...

    Android数据库SQLite手动建库适合小白学习的代码清晰易懂

    Android数据库SQLite手动建库的代码页,适合小白学习分析Android代码。即便是刚刚接触的Android的学生,看里面的两行注释也能明白。 程序运行效果,在File Explore里面的Date/Date/<packageName>/database下会看到...

    android操作数据库Sqlite源代码

    在Android开发中,SQLite是一个非常重要的组成部分,它是一个轻量级的数据库系统,适用于移动设备。SQLite被集成在Android操作系统中,...学习并理解这些知识点,将有助于你更好地在Android项目中运用SQLite数据库。

    Android学习之SQLite练习(一)

    总的来说,Android应用中的SQLite学习是一个重要的环节,它涉及到数据持久化的基础。SQLiteOpenHelper和SQLiteDatabase提供的API使得我们可以方便地管理和操作数据库,而无需深入理解SQL的底层实现。通过不断的练习...

    Android SQLite源码+说明

    总的来说,这个资料包为Android开发者提供了一个深入了解SQLite的机会,无论是从理论层面的文档学习,还是实践层面的源码分析,都能帮助开发者提高在Android平台上使用SQLite的技能,从而编写出更加高效和可靠的...

    Android Database SQLite 多表操作源码

    在Android开发中,SQLite数据库是默认的轻量级数据库,用于存储应用的数据。...通过分析和运行这个源码,你可以学习如何在Android Studio中有效地管理和操作SQLite数据库,提升你的应用数据管理能力。

    android连接SQLite数据库源码.rar

    以上就是Android应用连接SQLite数据库的基本知识点,通过提供的源码,你可以深入理解这些概念并学习如何在实际项目中应用它们。请仔细研究源码,以便更好地掌握Android与SQLite数据库的交互技巧。

    AndroidSQLite开发案例

    综上所述,“AndroidSQLite开发案例”涵盖了Android应用中SQLite数据库的基本使用,包括数据库的创建、操作接口的封装、数据的CRUD操作以及事务处理等核心概念。这样的案例对于学习和实践Android数据库编程非常有...

    Android 对sqlite的封装,实现CRUD

    大家好,个人觉得用Sqlite数据库时,经常需要进行机械性的CRUD操作,故对其进行了一下封装,希望能起到抛砖引玉的作用。 目的:封装共有的CRUD 下面简单的说一下使用步骤,如果觉得多余,可以无视。 1. 实现自己...

    Android Studio SQLite学习

    总的来说,SQLite是Android应用程序中存储结构化数据的重要工具,熟练掌握其基本操作是Android开发者必备的技能之一。通过Android Studio提供的SQLiteOpenHelper和Cursor,我们可以高效、安全地管理和操作数据库。

    Android 简单通讯录 Sqlite

    在Android开发中,SQLite是一个非常重要的组成部分,尤其在构建如通讯录这样的数据密集型应用时。SQLite是一个开源、轻量级、嵌入式的关系型数据库,它不需要单独的服务进程,可以直接在应用程序中进行操作,因此在...

    Android使用SQLite数据库

    ### Android使用SQLite数据库知识点详解 #### 一、SQLite简介及特点 ...通过以上知识点的学习,开发者可以更好地理解如何在Android应用中使用SQLite数据库,从而实现更高效、可靠的数据管理功能。

    Android开发学习教程—Android使用SQLite数据库

    ### Android开发学习教程—深入解析Android使用SQLite数据库 #### SQLite数据库概述 SQLite是一款轻量级、高性能的嵌入式数据库,被广泛应用于各种资源受限的环境中,如移动设备。它支持标准的SQL语言,占用内存极...

Global site tag (gtag.js) - Google Analytics