zoukankan      html  css  js  c++  java
  • SqLite的简单操作

    DEMO:     http://pan.baidu.com/s/1APghK

    DatabaseHelper作为一个访问SQLite的助手类,提供两个方面的功能

    1.getReadableDatabase(),getWritableDatabase()可以获得SQLiteDatabse对象,通过该对象可以对数据库进行操作

    2.提供了onCreate()和onUpgrade()两个回调函数,允许我们在创建和升级数据库时,进行自己的操作

    使用Sqlite 的时候首先创建DatabaseHelper类

    package com.sqlite;
    
    
    import android.content.Context;
    import android.database.sqlite.SQLiteDatabase;
    import android.database.sqlite.SQLiteDatabase.CursorFactory;
    import android.database.sqlite.SQLiteOpenHelper;
    
    //DatabaseHelper作为一个访问SQLite的助手类,提供两个方面的功能,
    //第一,getReadableDatabase(),getWritableDatabase()可以获得SQLiteDatabse对象,通过该对象可以对数据库进行操作
    //第二,提供了onCreate()和onUpgrade()两个回调函数,允许我们在创建和升级数据库时,进行自己的操作
    
    public class DatabaseHelper extends SQLiteOpenHelper {
        
        private static final int VERSION = 1;
        //在SQLiteOepnHelper的子类当中,必须有该构造函数
        public DatabaseHelper(Context context, String name, CursorFactory factory,
                int version) {
            //必须通过super调用父类当中的构造函数
            super(context, name, factory, version);
            // TODO Auto-generated constructor stub
        }
        public DatabaseHelper(Context context,String name){
            this(context,name,VERSION);
        }
        public DatabaseHelper(Context context,String name,int version){
            this(context, name,null,version);
        }
    
        //该函数是在第一次创建数据库的时候执行,实际上是在第一次得到SQLiteDatabse对象的时候,才会调用这个方法
        @Override
        public void onCreate(SQLiteDatabase db) {
            // TODO Auto-generated method stub
            System.out.println("create a Database");
            //execSQL函数用于执行SQL语句
            db.execSQL("create table user(id int,name varchar(20))");
        }
    
        @Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
            // TODO Auto-generated method stub
            System.out.println("update a Database");
        }
    
    }

    创建数据库:

    //创建一个DatabaseHelper对象
                DatabaseHelper dbHelper = new DatabaseHelper(MainActivity.this,"test_mars_db");
                //只有调用了DatabaseHelper对象的getReadableDatabase()方法,或者是getWritableDatabase()方法之后,才会创建,或打开一个数据库
                SQLiteDatabase db = dbHelper.getReadableDatabase();

    更新数据库:

    DatabaseHelper dbHelper = new DatabaseHelper(MainActivity.this,"test_mars_db",2);
    SQLiteDatabase db = dbHelper.getReadableDatabase();

    数据库中插入值:

              //生成ContentValues对象
                ContentValues values = new ContentValues();
                //想该对象当中插入键值对,其中键是列名,值是希望插入到这一列的值,值必须和数据库当中的数据类型一致
                values.put("id", 1);
                values.put("name","zhangsan");
                DatabaseHelper dbHelper = new DatabaseHelper(MainActivity.this,"test_mars_db",2);
                SQLiteDatabase db = dbHelper.getWritableDatabase();
                //调用insert方法,就可以将数据插入到数据库当中
                db.insert("user", null, values);

    改变数据库

                // TODO Auto-generated method stub
                //得到一个可写的SQLiteDatabase对象
                DatabaseHelper dbHelper = new DatabaseHelper(MainActivity.this,"test_mars_db");
                SQLiteDatabase db = dbHelper.getWritableDatabase();
                ContentValues values = new ContentValues();
                values.put("name", "zhangsanfeng");
                //第一个参数是要更新的表名
                //第二个参数是一个ContentValeus对象
                //第三个参数是where子句   new String[]{"1"}中的值与问号一一对应
                db.update("user", values, "id=?", new String[]{"1"});

    查询数据库

                System.out.println("aaa------------------");
                Log.d("myDebug", "myFirstDebugMsg");
                
                DatabaseHelper dbHelper = new DatabaseHelper(MainActivity.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);
  • 相关阅读:
    清北刷题班day3 morning
    [NOI1997] 积木游戏(dp)
    [NOI1999] 棋盘分割(推式子+dp)
    2017北京国庆刷题Day7 afternoon
    湖南集训day8
    湖南集训day7
    湖南集训day6
    湖南集训day5
    湖南集训day4
    湖南集训day3
  • 原文地址:https://www.cnblogs.com/yuqilihualuo/p/4027652.html
Copyright © 2011-2022 走看看