前言

我的工作目前不涉及到Windows phone的开发,但是业余时间也开发过几款app。以前由于各种条件的限制,只接触到WP8.0设备的app开发。

最近几个月开始将WP8的应用迁移到WP8.1,发现很多API都变了。

最令我印象深刻也最意外的一点是:【找不到MessageBox】了。

卧槽,找不到MessageBox...(此处省略100字)

回归正题,在WP8阶段,微软为本地数据库的操作提供了一系列API,需要的朋友可以通过:http://msdn.microsoft.com/zh-cn/library/hh202860查看。

不过在WP8.1(XAML)中这些API已经无法使用了,通过搜索一些资料,最终把以前的一些本地数据库操作API替换成Sqlite的版本。

步骤

1.建立一个WP8.1的项目。

2.画一个简单的UI,如图:

app具有一个简单的功能:将“姓名”和“年龄”数据保存到数据库表中。

app的下半部分是一个列表(现在没有任何数据所以看不出来),用于显示当前数据表中的所有信息。

3.建立模型

public class Person
{
public int ID
{
get;
set;
} public string Name
{
get;
set;
} public int Age
{
get;
set;
}
}

4.依次选择VS菜单栏:【工具】--》【扩展和更新】-->【联机搜索Sqllite】,如图:

下载Sqlite for windows phone8.1,我这里已经下载好了。

5.下载安装完毕之后需要重启VS。

6.添加对Sqlite的引用,如图:

7.接下来编译会发生一个错误,需要将编译架构调整为“ARM”或者“X86”.

8.添加的sqlite引用是C++开发的,在项目中没有办法直接使用。我们还需要在项目中添加一些别人封装好的类。

9.打开Nuget管理器,搜索“Sqlite”,安装“Sqlite-net”,如图:

10.安装完毕后会发现项目中多了两个类,我们操作Sqlite数据库主要也就是使用这两个类中的方法和属性。如图:

11.接下来可以做点真正有意义的事情了。首先得我们需要告诉Sqlite哪个属性是主键吧?

我们把“ID”作为主键。

public class Person
{
[PrimaryKey]
[AutoIncrement]
public int ID
{
get;
set;
} public string Name
{
get;
set;
} public int Age
{
get;
set;
}
}

特性"PrimaryKey"表明特性对应的属性作为表的主键。“AutoIncrement”表明这是一个自增列。

12.创建Person表。

/// <summary>
/// 创建Person表
/// </summary>
/// <returns></returns>
private async Task<SQLiteAsyncConnection> CreatePersonTableAsync()
{
var conn = new SQLiteAsyncConnection(localDBPath);
await conn.CreateTableAsync<Person>(); return conn;
}

localDBPath是数据库文件的路径。

我们可以通过返回的“SQLiteAsyncConnection”对象,对Person表进行增删查改的操作。

13.目前为止,准备工作都做好了。可以书写按钮点击事件的逻辑了。

private async void AddData_Tapped(object sender, TappedRoutedEventArgs e)
{
//构造Person对象
Person person = new Person();
person.Name = textboxName.Text;
person.Age = int.Parse(textboxAge.Text); //插入到数据库
var conn = await CreatePersonTableAsync();
await conn.InsertAsync(person);
}

需要注意的是CreateTableAsync方法并不会覆盖掉已有的Table。

备注

这篇文章主要帮助一些不知道如何在WP8.1中使用Sqlite的朋友快速上手。

文章中贴出的代码并没有对一些异常做处理,实际项目中这是不可能的。主要是方便大家看到最精要的部分。

其他数据库的操作方法我就不一一列举了,查看“SQLiteAsync”类的代码,5分钟就可以知道可以通过SQLiteAsync做哪些事情。

友情链接:zhoumy博客

在Windows Phone 8.1中使用Sqlite数据库的更多相关文章

  1. Android虚拟机中的sqlite数据库文件

    Android虚拟机中的sqlite数据库文件 ①

  2. 在项目中使用SQLite数据库小结

    ------------------------------------------------------------------------推荐: - VS2012 使用 1.0.84 版的库 - ...

  3. 2014-08-01 ASP.NET中对SQLite数据库的操作——ADO.NET

    今天是在吾索实习的第18天.我主要学习了如何在ASP.NET中对SQLite数据库的操作,其基本操作如下: 添加引用System.Data.SQLite.dll(PS:在网页里面任意找到适合的.NET ...

  4. android中与SQLite数据库相关的类

    为什么要在应用程序中使用数据库?数据库最主要的用途就是作为数据的存储容器,另外,由于可以很方便的将应用程序中的数据结构(比如C语言中的结构体)转化成数据库的表,这样我们就可以通过操作数据库来替代写一堆 ...

  5. Go语言中使用SQLite数据库

    Go语言中使用SQLite数据库 1.驱动 Go支持sqlite的驱动也比较多,但是好多都是不支持database/sql接口的 https://github.com/mattn/go-sqlite3 ...

  6. 在Android 开发中使用 SQLite 数据库笔记

    SQLite 介绍   SQLite 一个非常流行的嵌入式数据库,它支持 SQL 语言,并且只利用很少的内存就有很好的性能.此外它还是开源的,任何人都可以使用它.许多开源项目((Mozilla, PH ...

  7. 在 Android 应用程序中使用 SQLite 数据库以及怎么用

    part one : android SQLite 简单介绍 SQLite 介绍 SQLite 一个非常流行的嵌入式数据库.它支持 SQL 语言,而且仅仅利用非常少的内存就有非常好的性能.此外它还是开 ...

  8. C#中使用SQLite数据库简介(上)

    [SQLite数据库] SQLite是一个开源的轻量级的桌面型数据库,它将几乎所有数据库要素(包括定义.表.索引和数据本身)都保存在一个单一的文件中.SQLite用C编写实现,它在内存消耗.文件体积. ...

  9. 在安卓开发中使用SQLite数据库操作实例

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

随机推荐

  1. Asp.net Core 2.1新功能Generic Host(通用主机),了解一下

    什么是Generic Host ? 这是在Asp.Net Core 2.1加入了一种新的Host,现在2.1版本的Asp.Net Core中,有了两种可用的Host. Web Host –适用于托管W ...

  2. SQL注入渗透实战

    概述: 判断注入点: http://www.xxxxx.com/page.php?pid=42 and 1=1 #true http://www.xxxxx.com/page.php?pid=42 a ...

  3. 解决mysql中只能通过localhost访问不能通过ip访问的问题

    解决mysql中只能通过localhost访问不能通过ip访问的问题 原因是没开权限 SELECT * FROM USER WHERE USER='root'; grant all privilege ...

  4. 【English】20190428

    It is of paramount importance that极为重要的一点[pærəmaʊnt] strategizing around SOA围绕soa制定战略  efficient gov ...

  5. Java 钩子函数编程技巧

    Java提供注册钩子线程,在JVM进程关闭之前,会自动执行这个钩子线程. 运用这个技巧,可以再JVM关闭之前,释放一些系统资源. 这个功能利用的是Runtime类来实现. public class H ...

  6. 我所不知道的Makefile语法

    问题一: $(CC) -c $^ -o $(ROOT_DIR)/$(OBJS_DIR)/$@ 这里的$^和$@是设么意思? 经过查找,该特殊符号的用法如下: 假如:all:library.cpp ma ...

  7. c语言-自己写的库

    一.俗话说算法是程序的灵魂,这下面本人写了一部分常用算法,欢迎大家使用,并提出批评和指正,当然也可以改进或者添加. 1.这是自己实现的算法库头文件 #ifndef _INC_ALGORITHM #de ...

  8. Kubernetes 笔记 08 Deployment 副本管理 重新招一个员工来填坑

    本文首发于我的公众号 Linux云计算网络(id: cloud_dev),专注于干货分享,号内有 10T 书籍和视频资源,后台回复「1024」即可领取,欢迎大家关注,二维码文末可以扫. Hi,大家好, ...

  9. WebPack引用Bootstrap 无法使用图标的结局方案

    npm i https://github.com/iconic/open-iconic.git -D  因为boostrap的css里删除了图标 分开了 我们在引入个呵呵. 下载:npm i boot ...

  10. Kubernetes的污点和容忍(上篇)

    背景 搭建了一个k8s(Kubernetes)的事件监听服务,监听事件之后对数据做处理.有天报了一个问题经调查是新版本的k8s集群添加会把unschedule等信息通过污点的方式反映.而这些污点是只有 ...