Android:数据库增删改查、SQLite、SQLiteOpenHelper、openOrCreateDatabase

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

1. 创建一个SQLiteOpenHelper继承类

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
public  class  MySQLiteHelper  extends  SQLiteOpenHelper
{
     //重写构造方法,可以改为(Context context, int version)只要这两参数
     public  MySQLiteHelper(Context context, String name, CursorFactory factory,
             int  version)
     {
         super (context,  "test.db" null , version);
     }
     //创建表
     @Override
     public  void  onCreate(SQLiteDatabase db)
     {
         db.execSQL( "CREATE TABLE person(personid INTEGER PRIMARY KEY AUTOINCREMENT,name VARCHAR(20),phone VARCHAR(20))"  );
         db.execSQL( "CREATE TABLE student(personid INTEGER PRIMARY KEY AUTOINCREMENT,name VARCHAR(20),phone VARCHAR(20))"  );
     }
     //升级表(当Database的Version低于当前new里的Version,直接执行下面方法)
     @Override
     public  void  onUpgrade(SQLiteDatabase db,  int  oldVersion,  int  newVersion)
     {
                                            
         int  v = newVersion - oldVersion;
         switch  (v)
         {
         case  3 :
             db.execSQL( "ALTER TABLE person ADD salary3 VARCHAR(20)" );
         case  2 :
             db.execSQL( "ALTER TABLE person ADD salary2 VARCHAR(20)" );
         case  1 :
             db.execSQL( "ALTER TABLE person ADD salary1 VARCHAR(20)" );
         default :
             break ;
         }
     }
                                        
}


2.使用SQLite增删改查

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
/**
  *
CREATE TABLE person
(
        personid INTEGER PRIMARY KEY AUTOINCREMENT,
        name VARCHAR(20),
        phone VARCHAR(20)
)
DROP TABLE person  //删除表
INSERT INTO person(name,phone) VALUES ("rongqin","1598088588")  //插入
SELECT * FROM person WHERE name="Andfeel"
UPDATE person SET name="Andfeel" WHERE personid=2   //改
ALTER TABLE person ADD salary      //增加列
DELETE FROM person WHERE name="Andfeel"    //删除
                              
  *
  */
public  class  MainActivity  extends  Activity  implements  OnClickListener
{
                                
     private  TextView textView;
     private  MySQLiteHelper mDBHelper;
     private  MySQLiteHelper bHelper;
     @Override
     protected  void  onCreate(Bundle savedInstanceState)
     {
         super .onCreate(savedInstanceState);
         setContentView(R.layout.activity_main);
                                    
         findViewById(R.id.btn__create_table).setOnClickListener( this );
         findViewById(R.id.btn_delete_table).setOnClickListener( this );
         findViewById(R.id.btn_alter_table).setOnClickListener( this );
         findViewById(R.id.btn_insert).setOnClickListener( this );
         findViewById(R.id.btn_delete).setOnClickListener( this );
         findViewById(R.id.btn_update).setOnClickListener( this );
         findViewById(R.id.btn_select).setOnClickListener( this );
         textView = (TextView) findViewById(R.id.textView1);
                                    
         //创建数据库
         mDBHelper =  new  MySQLiteHelper( this "one.db" null 3 );
         bHelper =  new  MySQLiteHelper( this "two.db" null 4 );
     }
                                
     @Override
     public  boolean  onCreateOptionsMenu(Menu menu)
     {
         getMenuInflater().inflate(R.menu.activity_main, menu);
         return  true ;
     }
     @Override
     public  void  onClick(View v)
     {
         switch  (v.getId())
         {
         case  R.id.btn__create_table:
             btnCreateTable();
             break ;
         case  R.id.btn_delete_table:
             btnDeleteTable();
             break ;
         case  R.id.btn_alter_table:
             btnAlterTable();
             break ;
         case  R.id.btn_insert:
             btnInsert();
             break ;
         case  R.id.btn_delete:
             btnDelete();
             break ;
         case  R.id.btn_update:
             btnUpdate();
             break ;
         case  R.id.btn_select:
             btnSelect();
             break ;
                                    
         default :
             break ;
         }
     }
     private  void  btnSelect() //查
     {
         SQLiteDatabase db = mDBHelper.getWritableDatabase();
         SQLiteDatabase db1 = bHelper.getWritableDatabase();
                                    
         Cursor cursor = db.rawQuery( "SELECT * FROM person WHERE name = ?" new  String[]{ "rongqin" });
//        cursor.moveToFirst();
         while (cursor.moveToNext())
         {
             int  columnIndex = cursor.getColumnIndex( "name" );
             String name = cursor.getString(columnIndex);
             int  columnIndex2 = cursor.getColumnIndex( "phone" );
             String phone = cursor.getString(columnIndex2);
                                        
             textView.setText(name +  ":"  + phone);
                                        
         }
     }
     private  void  btnUpdate() //改
     {
         SQLiteDatabase db = mDBHelper.getWritableDatabase();
         db.execSQL( "UPDATE person SET phone='0592xxxxxx' WHERE personid=5" );
     }
     private  void  btnDelete() //删
     {
         SQLiteDatabase db = mDBHelper.getWritableDatabase();
         db.execSQL( "DELETE FROM person WHERE name='Andfeel'" );
     }
     private  void  btnInsert() //增
     {
         SQLiteDatabase db = mDBHelper.getWritableDatabase();
         db.execSQL( "INSERT INTO person(name,phone) VALUES ('rongqin',1598088588)" );
     }
     private  void  btnAlterTable() //扩展表
     {
                                    
     }
     private  void  btnDeleteTable() //删除表
     {
                                    
     }
     private  void  btnCreateTable() //创建表
     {
                                    
     }
                                
}


注:

1.通过以下方法可以修改数据库存储路径

SQLiteDatabase.openOrCreateDatabase(file, factory);

context.openOrCreateDatabase(name, mode, factory);





本文转自 glblong 51CTO博客,原文链接:http://blog.51cto.com/glblong/1216873,如需转载请自行联系原作者
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
8天前
|
关系型数据库 MySQL 数据库
mysql数据库表格的增删改查
mysql数据库表格的增删改查
|
9天前
|
SQL 关系型数据库 数据库
17. Python 数据库操作之MySQL和SQLite实例
17. Python 数据库操作之MySQL和SQLite实例
42 2
|
10天前
|
SQL 存储 数据库
48. 【Android教程】数据库:SQLite 的使用
48. 【Android教程】数据库:SQLite 的使用
9 1
|
14天前
|
SQL 关系型数据库 MySQL
mysql 数据库 增删改查 基本操作
mysql 数据库 增删改查 基本操作
|
19天前
|
JavaScript 小程序 Shell
在JSTL 中使用小型数据库 SQLite
`code袁`是一位热爱分享和记录学习的大学生,主攻编程领域。他的个人主页在[CSDN](https://blog.csdn.net/qq_48164590),QQ号为2647996100,WeChat号为code8896。他分享了三个专栏:毕业设计与课程设计、微信小程序开发和Vue全程学习。文章介绍了SQLite数据库命令行工具的下载、使用方法,包括创建数据库、定义表结构、插入数据及退出命令。此外,还展示了如何将ER图转化为数据库。最后鼓励读者点赞和支持。
21 2
|
19天前
|
小程序 数据库
一分钟教你学会小程序云开发的数据库的增删改查
本文简要介绍了小程序云开发中数据库的增删改查操作。首先展示了查询代码,通过`wx.cloud.database().collection().get()`获取数据;接着演示添加数据,强调数据字段需与数据库匹配;然后说明删除数据需基于_id,通过`doc(id).remove()`执行;最后,更新数据同样依赖_id,使用`doc(id).update()`进行修改。
23 1
|
20天前
|
存储 关系型数据库 数据库
利用Python与SQLite构建轻量级数据库应用
在当今日益增长的数据处理需求下,数据库成为存储、检索和管理数据的关键技术。然而,对于小型项目或快速原型开发,大型数据库系统可能显得过于庞大和复杂。本文将介绍如何利用Python编程语言与SQLite轻量级数据库,快速搭建一个功能齐全、易于维护的数据库应用。我们将探讨SQLite数据库的特点、Python对SQLite的支持,并通过一个实际案例展示如何构建一个简单的数据库应用,为读者提供一种高效、灵活的解决方案。
|
27天前
|
数据库 Android开发
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
|
29天前
|
SQL 开发框架 数据库连接
uniapp中sqlite数据库常用操作的简单封装
uniapp中sqlite数据库常用操作的简单封装
|
30天前
|
数据库 数据库管理 关系型数据库