SQLite语句操作数据库

本文介绍了在Android中如何使用SQLite进行数据库操作,包括使用SQL语句插入数据、利用ContentValues提高效率,以及SQLiteOpenHelper类的运用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Android中的SQLite

1.SQL语句的插入数据

package com.example.sqlitedemo1;

import android.os.Bundle;
import android.app.Activity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.util.Log;
import android.view.Menu;

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        // 每个程序都有自己的数据库 默认情况下是各自互相不干扰
        // 创建一个数据库 并且打开
        SQLiteDatabase db = openOrCreateDatabase("user.db", MODE_PRIVATE, null); //定义数据库的名字和让数据库仅本程序访问(Private)

        db.execSQL("create table if not exists usertb (_id integer primary key autoincrement, name text not null , age integer not null , sex text not null )");  //上面下划线_id比较重要 

        db.execSQL("insert into usertb(name,sex,age) values('张三','女',18)");
        db.execSQL("insert into usertb(name,sex,age) values('李四','女',19)");
        db.execSQL("insert into usertb(name,sex,age) values('王五','男',20)");


        Cursor c = db.rawQuery("select * from usertb", null);//查询
        if (c != null) {
            while (c.moveToNext()) {
                Log.i("info", "_id:" + c.getInt(c.getColumnIndex("_id")));
                Log.i("info", "name:" + c.getString(c.getColumnIndex("name")));
                Log.i("info", "age:" + c.getInt(c.getColumnIndex("age")));
                Log.i("info", "sex:" + c.getString(c.getColumnIndex("sex")));
                Log.i("info", "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!");
            }
            c.close(); //释放游标
        }
        db.close();//关闭数据库
    }

}

2.SQL语句可能使用起来易出错,或效率低,因此使用ContentValues:

package com.example.sqlitedemo2;

import android.os.Bundle;
import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.util.Log;
import android.view.Menu;

public class MainActivity extends Activity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        SQLiteDatabase db = openOrCreateDatabase("stu.db", MODE_PRIVATE, null);//新建一个数据库
        db.execSQL("create table if not exists stutb(_id integer primary key autoincrement,name text not null,sex text not null,age integer not null)");
        ContentValues values = new ContentValues();//使用ContentValues
        values.put("name", "张三"); //valuse的put对应的上面的名字要写对
        values.put("sex", "男");
        values.put("age", 19);
        long rowId = db.insert("stutb", null, values);//插入数据
        values.clear();//在下一次插入前要清空valuse
        values.put("name", "张三丰");
        values.put("sex", "男");
        values.put("age", 99);
        db.insert("stutb", null, values);
        values.clear();
        values.put("name", "张三疯");
        values.put("sex", "男");
        values.put("age", 59);
        db.insert("stutb", null, values);
        values.clear();
        values.put("name", "张三峰");
        values.put("sex", "男");
        values.put("age", 39);
        db.insert("stutb", null, values);
        values.clear();
        values.put("name", "张三封");
        values.put("sex", "男");
        values.put("age", 29);
        db.insert("stutb", null, values);

        values.clear();//下面演示了如何更新数据库
        values.put("sex", "女");
        db.update("stutb", values, "_id>?", new String[] { "3" });// 将全部id>3的人的性别改成女
        db.delete("stutb", "name like ?", new String[] { "%丰%" });// 删除所有名字中带有丰的人
        Cursor c = db.query("stutb", null, "_id>?", new String[] { "0" }, null,null, "name");//从id>0查询,x相当于全部查询 按name排序
        if (c != null) {
            String[] columns = c.getColumnNames();//查询出所有字段
            while (c.moveToNext()) { //如果有数据
                for (String columnName : columns) {
                    Log.i("info", c.getString(c.getColumnIndex(columnName)));
                }
            }
            c.close();
        }
        db.close();
    }

}

3.SQLiteOpenHelper类

package com.example.sqlitedemo3;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;

public class DBOpenHelper extends SQLiteOpenHelper{

    public DBOpenHelper(Context context, String name) {
        super(context, name, null, 1);//演示中把版本固定为1
        // TODO Auto-generated constructor stub
    }
    public DBOpenHelper(Context context, String name, CursorFactory factory,
            int version) {
        super(context, name, factory, version);
        // TODO Auto-generated constructor stub
    }

    @Override//首次创建数据库的时候调用 一般可以把建库 建表的操作
    public void onCreate(SQLiteDatabase db) {
        // TODO Auto-generated method stub
        db.execSQL("create table if not exists stutb(_id integer primary key autoincrement,name text not null,sex text not null,age integer not null)");
        db.execSQL("insert into stutb(name,sex,age)values('张三','女',18)");
    }

    @Override//当数据库的版本发生变化的时候 会自动执行
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // TODO Auto-generated method stub

    }

}

在MainActivity中使用

package com.example.sqlitedemo3;

import android.app.Activity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.util.Log;

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        DBOpenHelper helper =   new DBOpenHelper(MainActivity.this, "stu.db");
//      helper.getReadableDatabase();//先以读写方式打开数据库,如果数据库的磁盘空间满了,就会打开失败,当打开失败后会继续尝试以只读方式打开数据库。如果该问题成功解决,则只读数据库对象就会关闭,然后返回一个可读写的数据库对象。getWritableDatabase() 方法以读写方式打开数据库,一旦数据库的磁盘空间满了,数据库就只能读而不能写,使用的是getWritableDatabase() 方法就会出错。
        SQLiteDatabase db = helper.getWritableDatabase();
//      db.query(table, columns, selection, selectionArgs, groupBy, having, orderBy)
        Cursor c = db.rawQuery("select * from stutb", null);
        if (c!=null) {
            String [] cols = c.getColumnNames();
            while (c.moveToNext()) {
                for (String ColumnName : cols) {
                    Log.i("info", ColumnName+":"+c.getString(c.getColumnIndex(ColumnName)));
                }
            }
            c.close();
        }
        db.close();
    }


}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值