问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

程序的配置信息写在sqlite中与写在config哪个更好

发布网友 发布时间:2022-04-07 18:21

我来回答

2个回答

懂视网 时间:2022-04-07 22:43

package com.example.sqlitetransaction; 2 3 import android.content.Context; 4 import android.database.sqlite.SQLiteDatabase; 5 import android.database.sqlite.SQLiteDatabase.CursorFactory; 6 import android.database.sqlite.SQLiteOpenHelper; 7 import android.util.Log; 8 9 public class MydbOpenHelper extends SQLiteOpenHelper { 10 11 // 12 public MydbOpenHelper(Context context, String name, CursorFactory factory, 13 int version) { 14 super(context, name, factory, version); 15 // TODO Auto-generated constructor stub 16 } 17 18 19 //oncreate函数当数据库第一次被创建的时候会调用 20 @Override 21 public void onCreate(SQLiteDatabase db) { 22 // TODO Auto-generated method stub 23 String createtable = "create table user(id int, name varchar(20), money int);"; 24 db.execSQL(createtable); 25 System.out.println("MydbOpenHelper.onCreate()"); 26 } 27 28 29 //onUpgrade当你的数据库版本升级的时候会调用 30 @Override 31 public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { 32 // TODO Auto-generated method stub 33 //更改数据库的表结构 34 // user(id,name,password) user(id,name,password,gender) 35 // 36 // db.execSQL(""); 37 Log.i("MydbOpenHelper", "oldervserion"+oldVersion+"newversion"+newVersion); 38 System.out.println("MydbOpenHelper.onUpgrade()"); 39 40 } 41 42 } MydbOpenHelper.java

 

技术分享
 1 package com.example.sqlitetransaction;
 2 
 3 import android.app.Activity;
 4 import android.content.ContentValues;
 5 import android.database.Cursor;
 6 import android.database.sqlite.SQLiteDatabase;
 7 import android.os.Bundle;
 8 import android.util.Log;
 9 import android.view.Menu;
10 import android.view.MenuItem;
11 
12 public class MainActivity extends Activity {
13  SQLiteDatabase db;
14 
15  @Override
16 protected void onCreate(Bundle savedInstanceState) {
17  super.onCreate(savedInstanceState);
18  setContentView(R.layout.activity_main);
19  
20  MydbOpenHelper helper = new MydbOpenHelper(this, "count.db", null,1);
21  db = helper.getReadableDatabase();
22  
23  //insert();
24  try {
25   update(); 
26   query();
27  } 
28  finally{
29   db.close();  
30  }
31  
32  }
33 private void update(){
34  db.beginTransaction();
35  try{
36  ContentValues cv = new ContentValues();
37  cv.put("money", 7000);
38  db.update("user", cv, "id=1", null);
39  
40  //int b = 1/0;
41  
42   cv.clear();
43  cv.put("money", 11000);
44  db.update("user", cv, "id=2", null);
45   db.setTransactionSuccessful();
46  }catch(Exception e){
47  
48  }finally{
49   db.endTransaction();
50  }
51 
52  }
53 private void query(){
54  Cursor c = db.rawQuery("select * from user", null);
55  
56  while(c.moveToNext()){
57  int id = c.getInt(c.getColumnIndex("id"));
58  String username = c.getString(c.getColumnIndex("name"));
59  String money = c.getString(c.getColumnIndex("money"));
60  Log.i("sqlitetransaction", id+","+username+","+money);
61  }
62  }
63 private void insert(){
64  ContentValues cv = new ContentValues();
65  cv.put("id", 1);
66  cv.put("name", "user1");
67  cv.put("money", 8000);
68  db.insert("user", null, cv);
69  cv.clear();
70  
71  cv.put("id", 2);
72  cv.put("name", "user2");
73  cv.put("money", 10000);
74  db.insert("user", null, cv);
75  cv.clear();
76  }
77 }
MainActivity.java

 

007_01SQLiteTransaction

标签:

热心网友 时间:2022-04-07 19:51

使用SQLite方式存储数据

  在Android中一共提供了5种数据存储方式,分别为:

  (1)Files:通过FileInputStream和FileOutputStream对文件进行操作。具体使用方法可以参阅博文《Android学习笔记34:使用文件存储数据》。

  (2)Shared Preferences:常用来存储键值对形式的数据,对系统配置信息进行保存。具体使用方法可以参阅博文《Android学习笔记35:使用Shared Preferences方式存储数据》。

  (3)Content Providers:数据共享,用于应用程序之间数据的访问。

  (4)SQLite:Android自带的轻量级关系型数据库,支持SQL语言,用来存储大量的数据,并且能够对数据进行使用、更新、维护等操作。

  (5)Network:通过网络来存储和获取数据。

  本篇博文介绍第四种方式,通过Android自带的SQLite数据库存储数据。

1.SQLite简介

  SQLite是一款开源的、嵌入式关系型数据库,第一个版本Alpha发布于2000年。SQLite在便携性、易用性、紧凑性、高效性和可靠性方面有着突出的表现。

  SQLite和C/S模式的数据库软件不同,它是一款嵌入式数据库,没有独立运行的进程,与所服务的应用程序在应用程序进程空间内共生共存。它的代码与应用程序代码也是在一起的,或者说嵌入其中,作为托管它的程序的一部分。因此不存在数据库的客户端和服务器,使用SQLite一般只需要带上它的一个动态库,就可以享受它的全部功能。

  数据库服务器在程序中的好处是不需要网络配置或管理。将数据库客户端与服务器运行在同一个进程中,可以省去不少的操作及麻烦:不用担心防火墙或者地址解析;不用浪费时间管理复杂的授权和权限;可以减少网络调用相关的消耗;可以简化数据库管理并使程序更容易部署。

  SQLite数据库通过数据库级上的独占性和共享锁来实现独立事务处理。这意味着多个进程可以在同一时间从同一数据库读取数据,但是只有一个可以写入数据。在某个进程向数据库执行写操作之前,必须获得独占锁定。在发出独占锁定后,其他的读写操作将不会再发生。

  此外,SQLite数据库中的所有信息(比如表、视图、触发器等)都包含在一个文件内,方便管理和维护。SQLite数据库还支持大部分操作系统,除电脑上使用的操作系统之外,很多手机上使用的操作系统同样可以运行。同时,SQLite数据库还提供了多语言的编程接口,供开发者使用。

2.SQL基本命令

  SQL是与关系型数据库通信的唯一方式。它专注于信息处理,是为构建、读取、写入、排序、过滤、映射、分组、聚集和通常的管理信息而设计的声明式语言。

  在讲解SQL基本命令之前,有必要先了解一下SQLite所支持的数据类型都有哪些。

2.1 SQLite支持的数据类型

  SQLite采用动态数据存储类型,会根据存入的值自动进行判断。SQLite支持以下5种数据类型:

  (1)NULL:空值

  (2)INTEGER:带符号的整型

  (3)REAL:浮点型

  (4)TEXT:字符串文本

  (5)BLOB:二进制对象

2.2 SQL基本命令

  表是探索SQLite中SQL的起点,也是关系型数据库中信息的标准单位,所有的操作都是以表为中心的。那么如何使用SQL命令创建一张表呢?

2.2.1创建表

  表是由行和列组成的,列称为字段,行称为记录。

  使用CREATE命令可以创建表,CREATE命令的一般格式为:

  CREATE [TEMP/TEMPORARY] TABLE table_name (column_definitions [, constraints]);

  其中,[]中的内容是可选的,用TEMP或TEMPORARY关键字声明的表是临时表,这种表只存活于当前会话,一旦连接断开,就会被自动销毁。如果没有明确指出创建的表是临时表,则创建的是基本表,将会在数据库中持久存在,这也是数据库中最常见的表。

  CREATE TABLE命令至少需要一个表名和一个字段名,上述命令中的table_name表示表名,表名必须与其他标识符不同。column_definitions由用逗号分隔的字段列表组成,每个字段定义包括一个名称、一个域(类型)和一个逗号分隔的字段约束。其中,域是指存储在该列的信息的类型,约束用来控制什么样的值可以存储在表中或特定的字段中。

  一条创建表的命令示例如下:

1   CREATE TABLE tab_student (studentId INTEGER PRIMARY KEY AUTOINCREMENT,
2   studentName VARCHAR(20),
3   studentAge INTEGER);

  如上,我们创建了一个名为tab_student的表,该表包含3个字段:studentId、 studentName和studentAge,其数据类型分别为:INTEGER、VARCHAR和INTEGER。

  此外,通过使用关键字PRIMARY KEY,我们指定了字段studentId所在的列是主键。主键确保了每一行记录在某种方式上与表中的其他行记录是不同的(唯一的),进而确保了表中的所有字段都是可寻址的。

  SQLite为主键提供自增长功能,当定义字段类型为INTEGER PRIMARY KEY时,SQLite将为该字段创建默认值,该默认值确保整数值是唯一的。SQLite使用64-bit单符号整数主键,因此,该字段的最大值是9,223,372,036,854,775,807。当达到最大值时,SQLite会自动搜索该字段还未使用的值,并作为要插入的值。从表中删除记录时,rowid可能被回收并在后面的插入中使用。因此,新创建的rowid不一定是按照严格顺序增长的。如果想要SQLite使用唯一的自动主键值,而不是填补空白,可以在主键定义INTEGER PRIMARY KEY中加入关键字AUTOINCREMENT。AUTOINCREMENT关键字阻止rowid回收,它将为新插入的记录产生新的(不是回收的)rowid。

2.2.2插入记录

  使用INSERT命令可以一次插入一条记录,INSERT命令的一般格式为:

  INSERT INTO tab_name (column_list) VALUES (value_list);

  其中,tab_name指明将数据插入到哪个表中,column_list是用逗号分隔的字段名称,这些字段必须是表中存在的,value_list是用逗号分隔的值列表,这些值是与column_list中的字段一一对应的。

  比如,向刚才创建的tab_student表中插入一条记录,便可以使用如下的语句完成:

  INSERT INTO tab_student (studentId, studentName, studentAge) VALUES (1, “jack”, 23);

  通过以上的语句,便插入了一条studentName=”jack”, studentAge=”23”的记录,该记录的主键为studentId=1。

2.2.3更新记录

  使用UPDATE命令可以更新表中的记录,该命令可以修改一个表中一行或者多行中的一个或多个字段。UPDATE命令的一般格式为:

  UPDATE tab_name SET update_list WHERE predicate;

  其中,update_list是一个或多个字段赋值的列表,字段赋值的格式为column_name=value。WHERE子句使用断言识别要修改的行,然后将更新列应用到这些行。

  比如,要更新刚才插入到tab_student表中的记录,便可以使用如下的语句完成:

  UPDATE tab_student SET studentName=”tom”, studentAge=”25” WHERE studentId=1;

  通过以上的语句,便可以将刚才插入的主键为studentId=1的记录更新为studentName=”tom”, studentAge=”25”了。

2.2.4删除记录

  使用DELETE命令可以删除表中的记录,DELETE命令的一般格式为:

  DELETE FROM table_name WHERE predicate;

  其中,table_name指明所要删除的记录位于哪个表中。和UPDATE命令一样,WHERE子句使用断言识别要删除的行。

  比如,要删除刚才插入的记录,便可以使用如下的语句完成:

  
  DELETE FROM tab_student WHERE studentId=1;

2.2.5查询记录

  SELECT命令是查询数据库的唯一命令。SELECT命令也是SQL命令中最大、最复杂的命令。

  SELECT命令的通用形式如下:

  SELECT [distinct] heading

  FROM tables

  WHERE predicate

  GROUP BY columns

  HAVING predicate

  ORDER BY columns

  LIMIT count,offset;

  其中,每个关键字(如FROM、WHERE、HAVING等)都是一个单独的子句,每个子句由关键字和跟随的参数构成。GROUP BY和HAVING一起工作可以对GROUP BY进行约束。ORDER BY使记录集在返回之前按一个或多个字段的值进行排序,可以指定排序方式为ASC(默认的升序)或DESC(降序)。此外,还可以使用LIMIT限定结果集的大小和范围,count指定返回记录的最大数量,offset指定偏移的记录数。

  在上述的SELECT命令通用形式中,除了SELECT之外,所有的子句都是可选的。目前最常用的SELECT命令由三个子句组成:SELECT、FROM、WHERE,其基本语法形式如下:

  SELECT heading FROM tables WHERE predicate;

  比如,要查询刚才插入的记录,便可以使用如下的语句完成:

  
  SELECT studentId, studentName, studentAge FROM tab_student WHERE studentId=1;

  至此,我们介绍了SQL中最基本和最常用的CREATE、INSERT、UPDATE、DELETE和SELECT命令。当然了,这里只是对其进行了简单的介绍,有关SQLite中SQL命令的详细使用方法,可以参阅《SQLite权威指南》一书的第三章和第四章。

3.数据库操作辅助类SQLiteOpenHelper

  Android提供了一个重要的类SQLiteOpenHelper,用于辅助用户对SQLite数据库进行操作。

  SQLiteOpenHelper的构造函数原型如下:

  public SQLiteOpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version);

  其中,参数context表示应用程序运行的环境,包含应用程序所需的共享资源。参数name表示Android的数据库名字。参数factory是SQLiteDatabase.CursorFactory类对象,用于存储查询Android SQLite数据库的结果集。参数version表示应用程序所用的数据库的版本,该版本并非SQLite的真正版本,而是指定应用程序中的SQLite数据库的版本,当该版本号发生变化时,将会触发SQLiteOpenHelper类中的onUpgrade()或onDowngrade()方法。

  SQLiteOpenHelper类的所有方法如图1所示。

图1 SQLiteOpenHelper类的方法

  其中,close()方法用于关闭SQLiteOpenHelper对象中的SQLite数据库;getReadableDatabase()方法和getWriteableDatabase()方法类似,getReadableDatabase()方法以只读状态打开SQLiteOpenHelper对象中指定的SQLite数据库,任何想要修改数据库的操作都是不允许的;getWriteableDatabase()方法也是打开数据库,但是允许数据库正常的读/写操作;在一个不存在的数据库上调用任何方法时,都会隐式的调用SQLiteOpenHelper对象的onCreate()方法;当应用程序第一次访问数据库时,则会调用onOpen()方法,但是,如果版本号发生了变化的话,则会调用onUpgrade()或onDowngrade()方法。

4.数据库类SQLiteDatabase

  SQLiteDatabase类用来完成对数据库的操作任务,比如表的选择、插入、更新和删除语句等。

  SQLiteDatabase类中常用的用于执行SQL语句的方法有以下一些。

  (1)execSQL()方法:

  public void execSQL (String sql);

  public void execSQL (String sql, Object[] bindArgs);

  (2)query()方法:

  public Cursor query (String table, String[] columns, String selection, String[] selectionArgs, String
groupBy, String having,String orderBy, String limit);

  public Cursor query (boolean distinct, String table, String[] columns, String selection, String[] selectionArgs, String
groupBy, String having, String orderBy, String limit, CancellationSignal cancellationSignal);

  public Cursor query (String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String
having,String orderBy);

  public Cursor query (boolean distinct, String table, String[] columns, String selection, String[] selectionArgs, String
groupBy, String having, String orderBy, String limit);

  (3)queryWithFactory()方法:

  public Cursor queryWithFactory (SQLiteDatabase.CursorFactory cursorFactory, boolean distinct, String table, String[]columns, String selection, String[] selectionArgs, String groupBy, String having, String
orderBy, String limit,CancellationSignal cancellationSignal);

  public Cursor queryWithFactory (SQLiteDatabase.CursorFactory cursorFactory, boolean distinct, String table, String[]columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit);

  (4)rawQuery()方法:

  public Cursor rawQuery (String sql, String[] selectionArgs, CancellationSignal cancellationSignal);

  public Cursor rawQuery (String sql, String[] selectionArgs);

  (5)rawQueryWithFactory()方法:

  public Cursor rawQueryWithFactory (SQLiteDatabase.CursorFactory cursorFactory, String sql, String[]
selectionArgs,String editTable);

  public Cursor rawQueryWithFactory (SQLiteDatabase.CursorFactory cursorFactory, String sql, String[]
selectionArgs,String editTable, CancellationSignal cancellationSignal);

  其中,execSQL()方法都有一个参数sql,这个参数是一个SQL语句。第二个参数bindArgs接收一个数组,数组中的每个成员*了一个查询。execSQL()方法用于运行那些没有返回值的查询语句,比如创建、插入、更新和修改表。

  query()方法和queryWithFactory()方法是在数据库中运行一些轻量级的单查询语句,参数包括table、columns、groupBy、having、orderBy、limit等SQL语句关键字。这些方法允许将SQL语句传递给相关方法,而不必直接使用SQL语句。

  rawQuery()方法和rawQueryWithFactory()方法也都有一个参数sql,用于执行SQL查询语句,返回值是Cursor对象。这两个方法都有一个版本能够接收一个字符串数组selectionArgs作为参数,通过这个参数,SQLiteDatabase对象将把*的SQL语句中的问号(?)用这个数组中的值代替,并按照一一对应的位置关系进行取代。

  SQLiteDatabase类提供了大约50个方法,除此之外还有一些用于打开数据库的方法(如openDatabase()、openOrCreateDatabase()等),用于管理SQLite事务的方法(如beginTransaction()、endTransaction()等),用于测试数据库是否被锁住的方法(如isDbLockedByCurrentThread()、isDbLockedByOtherThread()等),以及获取数据库基本信息的方法(如getMaximumSiza()、getVersion()等)。这里就不一一介绍了,具体可以参阅SQLiteDatabase类的API帮助文档。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
如何分别真金和仿金首饰 怎样区分真金和仿金首饰呢 小学生新年晚会主持人的串词!!(不要太多)急 大大后天就需要了!!!_百度... 周年晚会策划公司 奥格瑞玛传送门大厅在哪 奥格瑞玛传送门大厅怎么走 锻炼颈椎的几个动作 水多久能结冰 冰能在多长时间内形成 请问水低于0度会结冰吗? 如何防止脱发严重 嘴唇上有黑印用蜜蜡和棉线去除了胡须 健康管理师需要哪些报考条件? bilibili直播人气值6是什么意思 我水管出水太小,压力太小,有什么办法让水管的压力大呢出水快 家住6楼 如何安装自吸式水泵 智学网c1排名多少(全班46人)? 为什么老公不和我过夫妻生活呢? 不想与老公实施夫妻生活该怎么拒绝 智学网年级A3一B1什么意思 智学网c2等级啥意思? 我今年34岁了,一点都不想和老公过性生活,怎么办 智学网年级成绩A2,+全校有1200个人是多少名 不想和老公过性生活的理由有哪些 不愿意和丈夫过性生活,怎样做才不算过分? 武汉市2019年期末考试智学网成绩A2是第几名? 为什么我现在都不想跟老公过性生活了呢? TP-LINK 物联 索要 手机上的照片 媒体内容 文件 正常吗 初中期中考试在班级排名A2是什么意思? 智学网年级A2是多少名,年级383人 700人智学网A2是多少名 tp-link物联怎样开灯 新高考理化生可以选择的专业有哪些 哪些银行办理Ec丅没有押金? 老乡知道哪个银行办ETC不要押金的么 物化地能选啥专业 活动期间在建设银行办理ETC需要交保证金吗? 物化政可以选哪些专业? 理化地可以选什么专业? 在中国银行办理的ETC要压金吗? 我现在是高一学生,数理化生好,可以选择哪些大学? 聊城建设银行办etc借记卡要交押金吗 选择物理生物地理能报哪些专业 文理科各有哪些专业 芜湖有大专院校招收自考生吗? 芜湖自考公办大专 饿了么用微信支付会员怎么取消自动续费 芜湖有什么好的自考大专院校?芜湖职业技术学院收自考的吗? 安徽芜湖有哪些自考学校??? 安徽芜湖有哪些大专院校?包括本科的学校。 求问这款美的空调是什么型号的 本科学校里有专科的学校有那些,可以升本的有那些,谢谢