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>
本章结束。