SQLite 数据库增删改查
布局:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context="net.bwie.localdata.MainActivity"> <Button
android:id="@+id/insert_btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="插入"/> <Button
android:id="@+id/delete_btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="删除"/> <Button
android:id="@+id/update_btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="修改"/>
<Button
android:id="@+id/query_btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="查询"/> </LinearLayout>
Activivy:
 public class MainActivity extends AppCompatActivity implements View.OnClickListener {
     protected Button mInsertBtn;
     protected Button mDeleteBtn;
     protected Button mUpdateBtn;
     protected Button mQueryBtn;
     private DBHelper mHelper;
     private SQLiteDatabase mDatabase;
     @Override
     protected void onCreate(Bundle savedInstanceState) {
         super.onCreate(savedInstanceState);
         super.setContentView(R.layout.activity_main);
         initView();
         mHelper = new DBHelper(this);
         mDatabase = mHelper.getWritableDatabase();
     }
     private void initView() {
         mInsertBtn = (Button) findViewById(R.id.insert_btn);
         mInsertBtn.setOnClickListener(MainActivity.this);
         mDeleteBtn = (Button) findViewById(R.id.delete_btn);
         mDeleteBtn.setOnClickListener(MainActivity.this);
         mUpdateBtn = (Button) findViewById(R.id.update_btn);
         mUpdateBtn.setOnClickListener(MainActivity.this);
         mQueryBtn = (Button) findViewById(R.id.query_btn);
         mQueryBtn.setOnClickListener(MainActivity.this);
     }
     @Override
     public void onClick(View view) {
         if (view.getId() == R.id.insert_btn) {
             insertData();
         } else if (view.getId() == R.id.delete_btn) {
             deleteData();
         } else if (view.getId() == R.id.update_btn) {
             updateData();
         } else if (view.getId() == R.id.query_btn) {
             queryData();
         }
     }
     // 表名
     // null。数据库如果插入的数据为null,会引起数据库不稳定。为了防止崩溃,需要传入第二个参数要求的对象
     // 如果插入的数据不为null,没有必要传入第二个参数避免崩溃,所以为null
     // 插入的数据
     private void insertData() {
         ContentValues values = new ContentValues();
         values.put(DBHelper.NAME, "鹿晗");
         values.put(DBHelper.AGE, 17);
         mDatabase.insert(DBHelper.TABLE_NAME, null, values);
         Toast.makeText(this, "插入成功", Toast.LENGTH_SHORT).show();
     }
     // 表名
     // 删除条件
     // 满足删除的值
     private void deleteData() {
         int count = mDatabase.delete(DBHelper.TABLE_NAME, DBHelper.NAME + " = ?", new String[]{"鹿晗"});
         Toast.makeText(this, "删除数量:"+count, Toast.LENGTH_SHORT).show();
     }
     // 表名
     // 修改后的数据
     // 修改条件
     // 满足修改的值
     private void updateData() {
         ContentValues values = new ContentValues();
         values.put(DBHelper.NAME, "小茗同学");
         values.put(DBHelper.AGE, 18);
         int count = mDatabase
                 .update(DBHelper.TABLE_NAME, values, DBHelper.NAME + " = ?", new String[]{"鹿晗"});
         Toast.makeText(this, "修改成功:" + count, Toast.LENGTH_SHORT).show();
     }
     // 表名
     // 查询字段
     // 查询条件
     // 满足查询的值
     // 分组
     // 分组筛选关键字
     // 排序
     private void queryData() {
         Cursor cursor = mDatabase.query(DBHelper.TABLE_NAME,
                 new String[]{DBHelper.NAME, DBHelper.AGE},
                 DBHelper.AGE + " > ?",
                 new String[]{"16"},
                 null,
                 null,
                 DBHelper.AGE + " desc");// 注意空格!
         int nameIndex = cursor.getColumnIndex(DBHelper.NAME);
         int ageIndex = cursor.getColumnIndex(DBHelper.AGE);
         while (cursor.moveToNext()) {
             String name = cursor.getString(nameIndex);
             String age = cursor.getString(ageIndex);
             Log.d("1507", "name: " + name + ", age: " + age);
         }
     }
 }
创建数据库:
 public class DBHelper extends SQLiteOpenHelper {
     // 数据库文件名
     public static final String DB_NAME = "my_database.db";
     // 数据库表名
     public static final String TABLE_NAME = "t_person";
     // 数据库版本号
     public static final int DB_VERSION = 1;
     public static final String NAME = "name";
     public static final String AGE = "age";
     public DBHelper(Context context) {
         super(context, DB_NAME, null, DB_VERSION);
     }
     // 当数据库文件创建时,执行初始化操作,并且只执行一次
     @Override
     public void onCreate(SQLiteDatabase db) {
         // 建表
         String sql = "create table " +
                 TABLE_NAME +
                 "(_id integer primary key autoincrement, " +
                 NAME + " varchar, " +
                 AGE + " varchar"
                 + ")";
         db.execSQL(sql);
     }
     // 当数据库版本更新执行该方法
     @Override
     public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
     }
 }
SQLite 数据库增删改查的更多相关文章
- (转)SQLite数据库增删改查操作
		
原文:http://www.cnblogs.com/linjiqin/archive/2011/05/26/2059182.html SQLite数据库增删改查操作 一.使用嵌入式关系型SQLite数 ...
 - Android SQLite 数据库 增删改查操作
		
Android SQLite 数据库 增删改查操作 转载▼ 一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库--SQLite,SQLite3支持NU ...
 - IOS sqlite数据库增删改查
		
1.简单介绍 简单封装sqlite数据库操作类 BaseDB 用于完毕对sqlite的增删改查.使用前先导入libsqlite3.0.dylib库 2.BaseDB.h // // BaseDB.h ...
 - 使用C#书写SQLite数据库增删改查语句(以及插入byte[]时遇到的问题总结)
		
在没有使用SQLite这种轻量级的数据库之前,只使用过Sqlserver2008进行数据的增删改查,公司使用的是大型的ORACLE数据库,还没有真正的会使用它.那时候觉得数据库很庞大,然而遇到SQLi ...
 - SQLite数据库增删改查操作
		
一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库——SQLite,SQLite3支持NULL.INTEGER.REAL(浮点数字).TEXT(字符串 ...
 - Android SQLite数据库增删改查操作
		
一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库——SQLite,SQLite3支持NULL.INTEGER.REAL(浮点数字). TEXT(字符 ...
 - SQLite数据库增删改查
		
一:SQLite数据库简介: SQLite是一种轻量级的关系型数据库,官网:http://www.sqlite.org/. SQLite数据库文件存在于移动设备的一下目录中:data->data ...
 - 通过API函数来控制SQLite数据库增删改查
		
person类属性有Intenger id,String name,Intenger age,相应的构造方法和set get方法. package com.xh.tx.dao; import and ...
 - 通过Sql语句控制SQLite数据库增删改查
		
person类属性有Intenger id,String name,Intenger age,相应的构造方法和set get方法. package com.xh.tx.dao; import jav ...
 - 转:ios Sqlite数据库增删改查基本操作
		
研究了几天的数据库,终于把它给搞出来了.Sqlite是ios上最常用的数据库之一,大家还是有必要了解一下的.这是仿照网上的一个例子做的,有些部分写的不好,我稍作了修改,以讲解为主,主要让大家能够明白如 ...
 
随机推荐
- VNC远程连接阿里云Linux服务器 图形界面
			
VNC 简介: VNC,全称:Virtual Network Computing,即虚拟网络计算机:分客户端和服务端,即VNC Viewer和VNC Server.它是一款远程控制的软件,一般用于远程 ...
 - android 回调函数使用简介
			
//1---定义回调函数 public interface GirdMenuStateListener { void onSuccess(); void onError(); } //2---使用的地 ...
 - linux free命令详解(一)
			
一. 作用 free命令可以显示当前系统未使用的和已使用的内存数目,还可以显示被内核使用的内存缓冲区. 二. 语法 free [选项] 三. 选项 默认情况下,即在没有选项的情况下,&qu ...
 - Linux 部署 ASP.NET Core 的一些问题记录
			
异常错误: 关闭 IP6 #修改 vi /etc/sysctl.conf # 添加如下三条设置 net.ipv6.conf.all.disable_ipv6 = 1 net.ipv6.co ...
 - Silverlight中使用MVVM(3)—进阶
			
这篇主要引申出Command结合MVVM模式在应用程序中的使用 我们要做出的效果是这样的 就是提供了一个简单的查询功能将结果绑定到DataGrid中,在前面的基础上,这个部分相对比较容易实现了 我们在 ...
 - What does -> do in clojure?
			
https://stackoverflow.com/questions/4579226/what-does-do-in-clojure
 - Spring Boot + Spring Cloud 实现权限管理系统 后端篇(七):集成 Druid 数据源
			
数据库连接池负责分配.管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是再重新建立一个:释放空闲时间超过最大空闲时间的数据库连接来避免因为没有释放数据库连接而引起的数据库连接遗漏 ...
 - Spring Boot + Spring Cloud 实现权限管理系统 后端篇(三):搭建开发环境
			
生成项目模板 登录Spring Initializr生成Spring Boot项目模板,保存到本地. 地址:https://start.spring.io/ 导入Maven项目 使用IDE导入生成的M ...
 - NIO的Buffer&Channel&Selector
			
java的NIO和AIO Buffer position.limit.capacity 初始化 Buffer 填充 Buffer 提取 Buffer 中的值 mark() & reset() ...
 - Mysql字符串转换为整型
			
使用Convert(字段名, 类型)方法 SELECT CONVERT(filedName, UNSIGNED INTEGER) ;