• Android之SQLite


    在模拟器运行的情况下,进入cmd运行adb shell 可进入模拟器的linux系统
    输入 lite3 mars_test_db 可进入sqlite模式
    .schema或者.sch 查看有哪些表

    SQLite帮助类

    package com.example.mars_1400_sqlite01;
    
    import android.content.Context;
    import android.database.sqlite.SQLiteDatabase;
    import android.database.sqlite.SQLiteDatabase.CursorFactory;
    import android.database.sqlite.SQLiteOpenHelper;
    
    //DatabaseHelper作为一个访问SQLite的助手类,提供两个方面的功能
    //第一:getReadableDatabase(),getWritableDatabase()可以获得SQLiteDatabase对象,通过该对象可以对数据库进行操作
    //第二:提供了onCreate()和onUpgrade()两个回调函数,允许我们在创建和升级数据库时,进行自己的操作
    public class DatabaseHelper extends SQLiteOpenHelper {
    
        private static final int VERSION = 1;
        //在SQLiteOpenHelper子类中,必须有该构造函数
        public DatabaseHelper(Context context, String name, CursorFactory factory,
                int version) {
            // 必须通过super调用父类当中的构造函数
            super(context, name, factory, version);
        }
    
        public DatabaseHelper(Context context, String name) {
            this(context, name, VERSION);
        }
    
        public DatabaseHelper(Context context, String name, int version) {
            this(context, name, null, version);
        }
    
        //该函数是在第一次创建数据库的时候执行,实际上是在第一次得到SQLiteDatabase对象的时候
        @Override
        public void onCreate(SQLiteDatabase db) {
            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) {
            //当数据库的版本更新时执行
            System.out.println("update a Database");
        }
    
    }

    SQLite增删改查

    public class MainActivity extends Activity {
        private Button createDatabase = null;
        private Button updateDatabase = null;
        private Button insert = null;
        private Button update = null;
        private Button query = null;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
            createDatabase = (Button) findViewById(R.id.createDatabase);
            updateDatabase = (Button) findViewById(R.id.updateDatabase);
            insert = (Button) findViewById(R.id.insert);
            update = (Button) findViewById(R.id.update);
            query = (Button) findViewById(R.id.query);
    
            createDatabase.setOnClickListener(new CreateListener());
            updateDatabase.setOnClickListener(new UpdateListener());
            insert.setOnClickListener(new InsertListener());
            update.setOnClickListener(new UpdateRecordListener());
            query.setOnClickListener(new QueryListener());
            
            /*
             * if (savedInstanceState == null) {
             * getSupportFragmentManager().beginTransaction() .add(R.id.container,
             * new PlaceholderFragment()).commit(); }
             */
        }
    
        class CreateListener implements OnClickListener {
            @Override
            public void onClick(View v) {
                // 创建一个DatabaseHelper对象
                DatabaseHelper dbHelper = new DatabaseHelper(MainActivity.this,
                        "mars_test_db");
                // 只有调用了DatabaseHelper对象的getReadableDatabase()方法,或者是getWritableDatabase()方法之一
                // 才会创建数据库
                SQLiteDatabase db = dbHelper.getReadableDatabase();
            }
        }
    
        class UpdateListener implements OnClickListener {
            @Override
            public void onClick(View v) {
                // 更新数据库的版本
                DatabaseHelper dbHelper = new DatabaseHelper(MainActivity.this,
                        "mars_test_db", 2);
                SQLiteDatabase db = dbHelper.getReadableDatabase();
            }
        }
    
        // 更新操作就相当于执行SQL语句当中的update语句
        // update table_name set xxcol=xx where xxclo=xx...
        class InsertListener implements OnClickListener {
            @Override
            public void onClick(View v) {
                System.out.println("insert data");
                // 生成ContentValues对象
                ContentValues values = new ContentValues();
                // 想该对象当中插入键值对,其中键是列名,值是希望插入到这一列的值,值必须和数据类型匹配
                values.put("id", 2);
                values.put("name", "zhangsan");
                DatabaseHelper dbHelper = new DatabaseHelper(MainActivity.this,
                        "mars_test_db");
                SQLiteDatabase db = dbHelper.getWritableDatabase();
                // 调用insert方法,就可以将数据插入到数据库当中
                db.insert("user", null, values);
            }
        }
    
        class UpdateRecordListener implements OnClickListener {
            @Override
            public void onClick(View v) {
                DatabaseHelper dbHelper = new DatabaseHelper(MainActivity.this,
                        "mars_test_db");
                SQLiteDatabase db = dbHelper.getWritableDatabase();
                ContentValues values = new ContentValues();
                values.put("name", "wzh");
                db.update("user", values, "id=?", new String[] { "1" });
            }
        }
    
        class QueryListener implements OnClickListener {
            @Override
            public void onClick(View v) {
                DatabaseHelper dbHelper = new DatabaseHelper(MainActivity.this,
                        "mars_test_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);
                }
            }
        }
  • 相关阅读:
    统计学(第六版)5-8章总结
    统计学(第六版)1到4单元——学习总结
    图与网络优化——中国邮递员问题
    图与网络优化——最小费用最大流问题
    图与网络优化——最大流的标号法
    图与网络优化——截集
    图与网络——Dijkstra算法
    图与网络优化——避圈法和破圈法
    django面试题
    redis笔记
  • 原文地址:https://www.cnblogs.com/zhuawang/p/3648551.html
Copyright © 2020-2023  润新知