我們聊一下常用的東西,SQLite,這東西很常用到,當再寫手機APP的時候,有時候會在Client 做 cache或是做一些資料的管理都很必須會用到,我們來看看今天的範例

建立SQL Lite 資料庫,然後建立一張為Users 的資料表其欄位為 ID(數字,並且自動累加)、Name(ntext)、Addr(ntext) ,之後我們寫入一筆資料進去,之後並且將他查詢出來
1.在專案的開始我們首先得先引用幾個library : System.Data , System.Data.SQLite

2.建立資料庫:

var sqlLiteFilePath = GetFileStreamPath("") + "/db_user.db";
//建立Database file @ data/data/
var btnCreateDB = FindViewById<Button>(Resource.Id.btnCreateDB);
btnCreateDB.Click += delegate
{
    SqliteConnection.CreateFile(sqlLiteFilePath);
};

存放的路徑,我之前在Internal Storage章節有提到將會放置在 [PACKAGE NAME]/data/data/files/ 建立成功後你會看到該檔案


這樣代表就寫入成功了,請注意,當這一段重複執行,資料庫會被重置 我因為手機有root 所以我可以直接去該APP 下的資料存放位置觀看.

3.建立資料表 Users:

//建立table
var btnCeateTable = FindViewById<Button>(Resource.Id.btnCeateTable);
btnCeateTable.Click += delegate
{
    try
    {
        var connectionString = String.Format("Data Source={0};Version=3;", sqlLiteFilePath);
        var conn = new SqliteConnection(connectionString);
 
        var cmd =
           new SqliteCommand(
               "CREATE TABLE Users (ID INTEGER PRIMARY KEY AUTOINCREMENT , Name ntext, Addr ntext)", conn)
               {
                   CommandType = CommandType.Text
               };
        conn.Open();
        cmd.ExecuteNonQuery();
        conn.Close();
        Toast.MakeText(this, "建立完成", ToastLength.Short).Show();
    }
    catch (Exception ex)
    {
        Toast.MakeText(this, "建立失敗:" + ex.Message, ToastLength.Short).Show();
    }
};

因為不能夠重複建立,所以我偷懶用try catch 起來,當然失敗原因不只包含這種狀況 建立成功後我點入db_user.db 終究會看到Users 那張資料表
並且欄位為:

4.新增資料,這時候我們試試看將資料寫進去 :

//建立資料
var btnInsertData = FindViewById<Button>(Resource.Id.btnInsertData);
btnInsertData.Click += delegate
{
    try
    {
        var connectionString = String.Format("Data Source={0};Version=3;", sqlLiteFilePath);
        var conn = new SqliteConnection(connectionString);
        conn.Open();
        var cmd = new SqliteCommand(conn)
            {
                CommandText = "INSERT INTO Users (\"Name\",\"Addr\") VALUES(\"許當麻\",\"台灣台北\");",
                CommandType = CommandType.Text
            };
        cmd.ExecuteNonQuery();
        conn.Close();
        Toast.MakeText(this, "資料寫入完成", ToastLength.Short).Show();
    }
    catch(Exception ex)
    {
        Toast.MakeText(this, "資料寫入完成:" + ex.Message, ToastLength.Short).Show();
    }
};

看一下資料中的資料:

5.用程式將資料撈取出來呈現:

//查詢
var btnSelect = FindViewById<Button>(Resource.Id.btnSelect);
btnSelect.Click += delegate
{
    try
    {
        //先清除LinearLayout中的所有資料 ,再重新匯入
        var dataContainer = FindViewById<LinearLayout>(Resource.Id.dataContainer);
        dataContainer.RemoveAllViews();
 
        var connectionString = String.Format("Data Source={0};Version=3;", sqlLiteFilePath);
        var conn = new SqliteConnection(connectionString);
        conn.Open();
        var cmd = new SqliteCommand(conn)
        {
            CommandText = "SELECT * FROM Users",
            CommandType = CommandType.Text
        };
        var dr = cmd.ExecuteReader();
 
        while (dr.Read())
        {
            var txtView = new TextView(this);
            txtView.Text = dr["ID"] + "," + dr["Name"] + "," + dr["Addr"];
            dataContainer.AddView(txtView);
        }
        conn.Close();
    }
    catch (Exception ex)
    {
        Toast.MakeText(this, "資料查詢失敗:" + ex.Message, ToastLength.Short).Show();
    }
};


其中,我用一個名為 dataContainer  的LinearLayout 來裝資料.

如果原本對SQLite有操作經驗的人,對你們來說應該很簡單,如果是剛接觸的人,其實這沒有很難可以參考一下,這樣可以很方便解決資料存取的問題
reference : http://docs.xamarin.com/recipes/ios/data/sqlite/create_a_database_with_ado.net

[Xamarin] 關於SQLite 的操作 (转帖)的更多相关文章

  1. [Xamarin] 關於發出Notification 的大小事 (转帖)

    關於Anroid 的使用者來說,Notification 是一個非常會看到且用到的功能 他可以提醒使用者甚麼東西需要待處理,像是郵件或是會議的提醒等.. 甚至有些APP ,直接使用Notificati ...

  2. [Xamarin] 關於Internal Storage ,存取App內部使用資料 (转帖)

    最近在開發App,會使用到必須要處理一些App所使用的資料,上網路查一下Android 得作法,包含我自己也實作了一下,可能是因為對Java || Android 不是很孰悉,常常錯在 java.la ...

  3. 在laravel下關於blade模板的嘗試

    Blade模板 關於模板繼承和分區段 @section和@yield的實驗 ①關於@section...@show嘗試 測試1 {{--appV2test.blade.php--}} <html ...

  4. Unity3D连接sqlite数据库操作C#版

    unity3d有自己对应的sqlite.dll分别需要三个文件 1.Mono.Data.Sqlite.dll 在unity安装文件“Unity\Editor\Data\MonoBleedingEdge ...

  5. 实验8 SQLite数据库操作

    实验报告 课程名称 实验8  SQLite数据库操作 实验日期 2016.5.6 实验项目名称 多媒体应用开发 实验地点 S30010 实验类型 □验证型    √设计型    □综合型 学  时 一 ...

  6. 我的Android六章:Android中SQLite数据库操作

    今天学习的内容是Android中的SQLite数据库操作,在讲解这个内容之前小编在前面有一篇博客也是讲解了SQLite数据库的操作,而那篇博客的讲解是讲述了 如何在Window中通过DOM来操作数据库 ...

  7. 開博客了, 因為搞Delphi 開發的關於Delphi學習

    開博客了, 因為搞Delphi 開發的關於Delphi學習,之前都是用本地TXT文件保存,發現在本地電腦保存非常不方面,而且只能在一台電腦上保存,不容易查看和修改內容.便於以後的記錄只用,以及經驗交流 ...

  8. [python]用Python进行SQLite数据库操作

    用Python进行SQLite数据库操作 1.导入Python SQLITE数据库模块 Python2.5之后,内置了SQLite3,成为了内置模块,这给我们省了安装的功夫,只需导入即可~  ]: u ...

  9. 安卓 SQLite数据库操作实例

    前段时间写了个安卓平台下SQLite数据库操作的实例 ,一直没得时间总结 ,今天把它弄出来了. 在Android 运行时环境包含了完整的 SQLite. 首先介绍一下SQLite这个数据库: SQLi ...

随机推荐

  1. VS2008 Windows Form项目安装包生成详解

    2008 Windows Form项目的发布对有经验的程序员来说,可能不值一提,但对很多新手来说却不知道如何操作,因为在很多关于Visual Studio的书籍中也没有相关介绍,权威如<C# 2 ...

  2. 关于rand()与srand()函数

    rand函数功能为获取一个伪随机数(伪随机数的概念下面会有介绍). 一.函数名: rand(); 二.声明: int rand(); 三.所在头文件: stdlib.h 四.功能: 返回一个伪随机数. ...

  3. {POJ}{动态规划}{题目列表}

    动态规划与贪心相关: {HDU}{4739}{Zhuge Liang's Mines}{压缩DP} 题意:给定20个点坐标,求最多有多少个不相交(点也不相交)的正方形 思路:背包问题,求出所有的正方形 ...

  4. CSS BOX模型

    对于box模型概念的理解以及它与决定元素最终尺寸的方式有何关系,是理解如何设定网 页上的元素位置的基础.box模型应用到块级元素.一个随之而来的概念,内联布局模型 定义了如何设定内联元素的位置. 对于 ...

  5. Brn系列商城4.1正式发布,欢迎大家下载体验

    此次升级内容如下: 独立IP搜索策略 独立文件上传策略 添加退换货功能 重构支付方式 常规性修复和改进 下载地址:http://www.brnshop.com

  6. Raid详解

    Raid详解 一.什么是RAID 磁盘阵列全名是『Redundant Arrays of Inexpensive Disks, RAID 』,英翻中的意思是:容错式廉价磁盘阵列. RAID 可以透过一 ...

  7. JSP(forward动作)登录功能

    <%@ page language= "java" contentType="text/html;charset=UTF-8" %><html ...

  8. 使用rownum对oracle分页

    以Student表为例进行分页 建表及插入 -- 有表结构如下 create table STUDENT ( sno INTEGER, sname ), sage INTEGER ); -- 插入数据 ...

  9. 用T-sql 实现Oracle Connect by 的功能

    ; with subDepartment as ( select BesonDepartmentID, DepartmentName, ParentBesonDepartmentID, 1 as Hi ...

  10. 你必须了解的基础的 Linux 网络命令

    Linux 基础网络命令列表 我在计算机网络课程上使用 FreeBSD,不过这些 UNIX 命令应该也能在 Linux 上同样工作. 连通性 ping <host>:发送 ICMP ech ...