sqlite创建数据库并创建一个表

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/activity_main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.example.cunli.sqllite001.MainActivity">

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="新建数据库并创建一个表"
        android:gravity="center"
        android:onClick="openDb"/>
</RelativeLayout>
package com.example.cunli.sqllite001;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;

public class MainActivity extends AppCompatActivity {
SQLiteDatabase sqLiteDatabase;
    private Context context = MainActivity.this;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

    }

    public void openDb(View view){
//以可读写的方式打开或创建一个数据库
    //使用MyOpenHelper打开数据库
        MyOpenHelper myOpenHelper = new MyOpenHelper(context,"school",null,1);
        //使用getReadableDatabase()得到SQLiteDatabase一个对象
        sqLiteDatabase = myOpenHelper.getReadableDatabase();

        //插入一条数据
        String sql = "insert into Students (student_name,mobile,gender) values (?,?,?)";
        sqLiteDatabase.execSQL(sql,new Object[]{"zhangsan","12345678900",Boolean.valueOf(false)});
        //关闭数据库
        sqLiteDatabase.close();
    }
    class MyOpenHelper extends SQLiteOpenHelper{
        public MyOpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
            super(context, name, factory, version);
        }
//只会在第一次创建数据库的时候调用
        @Override
        public void onCreate(SQLiteDatabase db) {
            String createSQL = "CREATE TABLE IF NOT EXISTS Students (_id INTEGER NOT NULL,student_name CHAR(20) NOT NULL,mobile CHAR(20),gender BOOLEAN,PRIMARY KEY(_id))";
            db.execSQL(createSQL);

        }
//这里不需要升级,保留空方法即可
        @Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

        }
    }
}

 

posted @ 2017-01-16 10:52  次序  阅读(3313)  评论(0编辑  收藏  举报