Android_SQL详解

来源:互联网 发布:淘宝能赚到钱吗 编辑:程序博客网 时间:2024/06/09 22:18
一.SQLite的介绍

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:

<?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>

本章结束。