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入门到精通教程
查看: 633|回复: 0

[实例教程]SQLite数据库的插入删除查询操作

[复制链接]

该用户从未签到

发表于 2011-10-22 13:30:01 | 显示全部楼层 |阅读模式
本文讲如何使用Android中内置的SQLite轻量数据库,Android SDK中已经对其进行了封装,使用起来相当简单。创建类继承SQLiteOpenHelper就可以将数据库的创建和应用版本更新后数据库的重建纳入自动管理中。本文实现一个简单的Sqlite数据库,存储人名和电话号码。效果如下截图:



主Activity 类SqliteSample.java 代码:
package jtapp.sqlitesamples;



import android.app.Activity;

import android.database.Cursor;

import android.os.Bundle;

import android.view.View;

import android.view.View.OnClickListener;

import android.widget.Button;

import android.widget.TextView;



public class SqliteSample extends Activity {

        private DBHelper mDBHelper = null;

        private Button btCreateDb = null;

        private Button btInsertData = null;

        private Button btViewData = null;

        private Button btDelOne = null;

        private Button btClearAll = null;

        

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

    @Override

    public void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.main);

        

        btCreateDb = (Button)findViewById(R.id.Button01);

        btCreateDb.setOnClickListener(new ClickViewHandler());

        btInsertData = (Button)findViewById(R.id.Button02);

        btInsertData.setOnClickListener(new ClickViewHandler());

        btInsertData.setEnabled(false);

        btViewData = (Button)findViewById(R.id.Button03);

        btViewData.setOnClickListener(new ClickViewHandler());

        btViewData.setEnabled(false);

        btDelOne = (Button)findViewById(R.id.Button04);

        btDelOne.setOnClickListener(new ClickViewHandler());

        btDelOne.setEnabled(false);

        btClearAll = (Button)findViewById(R.id.Button05);

        btClearAll.setOnClickListener(new ClickViewHandler());

        btClearAll.setEnabled(false);

    }



    public class ClickViewHandler implements OnClickListener {

            @Override

            public void onClick(View v) {

                    if (v == btCreateDb) {

                            createDB();

                    } else if (v == btInsertData) {

                            insertSomeRecords();

                    } else if (v == btViewData) {

                            ViewRecords();

                    } else if (v == btDelOne) {

                            DelOne();

                    } else if (v == btClearAll) {

                            mDBHelper.delAllPeople();

                    }

            }

    }

   

        private void createDB() {

                String DB_NAME = "sqlitedb1";

                mDBHelper = new DBHelper(

                                SqliteSample.this, DB_NAME, null, 1);

                assert(mDBHelper != null);

                btCreateDb.setEnabled(false);

                btInsertData.setEnabled(true);

                btViewData.setEnabled(true);

                btDelOne.setEnabled(true);

        btClearAll.setEnabled(true);

        }

        private void insertSomeRecords() {

                mDBHelper.addPeople("一休", "18602155856");

                mDBHelper.addPeople("巴巴", "13368565525");

        mDBHelper.addPeople("项羽", "057156856225");

        }

        private void ViewRecords() {

                // Make the query

                Cursor c = mDBHelper.getWritableDatabase().query(

                                DBHelper.TB_NAME,null,null,null,null,null,   

                        DBHelper.NAME + " ASC");

                StringBuilder sbRecords = new StringBuilder("");

                if (c.moveToFirst()) {

                        int idxID = c.getColumnIndex(DBHelper.ID);

                        int idxName = c.getColumnIndex(DBHelper.NAME);

                        int idxNumber = c.getColumnIndex(DBHelper.NUMBER1);

                        // Iterator the records

                        do {

                                sbRecords.append(c.getInt(idxID));

                                sbRecords.append(". ");

                                sbRecords.append(c.getString(idxName));

                                sbRecords.append(", ");

                                sbRecords.append(c.getString(idxNumber));

                                sbRecords.append("/n");

                        } while (c.moveToNext());

                }

                c.close();

                // Refresh the content of TextView

                ((TextView)(findViewById(

                                R.id.TextView01))).setText(sbRecords);

        }

        private void DelOne() {

                int id;

                Cursor c = mDBHelper.getWritableDatabase().query(

                                DBHelper.TB_NAME,null,null,null,null,null,   

                        DBHelper.NAME + " ASC");

                if (c.moveToFirst()) {

                        int idxID = c.getColumnIndex(DBHelper.ID);

                        id = c.getInt(idxID);

                        mDBHelper.delPeople(id);

                }

        }

}

ui界面 main.xml 代码,主要是几个bt的放置:
<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

        androidrientation="vertical" android:layout_width="fill_parent"

        android:layout_height="fill_parent">

        <TextView android:layout_width="fill_parent"

                android:layout_height="wrap_content" android:text="@string/hello" />

        <TableRow android:id="@+id/TableRow01" android:layout_width="wrap_content" android:layout_height="wrap_content">

                <Button android:text="create db" android:id="@+id/Button01"

                        android:height="30px" android:layout_width="wrap_content"

                        android:layout_height="wrap_content" />

                <Button android:text="insert some records" android:id="@+id/Button02"

                        android:height="30px" android:layout_width="wrap_content"

                        android:layout_height="wrap_content" />

        </TableRow>

        <TableRow android:id="@+id/TableRow01" android:layout_width="wrap_content" android:layout_height="wrap_content">

        <Button android:text="delete one" android:id="@+id/Button04"

                android:height="30px" android:layout_width="wrap_content"

                android:layout_height="wrap_content" />

        <Button android:text="clear all" android:id="@+id/Button05"

                android:height="30px" android:layout_width="wrap_content"

                android:layout_height="wrap_content" />

        </TableRow>

        <Button android:text="view records" android:id="@+id/Button03"

                android:height="30px" android:layout_width="wrap_content"

                android:layout_height="wrap_content" android:layout_gravity="center"/>

        <TextView android:text="..." android:id="@+id/TextView01"

                android:layout_width="wrap_content"

        android:layout_height="wrap_content" />

</LinearLayout>
数据库操作类 DBHelper.java 代码:
package jtapp.sqlitesamples;



import android.content.ContentValues;

import android.content.Context;

import android.database.sqlite.SQLiteDatabase;

import android.database.sqlite.SQLiteDatabase.CursorFactory;

import android.database.sqlite.SQLiteOpenHelper;



public class DBHelper extends SQLiteOpenHelper {   

   

    public static final String TB_NAME = "people";   

    public static final String ID = "_id";   

    public static final String NAME = "name";   

    public static final String NUMBER1 = "number1";   

   

    public DBHelper(Context context, String name,   

            CursorFactory factory, int version) {   

        super(context, name, factory, version);

        this.getWritableDatabase();  

    }

   

    /**

     * should be invoke when you never use DBhelper

     * To release the database and etc.

     */

    public void Close() {

            this.getWritableDatabase().close();

    }

  

    public void onCreate(SQLiteDatabase db) {   

        db.execSQL("CREATE TABLE IF NOT EXISTS "   

                + TB_NAME + " ("   

                + ID + " INTEGER PRIMARY KEY,"   

                + NAME + " VARCHAR,"  

                + NUMBER1 + " VARCHAR)");   

    }   

  

    public void onUpgrade(SQLiteDatabase db,   

            int oldVersion, int newVersion) {   

        db.execSQL("DROP TABLE IF EXISTS "+TB_NAME);   

        onCreate(db);   

    }

   

    public void addPeople(String name, String number) {

            ContentValues values = new ContentValues();   

        values.put(DBHelper.NAME, name);   

        values.put(DBHelper.NUMBER1, number);   

        this.getWritableDatabase().insert(

                        DBHelper.TB_NAME, DBHelper.ID, values);  

    }

   

    public void delPeople(int id) {

        this.getWritableDatabase().delete(

                        DBHelper.TB_NAME, this.ID + " = " + id, null);

    }

   

    public void delAllPeople() {

        this.getWritableDatabase().delete(

                        DBHelper.TB_NAME, null, null);

    }

}  
数据库操作主要实现了创建数据库,升级数据库的具体操作,封装了插入单条数据,删除单条数据,和删除全部数据的操作。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-22 17:47 , Processed in 0.397464 second(s), 48 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

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