Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 1087|回复: 0

[实例教程]Android 小项目之--SQLite 使用法门 (附源码)

[复制链接]

该用户从未签到

发表于 2011-10-22 12:50:59 | 显示全部楼层 |阅读模式
  每个应用程序都要使用数据,Android应用程序也不例外,Android使用开源的、与操作系统无关的SQL数据库 --大名鼎鼎的SQLite。SQLite是一款轻量级数据库,它的设计目的是嵌入式,而且它占用的资源非常少,在嵌入式设备中,可能只需要几百KB,这也是 Android 系统采用 SQLite 数据库的原因之一吧。

  简介轻量级使用 SQLite 只需要带一个动态库,就可以享受它的全部功能,而且那个动态库的尺寸想当小。

  独立性SQLite 数据库的核心引擎不需要依赖第三方软件,也不需要所谓的“安装”。

  隔离性SQLite 数据库中所有的信息(比如表、视图、触发器等)都包含在一个文件夹内,方便管理和维护。

  跨平台SQLite 目前支持大部分操作系统,不至电脑操作系统更在众多的手机系统也是能够运行,比如:Android。

  多语言接口SQLite 数据库支持多语言编程接口。

  安全性SQLite 数据库通过数据库级上的独占性和共享锁来实现独立事务处理。这意味着多个进程可以在同一时间从同一数据库读取数据,但只能有一个可以写入数据。

  SQLite使用介绍首先先来看一下本篇例子继承 SQLiteOpenHelper 类实现的 dbHelper 类。
package com.terry;



import android.content.ContentValues;

import android.content.Context;

import android.database.Cursor;

import android.database.sqlite.SQLiteDatabase;

import android.database.sqlite.SQLiteOpenHelper;

import android.database.sqlite.SQLiteDatabase.CursorFactory;



public class dbHelper extends SQLiteOpenHelper {



    private final static String DATABASE_NAME="sec_db";

    private final static int DATABASE_VERSION=1;

    private final static String TABLE_NAME="sec_pwd";

    public final static String FIELD_ID="_id";

    public final static String FIELD_TITLE="sec_Title";

   

   

    public dbHelper(Context context)

    {

        super(context, DATABASE_NAME,null, DATABASE_VERSION);

    }

   

   

     

    @Override

    public void onCreate(SQLiteDatabase db) {

        // TODO Auto-generated method stub

        String sql="Create table "+TABLE_NAME+"("+FIELD_ID+" integer primary key autoincrement,"

        +FIELD_TITLE+" text );";

        db.execSQL(sql);

        

         

    }



    @Override

    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

        // TODO Auto-generated method stub

        String sql=" DROP TABLE IF EXISTS "+TABLE_NAME;

        db.execSQL(sql);

        onCreate(db);

    }



    public Cursor select()

    {

        SQLiteDatabase db=this.getReadableDatabase();

        Cursor cursor=db.query(TABLE_NAME, null, null, null, null, null,  " _id desc");

        return cursor;

    }

   

    public long insert(String Title)

    {

        SQLiteDatabase db=this.getWritableDatabase();

        ContentValues cv=new ContentValues();

        cv.put(FIELD_TITLE, Title);

        long row=db.insert(TABLE_NAME, null, cv);

        return row;

    }

   

    public void delete(int id)

    {

        SQLiteDatabase db=this.getWritableDatabase();

        String where=FIELD_ID+"=?";

        String[] whereValue={Integer.toString(id)};

        db.delete(TABLE_NAME, where, whereValue);

    }

   

    public void update(int id,String Title)

    {

        SQLiteDatabase db=this.getWritableDatabase();

        String where=FIELD_ID+"=?";

        String[] whereValue={Integer.toString(id)};

        ContentValues cv=new ContentValues();

        cv.put(FIELD_TITLE, Title);

        db.update(TABLE_NAME, cv, where, whereValue);

    }

   

   

   

   

}

  创建和打开数据库上篇通过构造函数来创建数据库,看一下构造函数的方法
android.database.sqlite.SQLiteOpenHelper.SQLiteOpenHelper(Context context, String name, CursorFactory factory, int version)



public SQLiteOpenHelper (Context context, String name, SQLiteDatabase.CursorFactory factory, int version)

Since: API Level 1

Create a helper object to create, open, and/or manage a database. The database is not actually created or opened until one of getWritableDatabase() or getReadableDatabase() is called.



Parameters

context  to use to open or create the database

name  of the database file, or null for an in-memory database

factory  to use for creating cursor objects, or null for the default

version  number of the database (starting at 1); if the database is older, onUpgrade(SQLiteDatabase, int, int) will be used to upgrade the database  



Public Methods
  大体可以理成如下:如果进入此函数,不存在此数据库则创建,如果存在此数据库则打开连接,只要进入此方法就可以用打开的连接获得getWritableDatabase()或getReadableDatabase()这两个方法。

  创建表--》Create Table一个数据库中可以包含多个表,每一条数据都存在指定的表中,要创建可以通过 execSQL 方法来执行一条 SQL 语句。上面的方法为
public void onCreate(SQLiteDatabase db) {

        // TODO Auto-generated method stub

        String sql="Create table "+TABLE_NAME+"("+FIELD_ID+" integer primary key autoincrement,"

        +FIELD_TITLE+" text );";

        db.execSQL(sql);

        

         

    }

  上面代码创建了表名为“sec_pwd” 的数据表,表内存在一个 integer 类型的主键和一个 text 类型的字段,并执行创建该表。

  添加数据--》Insert上面的代码封装了一个使用SQLite 的 insert 方法,向表中添加数据,但是insert 方法要求把数据都打包到 ContentValues 中, ContentValue 其实可就是一个 HashTable,Key值是字段名称,Value 值是字段的值。通过 ContentValues 的put 方法就可以把数据库放到 ContentValue 对象中,然后插入到表中去。代码为:

public long insert(String Title)

    {

        SQLiteDatabase db=this.getWritableDatabase();

        ContentValues cv=new ContentValues();

        cv.put(FIELD_TITLE, Title);

        long row=db.insert(TABLE_NAME, null, cv);

        return row;

    }
  删除数据--》Delete依此类推,添加数据用Insert,那么删除数据为Delete
public void delete(int id)

    {

        SQLiteDatabase db=this.getWritableDatabase();

        String where=FIELD_ID+"=?";

        String[] whereValue={Integer.toString(id)};

        db.delete(TABLE_NAME, where, whereValue);

    }
  修改数据--》Update
public void update(int id,String Title)

    {

        SQLiteDatabase db=this.getWritableDatabase();

        String where=FIELD_ID+"=?";

        String[] whereValue={Integer.toString(id)};

        ContentValues cv=new ContentValues();

        cv.put(FIELD_TITLE, Title);

        db.update(TABLE_NAME, cv, where, whereValue);

    }
  可根据自己需要修改字段自行加参数。

  查询数据--》Query
public Cursor select()

    {

        SQLiteDatabase db=this.getReadableDatabase();

        Cursor cursor=db.query(TABLE_NAME, null, null, null, null, null,  " _id desc");

        return cursor;

    }

在 Android 中查询数据是通过 Cursor 类来实现的,当我们使用SQLiteDatabase.query()方法时,会得到一个Cursor对象,Cursor指向的就是每一条数据。它提供了很多有关查询的方法,具体截图如下:  



  现在dbHelper己经封装完毕,接下来正式进入到我们实际例子中要操作的功能吧,项目运行效果图:  
  这里用到了Menu做功能按钮,实例代码如下:
package com.terry;



import android.app.Activity;

import android.database.Cursor;

import android.database.sqlite.SQLiteCursor;

import android.os.Bundle;

import android.view.Menu;  

import android.view.MenuItem;

import android.view.View;

import android.widget.AdapterView;

import android.widget.EditText;

import android.widget.ListAdapter;

import android.widget.ListView;

import android.widget.SimpleCursorAdapter;

import android.widget.AdapterView.OnItemClickListener;

import android.widget.AdapterView.OnItemSelectedListener;





public class testDbActivity extends Activity {

   

    private dbHelper db;

    private Cursor myCursor;

    private ListView myListView;

    private EditText myEditText;

    private int _id;

    protected final static int MENU_ADD=Menu.FIRST;

    protected final static int MENU_EDIT=Menu.FIRST+1;

    protected final static int MENU_DELETE=Menu.FIRST+2;

   

       @Override

    public boolean onCreateOptionsMenu(Menu menu) {

        // TODO Auto-generated method stub

           super.onCreateOptionsMenu(menu);

        menu.add(Menu.NONE, MENU_ADD, 0, R.string.ADD);

        menu.add(Menu.NONE, MENU_EDIT, 0,R.string.EDIT);

        menu.add(Menu.NONE, MENU_DELETE, 0,R.string.DELETE);

         return true;

    }

   

       @Override

    public boolean onOptionsItemSelected(MenuItem item) {

        // TODO Auto-generated method stub

        

        super.onOptionsItemSelected(item);

        switch (item.getItemId()) {

        case MENU_ADD:

            operation("add");

            break;

        case MENU_EDIT:

            operation("edit");

            break;

        case MENU_DELETE:

            operation("delete");

            break;

        default:

            break;

        }

        return true;

    }

      

      

      

    /** Called when the activity is first created. */

    @Override

    public void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.main);

        myEditText=(EditText)findViewById(R.id.EditText1);

        myListView=(ListView)findViewById(R.id.ListView1);

        db=new dbHelper(testDbActivity.this);

        myCursor=db.select();

        SimpleCursorAdapter adpater=new SimpleCursorAdapter(this

                , R.layout.test, myCursor,

                new String[]{dbHelper.FIELD_TITLE},

                new int[]{R.id.topTextView});

        myListView.setAdapter(adpater);

        

        myListView.setOnItemClickListener(new OnItemClickListener() {



            @Override

            public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,

                    long arg3) {

                // TODO Auto-generated method stub

                myCursor.moveToPosition(arg2);

                _id=myCursor.getInt(0);

                myEditText.setText(myCursor.getString(1));

            }

        });

        

        

        myListView.setOnItemSelectedListener(new OnItemSelectedListener() {



            @Override

            public void onItemSelected(AdapterView<?> arg0, View arg1,

                    int arg2, long arg3) {

                // TODO Auto-generated method stub

                SQLiteCursor sc=(SQLiteCursor)arg0.getSelectedItem();

                _id=sc.getInt(0);

                myEditText.setText(sc.getString(1));

            }



            @Override

            public void onNothingSelected(AdapterView<?> arg0) {

                // TODO Auto-generated method stub

               

            }

        });

    }

    private void operation(String cmd)

    {

        if(myEditText.getText().toString().equals(""))

        return;

        if(cmd=="add")

            db.insert( myEditText.getText().toString());

        if(cmd=="edit")

            db.update(_id,  myEditText.getText().toString());

        if(cmd=="delete")

            db.delete(_id);

        myCursor.requery();

        myListView.invalidateViews();

        myEditText.setText("");

        _id=0;

        

    }

   

   

   

   

   

   

   

   

   

}
 至此,功能己经基本完成。源码下载:  testDb.rar (49.56 KB, 下载次数: 55)
回复

使用道具 举报

该用户从未签到

发表于 2011-10-22 12:51:09 | 显示全部楼层

Re:[实例教程]Android

很好很强大,拿走咯
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-22 12:51:14 | 显示全部楼层

Re:[实例教程]Android

试试看这个方法
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-22 12:51:25 | 显示全部楼层

Re:[实例教程]Android

回复下载啰。。
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-22 12:51:31 | 显示全部楼层

Re:[实例教程]Android

我就是 想一个人 搞点小项目啊。。
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-22 12:51:36 | 显示全部楼层

Re:[实例教程]Android

我就是 想一个人 搞点小项目啊。。
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-22 12:51:41 | 显示全部楼层

Re:[实例教程]Android

我就是 想一个人 搞点小项目啊。。
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-22 12:51:46 | 显示全部楼层

Re:[实例教程]Android

正在研究数据库……
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

GMT+8, 2025-1-22 16:46 , Processed in 0.379773 second(s), 45 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表