`
y150988451
  • 浏览: 195771 次
  • 性别: 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  
这个例子做的很好,看了大概就懂了,谢谢你!

相关推荐

    Android Studio SQLite数据库使用

    Android Studio 提供了SQLite数据库来存储应用程序的数据。在本文中,我们将介绍如何使用SQLite数据库在Android Studio中,并详细解释SQLiteOpenHelper和SQLiteDatabase的使用方法。 一、SQLiteOpenHelper的使用 ...

    Android使用SQLite数据库的示例

    SQLite使用单个文件存储数据,Android标准库包含SQLite库以及配套使用的一些Java辅助类。主要特点:轻量级,单一文件,跨平台,开源。 二. Android中SQLite数据库的使用 1、创建SQLite数据库 SQLiteDatabase db= ...

    在android studio中用SQLiteOpenHelper()方法建立数据库

    (3)数据库存储——SQLiteDataBase 今天我们讲讲在android studio中利用数据库存储中的SQLiteOpenHelper()方法建立数据库 SQLiteOpenHelper中需要重载函数: onCreate( ):利用SQL语句,在系统中创建数据库(表)...

    Android-嵌入式SQLite数据库.doc

    有两种方式可以执行 CRUD 操作,一种是自己编写 SQL 语句执行操作,另一种是使用 SQLiteDatabase 封装的 insert()、delete()、update()、query() 四个方法。 执行 SQL 语句 使用 SQLiteDatabase 对象的 execSQL() ...

    详解Android中一些SQLite的增删改查操作

    SQLite: SQLite是一个轻量级的数据库,支持基本SQL语法,是常被采用的一种数据存储方式。Android为此数据库提供了一个名为SQLiteDatabase的类,封装了一些操作数据库的API。 SharedPreference: 除SQLite数据库外,...

    Android内置数据库SQLite[参考].pdf

    SQLite是Android操作系统中的一种内置数据库,主要用于存储和管理应用程序中的数据。下面是Android内置数据库SQLite的知识点概述: 一、数据类型 SQLite支持五种基本数据类型:NULL、INTEGER、REAL、TEXT和BLOB。...

    android studio使用SQLiteOpenHelper()建立数据库的方法

    (3)数据库存储——SQLiteDataBase 今天我们讲讲在android studio中利用数据库存储中的SQLiteOpenHelper()方法建立数据库 SQLiteOpenH elper中需要重载函数: onCreate( ):利用SQL语句,在系统中创建数据库(表...

    Android+SQLite数据库实现的生词记事本功能实例

    本文实例讲述了Android+SQLite数据库实现的生词记事本功能。分享给大家供大家参考,具体如下: ...import android.database.sqlite.SQLiteDatabase; import android.os.Bundle; import android.view.Vi

    详解Android轻量型数据库SQLite

    数据库是Android存储方案的核心,在Andorid中SQLite非常轻量,而且执行sql语句甚至比MySQL还要快。 SQLiteDatabase 是 Android 中操作数据库的核心类之一,使用SQLiteDatabase可以打开数据库,也可以对数据库进行...

    Android创建和使用数据库详细指南.doc

    那么就需要一个数据库系统存储你的结构化数据,Android使用SQLite数据库,它是一个开源的、支持多操作系统的SQL数据库,在许多领域广泛使用,如Mozilla FireFox就是使用SQLite来存储配置数据的,iPhone也是使用...

    Android开发中使用sqlite实现新闻收藏和取消收藏的功能

    之前学习oracle,简单的认为数据库...由于SQLite数据库并不需要像C/S数据库那样建立连接以及身份验证的特性,以及SQLite数据库单文件数据库的特性,使得获得SQLiteDatabase对象就像获得操作文件的对象那样简单。  sql

    Android中显示数据库信息.pdf

    Android 中的数据存储可以通过使用 SharedPreferences、Internal Storage、External Storage、SQLite Database 等方式来实现。开发者需要了解 Android 中的数据存储方式以便更好地开发 Android 应用程序。 Android ...

    Android数据库实验.docx

    实验项目:Android数据库实验 一、实验目的 1、理解Android中常用的数据存储方式及各自特点; 2、掌握Sqlite数据库的相关操作; 3、掌握编程访问Sqlite数据库的方法; 二、实验原理 1、数据存储方式:...

    AutoSQLite.swift:SQLite.swift的封装,模型直接存储。获取,无需再转换,增删改查,脱离sql语句

    SQLite.swift的封装,使用swift的反射原理,模型直接存储。获取。无需再转换,增删改改查。脱离sql语句,不需要添加相关的绑定操作,直接完成转换。 使用方法 引进 A. Pod介绍 pod 'AutoSQLiteSwift' B.约会源目录...

    Android数据持久化之SQLite数据库用法分析

    这一节我将总结一下android中的另一种数据存储——SQLite 的相关知识点 SQLite数据库是android系统自带的,主要用到的类包括SQLiteOpenHelper和SQLiteDatabase。 1、SQLiteOpenHelper:创建数据库和数据库版本管理的...

    Android项目期末大作业,附带设计说明书(不用改配置下载解压就能用)

    通过SQLiteDatabase来存储数据,SQLite数据库和其他的SQL数据库不同, 我们并不需要在手机上另外安装一个数据库软件,Android系统已经集成了这个数据库,功能非常强大,而且使用也很方便快捷。下面会详细介绍SQLite...

    android将图片转换存到数据库再从数据库读取转换成图片实现代码

    首先,我们要把图片存入到数据库中,首先要创建一个数据库, 如下所示: ... import java.io.ByteArrayOutputStream;...import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteOpenH

    Android实例代码

    8.3、SQLite数据库:SQL语句; SQLiteDatabase; SQLiteOpenHelper; sqlite3 tools; 8.4、手势(Gesture): 8.5、自动朗读(TTS): 8.6、网络存储: 第9章、使用ContentProvider实现数据共享 9.1、数据共享标准:...

Global site tag (gtag.js) - Google Analytics