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

SQLite存储方式 SQLiteDatabase SQL

阅读更多
package com.eoeAndroid.SQLite;

import android.app.Activity;
import android.content.Context;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;

public class ActivityMain extends Activity {
	OnClickListener listener1 = null;
	OnClickListener listener2 = null;
	OnClickListener listener3 = null;
	OnClickListener listener4 = null;
	OnClickListener listener5 = null;

	Button button1;
	Button button2;
	Button button3;
	Button button4;
	Button button5;

	DatabaseHelper mOpenHelper;

	private static final String DATABASE_NAME = "dbForTest.db";
	private static final int DATABASE_VERSION = 1;
	private static final String TABLE_NAME = "diary";
	private static final String TITLE = "title";
	private static final String BODY = "body";

	/**
	 * SQLiteOpenHelper这个类是一个辅助类。这个类主要生成一个数据库,并对数据库的版本进行管理。
	 * 当在程序中调用这个类的方法getWritableDatabase()或者getReadableDatabase()方法的时候,
	 * 如果当时没有数据,那么android系统就会自动生成一个数据库。SQLiteOpenHelper是一个抽象类,
	 * 我们通常需要继承它,并且实现3个函数。
	 * 
	 * onCreate(SQLiteDatabase ):在数据库第一次生成的时候会调用这个方法,一般在这个方法里
	 * 边生存数据库表
	 * 
	 * onUpgrade(SQLiteDatabase,int,int):在数据库需要升级的时候,Android系统会主动的调用
	 * 这个方法。一般我们在这个方法里边删除数据表,并建立新表,当然是否还需要做其他的操作,完全取决
	 * 于应用的需求。
	 * 
	 * onOpen(SQLiteDatabase):这是当打开数据库时的回调函数,一般用不到
	 */
	private static class DatabaseHelper extends SQLiteOpenHelper {
		DatabaseHelper(Context context) {
			super(context, DATABASE_NAME, null, DATABASE_VERSION);
		}

		@Override
		/**
		 * 一个SQLiteDatabase的实例代表了一个SQLite的数据库,通过SQLiteDatabase实例的一些方法,
		 * 我们可以执行SQL语句,对数据进行增、删、改、查的操作。需要注意的是,数据库对于一个应用来说
		 * 是私有的,并且在一个应用中,数据库的名字也是唯一的。	
		 */
		public void onCreate(SQLiteDatabase db) {

			String sql = "CREATE TABLE " + TABLE_NAME + " (" + TITLE
					+ " text not null, " + BODY + " text not null " + ");";
			Log.i("haiyang:createDB=", sql);
			db.execSQL(sql);
		}
		@Override
		public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
		}
	}

	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		prepareListener();
		initLayout();
		mOpenHelper = new DatabaseHelper(this);
	}

	private void initLayout() {
		button1 = (Button) findViewById(R.id.button1);
		button1.setOnClickListener(listener1);

		button2 = (Button) findViewById(R.id.button2);
		button2.setOnClickListener(listener2);

		button3 = (Button) findViewById(R.id.button3);
		button3.setOnClickListener(listener3);
		button4 = (Button) findViewById(R.id.button4);
		button4.setOnClickListener(listener4);

		button5 = (Button) findViewById(R.id.button5);
		button5.setOnClickListener(listener5);

	}

	private void prepareListener() {
		listener1 = new OnClickListener() {
			public void onClick(View v) {
				CreateTable();
			}
		};
		listener2 = new OnClickListener() {
			public void onClick(View v) {
				dropTable();
			}
		};
		listener3 = new OnClickListener() {
			public void onClick(View v) {
				insertItem();
			}
		};
		listener4 = new OnClickListener() {
			public void onClick(View v) {
				deleteItem();
			}
		};
		listener5 = new OnClickListener() {
			public void onClick(View v) {
				showItems();
			}
		};
	}

	/*
	 * 重新创建数据库
	 */
	private void CreateTable() {
		SQLiteDatabase db = mOpenHelper.getWritableDatabase();
		String sql = "CREATE TABLE " + TABLE_NAME + " (" + TITLE
				+ " text not null, " + BODY + " text not null " + ");";
		Log.i("haiyang:createDB=", sql);

		try {
			db.execSQL("DROP TABLE IF EXISTS diary");
			db.execSQL(sql);
			setTitle("数据表重建成功");
		} catch (SQLException e) {
			setTitle("数据表重建失败");
		}
	}

	/*
	 * 删除数据库
	 */
	private void dropTable() {
		SQLiteDatabase db = mOpenHelper.getWritableDatabase();
		String sql = "drop table " + TABLE_NAME;
		try {
			db.execSQL(sql);
			setTitle("删除数据表成功" + sql);
		} catch (SQLException e) {
			setTitle("删除数据表失败");
		}
	}

	/*
	 *插入2条记录
	 */
	private void insertItem() {
		//mOpenHelper.getWritableDatabase()这条语句负责一个可写的SQLite数据库,如果这个
		//数据库还没有建立,那么mOpenHelper辅助类负责建立这个数据库,如果数据库已经建立,那么直接返回一个可写的数据库
		SQLiteDatabase db = mOpenHelper.getWritableDatabase();
		String sql1 = "insert into " + TABLE_NAME + " (" + TITLE + ", " + BODY
				+ ") values('haiyang', 'android的发展真是迅速阿');";
		String sql2 = "insert into " + TABLE_NAME + " (" + TITLE + ", " + BODY
				+ ") values('icesky', 'android的发真真是迅速啊');";
		try {
			Log.i("haiyang:sql1=", sql1);
			Log.i("haiyang:sql2=", sql2);
			db.execSQL(sql1);
			db.execSQL(sql2);
			setTitle("插入两条数据成功");
		} catch (SQLException e) {
			setTitle("插入两条数据失败");
		}
	}

	/*
	 * 删除一个条数据
	 */
	private void deleteItem() {
		try {
			SQLiteDatabase db = mOpenHelper.getWritableDatabase();
			db.delete(TABLE_NAME, " title = 'haiyang'", null);
			setTitle("删除title为haiyang的一条记录");
		} catch (SQLException e) {

		}
	}

	
	private void showItems() {

		SQLiteDatabase db = mOpenHelper.getReadableDatabase();
		String col[] = { TITLE, BODY };
		Cursor cur = db.query(TABLE_NAME, col, null, null, null, null, null);
		Integer num = cur.getCount();
		setTitle(Integer.toString(num) + " 条记录");
	}
}
分享到:
评论
1 楼 sam_jahn1985 2010-11-10  
这个例子做的很好,看了大概就懂了,谢谢你!

相关推荐

    安卓开发实验6——SQLite和SQLiteDatabase应用

    在本实验“安卓开发实验6——SQLite和SQLiteDatabase应用”中,我们将深入学习如何在Android应用程序中集成SQLite数据库来存储和检索数据,特别是新闻信息。我们将使用ListView组件来动态地展示这些新闻内容,提供...

    Sqlite及SQLiteDatabase的使用

    SQLite是一款轻量级的数据库引擎,它被广泛应用于移动设备、嵌入式系统以及桌面应用程序中,因为它无需单独的...它们为开发者提供了一种便捷的方式来存储和管理应用数据,同时也需要注意性能优化和良好的编程习惯。

    SQLiteDatabase

    在Cocos2d-x这个跨平台的游戏开发框架中,SQLite常常被用来处理游戏内的数据存储,如玩家信息、游戏进度、成就记录等。C++是Cocos2d-x的主要编程语言,因此对SQLite的C++接口进行封装是常见的需求。 标题...

    实验七SQLite和SQLiteDatabase的使用.docx

    【实验七:SQLite和SQLiteDatabase的使用】 在Android开发中,SQLite是一个不可或缺的组件,用于存储和管理应用程序的结构化数据。SQLite是一个轻量级的、嵌入式的、支持事务的SQL数据库引擎,特别适合资源有限的...

    Android数据库sqlite存储

    在Android开发中,SQLite是一个重要的组成部分,它是轻量级的数据库系统,被广泛用于本地数据存储。SQLite数据库在Android应用中扮演着至关重要的角色,它允许开发者创建、修改和管理数据库,无需用户干预,提供了...

    Android数据存储SQLite.docx

    SQLite 数据库存储的使用方法是通过 SQLiteOpenHelper 对象来创建和管理数据库,并使用 SQLiteDatabase 对象来执行 SQL 语句。 五、实验实现 在实验中,我们将使用 SQLite 数据库存储来实现联系人信息的存储和查询...

    无废话Android 系列教程35 [Android下的数据库SQLite事务概念及使用&&测试]

    在Android开发中,数据库是应用不可或缺的一部分,而SQLite作为Android内置的关系型数据库,为我们提供了高效、可靠的存储数据的方式。在本教程中,我们将深入探讨SQLite中的一个重要概念——事务(Transaction),...

    SQLite存储对象类型的数据

    在Android开发中,SQLite是一个非常重要的数据库管理系统,用于存储应用程序中的结构化数据。SQLite支持多种数据类型,包括整型、浮点型、字符串以及BLOB(二进制大对象),这使得它能够处理各种复杂的数据需求。本...

    安卓SQLite数据库相关-在Android平台上动态执行SQL语句.rar

    在Android平台上,SQLite数据库是应用开发中常用的本地数据存储方式,尤其对于那些不需要实时网络连接的应用,SQLite提供了高效且可靠的解决方案。本资料“安卓SQLite数据库相关-在Android平台上动态执行SQL语句.rar...

    android开发sqliteDataBase使用实例

    在Android开发中,SQLite数据库是一种常用的轻量级数据库,它被广泛用于存储应用程序的数据。SQLite是内置在Android系统中的,不需要额外安装任何驱动程序,因此是Android应用进行数据持久化的首选方式。本教程将...

    Android SQLite Database Tutorial_sql_android_

    在Android开发中,SQLite是一个重要的组成部分,它是轻量级的关系型数据库管理系统,广泛用于存储应用程序中的数据。本教程将深入探讨如何在Android应用中使用SQLite数据库,包括创建、查询、更新和删除数据。 首先...

    使用SQL语句操作SQLite数据库

    在Android开发中,SQLite是一个非常重要的组成部分,它是一个轻量级的、开源的、嵌入式的SQL数据库引擎,被广泛用于存储应用程序中的数据。本文将深入讲解如何使用SQL语句来操作SQLite数据库,以实现对Android应用...

    Android 中 如何使用SQLite直接用裸sql进行操作 DatabaseHelper.重新建立数据表、插入两条数据

    在Android开发中,SQLite是一个内置的轻量级数据库系统,用于存储应用程序的数据。SQLite支持SQL语句,使得开发者可以直接对数据库进行操作,如创建表、插入数据等。本篇文章将详细讲解如何在Android中利用SQLite...

    SqliteDatabase应用

    在Android开发中,SQLite数据库是应用内存储数据的常用方式,尤其适合小规模的数据存储。本文将深入探讨如何使用`SqliteDatabase`进行数据库操作,并结合`Menu`来实现查询、新增、修改和删除功能。 首先,`...

    Android-数据库SQLite的简单示例

    数据库 SQLiteDatabase 存储是 Android 中最常用的数据存储方式之一,通过使用 SQLite 数据库来存储数据。SQLite 是一个轻量级的关系数据库管理系统,它可以在 Android 中使用。Android 提供了一个名为 ...

    Android之SQlite存储

    SQLite是一个轻量级的数据库系统,它内嵌在Android操作系统中,允许开发者以结构化方式存储和管理数据。本篇文章将深入探讨Android中的SQLite数据库,包括其基本概念、使用场景、API操作以及优化策略。 SQLite在...

    SQLite数据库存储数据代码

    本篇文章将深入探讨如何使用SQLite数据库在Android中存储数据,特别是通过编程接口SQLiteDatabase进行操作。 首先,`SQLiteDatabase`类提供了四个主要的方法来处理数据: 1. **insert()**:这个方法用于向数据库表...

    Android中数据存储--采用SQLite存储数据及在SDCard中创建数据库

    本篇将详细讲解如何在Android应用中使用SQLite存储数据以及如何在SDCard(外部存储)上创建数据库。 首先,我们需要在Android项目中创建一个SQLite数据库。这通常通过实现`SQLiteOpenHelper`的子类来完成。`...

    android各组件详解- SQLite.

    标题与描述均聚焦于“Android各组件详解- SQLite”,表明文章旨在深入解析Android系统中用于数据存储的关键组件——SQLite数据库。以下将详细阐述该知识点。 ### SQLite:Android中的轻量级数据库 SQLite是一款轻...

    Android的Sqlite数据存储

    总结,SQLite是Android开发中广泛使用的数据存储解决方案,通过SQLiteOpenHelper和SQLiteDatabase,我们可以轻松地进行数据的CRUD操作。"日记本"应用实例展示了如何在实践中运用这些知识,帮助我们更好地理解和掌握...

Global site tag (gtag.js) - Google Analytics