Android_SQL详解
来源:互联网 发布:淘宝能赚到钱吗 编辑:程序博客网 时间:2024/06/09 22:18
1.SQLite简介
SQLite是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入 式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持 Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如Tcl、PHP、Java、C++、.Net等,还有ODBC接口,同样比起 Mysql、PostgreSQL这两款开源世界著名的数据库管理系统来讲,它的处理速度比他们都快。
2.SQLite的特点:
轻量级
SQLite和C/S模式的数据库软件不同,它是进程内的数据库引擎,因此不存在数据库的客户端和服务器。使用SQLite一般只需要带上它的一个动态 库,就可以享受它的全部功能。而且那个动态库的尺寸也挺小,以版本3.6.11为例,Windows下487KB、Linux下347KB。
不需要"安装"
SQLite的核心引擎本身不依赖第三方的软件,使用它也不需要"安装"。有点类似那种绿色软件。
单一文件
数据库中所有的信息(比如表、视图等)都包含在一个文件内。这个文件可以自由复制到其它目录或其它机器上。
跨平台/可移植性
除了主流操作系统 windows,linux之后,SQLite还支持其它一些不常用的操作系统。
弱类型的字段
同一列中的数据可以是不同类型
开源
这个相信大家都懂的!
3.SQLite数据类型
一般数据采用的固定的静态数据类型,而SQLite采用的是动态数据类型,会根据存入值自动判断。SQLite具有以下五种常用的数据类型:
NULL: 这个值为空值
VARCHAR(n):长度不固定且其最大长度为 n 的字串,n不能超过 4000。
CHAR(n):长度固定为n的字串,n不能超过 254。
INTEGER: 值被标识为整数,依据值的大小可以依次被存储为1,2,3,4,5,6,7,8.
REAL: 所有值都是浮动的数值,被存储为8字节的IEEE浮动标记序号.
TEXT: 值为文本字符串,使用数据库编码存储(TUTF-8, UTF-16BE or UTF-16-LE).
BLOB: 值是BLOB数据块,以输入的数据格式进行存储。如何输入就如何存储,不改 变格式。
DATA :包含了 年份、月份、日期。
TIME: 包含了 小时、分钟、秒。
二、创建数据库以及升级
1.SQLiteOpenHelper介绍
该类是SQLiteDatabase一个辅助类。这个类主要生成一 个数据库,并对数据库的版本进行管理。当在程序当中调用这个类的方法getWritableDatabase()或者getReadableDatabase()方法的时候,如果当时没有数据,那么Android系统就会自动生成一个数据库。 SQLiteOpenHelper 是一个抽象类,我们通常需要继承它,并且实现里面的3个函数:
1.onCreate(SQLiteDatabase)
在数据库第一次生成的时候会调用这个方法,也就是说,只有在创建数据库的时候才会调用,当然也有一些其它的情况,一般我们在这个方法里边生成数据库表。
2. onUpgrade(SQLiteDatabase,int,int)
当数据库需要升级的时候,Android系统会主动的调用这个方法。一般我们在这个方法里边删除数据表,并建立新的数据表,当然是否还需要做其他的操作,完全取决于应用的需求。
3. onOpen(SQLiteDatabase):
这是当打开数据库时的回调函数,一般在程序中不是很常使用。
示例代码如下:
public class MainActivity extends AppCompatActivity { private EditText et_id, et_msg; private TextView tv_info; SQLiteDatabase db; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); et_id = (EditText) findViewById(R.id.et_id); et_msg = (EditText) findViewById(R.id.et_msg); tv_info = (TextView) findViewById(R.id.tv_info); //实例化数据库操作类对象, db = SQLiteDatabase.openOrCreateDatabase(Environment.getExternalStorageDirectory(). getAbsolutePath() + File.separator + "mydb.db", null); db.execSQL("create table if not exists test(id integer primary key autoincrement,name varchar(100))"); } public void click(View view) { String id = et_id.getText().toString(); String msg = et_msg.getText().toString(); switch (view.getId()) { case R.id.btnAdd://增加数据 //第1中增加数据方式 //db.execSQL("insert into test(name) values ('"+msg+"')"); //第2种增加数据方式 ContentValues cv = new ContentValues(); cv.put("name", msg); db.insert("test", null, cv); Toast.makeText(MainActivity.this, "插入数据成功", Toast.LENGTH_LONG).show(); break; case R.id.btnDelete://删除数据 //db.execSQL("delete from test where id="+id+" or name='"+msg+"'"); //删除,参数1,表名;2.where后面的条件语句;3.占位符?对应的值 db.delete("test", "id=? or name=?", new String[]{id, msg}); Toast.makeText(MainActivity.this, "删除数据成功", Toast.LENGTH_LONG).show(); break; case R.id.btnUpdate://修改数据 ContentValues cv2 = new ContentValues(); cv2.put("name", msg); //修改,参数:1.表名,2.要修改的列和值,3.根据什么条件修改,where后面的条件语句,4.占位符?的值 db.update("test", cv2, "id=?", new String[]{id}); Toast.makeText(MainActivity.this, "修改数据成功", Toast.LENGTH_LONG).show(); break; case R.id.btnSelect://查询数据 //执行查询 Cursor cursor = db.query("Test", null, null, null, null, null, null); StringBuilder builder = new StringBuilder(); while (cursor.moveToNext()) { builder.append("序号:" + cursor.getInt(0)); builder.append("====》内容:" + cursor.getString(1)); builder.append("\r\n"); } tv_info.setText(builder); break; } }}
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity_main" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" android:orientation="vertical" tools:context="com.example.sjk.MainActivity"> <EditText android:id="@+id/et_id" android:layout_width="match_parent" android:layout_height="wrap_content" android:hint="请输入您要操作的ID" /> <EditText android:id="@+id/et_msg" android:layout_width="match_parent" android:layout_height="wrap_content" android:hint="请输入您要输入的内容" /> <Button android:id="@+id/btnAdd" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="增加" android:onClick="click" /> <Button android:id="@+id/btnDelete" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="删除" android:onClick="click" /> <Button android:id="@+id/btnUpdate" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="修改" android:onClick="click" /> <Button android:id="@+id/btnSelect" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="查询" android:onClick="click" /> <TextView android:id="@+id/tv_info" android:layout_width="match_parent" android:layout_height="wrap_content" /></LinearLayout>
本章结束。
- Android_SQL详解
- Android_SQL增删改查
- 详解
- 详解
- 详解
- 详解
- &,&&,|,||详解
- 详解
- Scala详解--------基础知识详解
- Spring详解-----------事务详解
- github 详解详解
- InputFilter详解、TextWatcher详解
- Spring详解-----------事务详解
- 【词汇详解】事务详解
- Session 详解
- Session 详解
- sizeof详解
- 端口详解
- [自学]Java发展史
- soj1303 KM算法
- linux--有名管道
- Depth-first Search -- Leetcode problem394. Decode String
- 1001. A+B Format (20)
- Android_SQL详解
- Linux日常
- java运行原理
- RBAC用户角色权限设计方案
- 机器学习-学习笔记 Cifar10(普适物体识别)
- Zookeepr和Hadoop,Hbase的关系
- mysql 有则更新无则插入
- PHP 购物车 session (ThinkPHP)
- STL(标准模板库)string(一)