加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

使用特定方法操作SQLite数据库

发布时间:2020-12-13 00:00:08 所属栏目:百科 来源:网络整理
导读:如果开发者对于SQL语法不熟悉,Android的SQLiteDatabase提供了增、删、改、查语句来操作数据库,虽然Android提供了这些所谓的“便捷”方法操作数据库,但笔者认为这些方法纯属“鸡肋”,毕竟SQL语法是程序员的基本功。不过Android既然提供了这些方法,这里也

如果开发者对于SQL语法不熟悉,Android的SQLiteDatabase提供了增、删、改、查语句来操作数据库,虽然Android提供了这些所谓的“便捷”方法操作数据库,但笔者认为这些方法纯属“鸡肋”,毕竟SQL语法是程序员的基本功。不过Android既然提供了这些方法,这里也简单介绍一下。

1、insert :方法签名:long insert(String table,String nullColumnHack,ContentValues values)

table:表名。

nullColumnHack:强行插入null值的数据列的列名。当values为null或它包含的键值对的数量为0时,就起作用了。它不应是主键列的列名,也不应是非空列的列名。

values:代表一行记录的数据。ContentValues类似于Map集合,存放键值对,键为数据列的列名。

2、update:方法签名:int update(String table,ContentValues values,String whereClause,String[] whereArgs)

table:表名。

values:想更新的数据。

whereClause:条件。

whereArgs:为whereClause子句传入参数。即用来替代占位符的内容。

返回的整数是受此update语句影响的记录的条数。

3、delete:方法签名:int delete(String table,String[] whereArgs)

table:表名

whereClause:条件,满足此条件的记录将会被删除。

whereArgs:用于为whereClause子句传入参数。即替代占位符。

返回的整数是受此delete语句影响的记录的条数。

4、query:方法签名:Cursor query(String table,String[] columns,String selection,String[] selectionArgs,String groupBy,String having,String orderBy)

table:表名

columns:要查询的列名

selection:查询条件子句 相当于where关键字后面的部分。

selectionArgs:为selection传入参数,替代占位符。

groupBy:控制分组,相当于select语句group by后面的部分

having:用于对分组进行过滤,相当于select语句having后面的部分

orderBy:排序。相当于select语句order by后面的部分

下面通过一个简单实例来演示它们的使用,代码如下:

Activity:

package com.lovo.activity;

import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.widget.TextView;
import com.lovo.dao.DBUtil;
import com.lovo.databasetest.R;

public class DatabaseTestActivity extends Activity {
	private TextView show;
	private SQLiteDatabase db;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		show = (TextView) findViewById(R.id.main_tv_show);
		db = DBUtil.getInstance(this);
	}

	public void click(View v) {
		switch (v.getId()) {

		case R.id.main_btn_insert:
			// 添加指定数据
			ContentValues insertValues = new ContentValues();
			insertValues.put("s_name","李四");
			insertValues.put("s_age",23);
			insertValues.put("s_sex","男");
			db.insert("t_stu",null,insertValues);
			break;
		case R.id.main_btn_delete:
			// 根据指定条件删除数据
			db.delete("t_stu","s_name like ?",new String[] { "李_" });
			break;
		case R.id.main_btn_update:
			// 根据指定ID修改数据
			ContentValues updateValues = new ContentValues();
			updateValues.put("s_name","新人名");
			db.update("t_stu",updateValues,"_id=?",new String[] { "2" });
			break;
		case R.id.main_btn_find:
			// 查询所有数据
			Cursor cursor = db.query("t_stu",null);
			// 根据指定条件查询
			// Cursor cursor=db.query("t_stu",new
			// String[]{"张%"},null);
			StringBuffer sb = new StringBuffer();
			while (cursor.moveToNext()) {
				int id = cursor.getInt(cursor.getColumnIndex("_id"));
				String name = cursor.getString(cursor.getColumnIndex("s_name"));
				String sex = cursor.getString(cursor.getColumnIndex("s_sex"));
				int age = cursor.getInt(cursor.getColumnIndex("s_age"));
				sb.append(id + " " + name + " " + sex + " " + age + "n");
			}
			show.setText(sb.toString());
			break;

		}
	}

}

SQLiteOpenHelper子类(DBUtil):

package com.lovo.dao;

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

public class DBUtil extends SQLiteOpenHelper {
	private static DBUtil dbUtil;

	private DBUtil(Context context,String name,CursorFactory factory,int version) {
		super(context,name,factory,version);
	}

	public static SQLiteDatabase getInstance(Context context) {
		if (dbUtil == null) {
			// 指定数据库名为student,需修改时在此修改;此处使用默认工厂;指定版本为1
			dbUtil = new DBUtil(context,"student",1);
		}
		return dbUtil.getReadableDatabase();
	}

	@Override
	public void onCreate(SQLiteDatabase db) {
		try {
			db.execSQL("create table t_stu(_id integer primary key,s_name text,s_age integer,s_sex text)");
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	@Override
	public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion) {
		System.out.println("-----onUpgrade Called-----" + oldVersion + "--->"
				+ newVersion);
	}

}

布局XML:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >


    <Button
        android:id="@+id/main_btn_insert"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="click"
        android:text="添加" />

    <Button
        android:id="@+id/main_btn_delete"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="click"
        android:text="删除" />

    <Button
        android:id="@+id/main_btn_update"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="click"
        android:text="修改" />

    <Button
        android:id="@+id/main_btn_find"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="click"
        android:text="查找" />

    <TextView
        android:id="@+id/main_tv_show"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

</LinearLayout>

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读