SQLCE是一个标准得关系数据库,可以使用 LINQ 和DateContext来处理本地数据库数据库。

  使用SQLCE 要在代码中使用本地数据库功能,需要添加以下命名空间 :

    using System.Data.Linq;

    using System.Data.Linq.Mapping;

    using Microsoft.Phone.Data.Linq;

    using Microsoft.Phone.Data.Linq.Mapping;

  DateContext能将LINQ数据库操作语句转换成关系数据库能辨识的标准SQL语句。DateContext类是LINQ操作SQLCE的一个基类。

DateContext连接数据库

  需要为DateContext类设置一个连接字符串,DateContext就可以连接或打开一个数据库。如果数据库存在则将其打开,不存在则创建。 实例代码如下:

    DateContext dcdb = new DataContext(Data Sourse =isostore:/dc.sdf);

创建数据库
  在创建 DataContext 对象之后,可以创建本地数据库并执行一些其他数据库操作。
  创建SQLCE数据库表,创建数据库时不能使用T-SQL语句进行创建,而是先要创建LINQ语句映射。
    例如:

 using (ToDoDataContext db = new ToDoDataContext("isostore:/db.sdf"))
{
if (db.DatabaseExists() == false)
{
db.CreateDatabase();
}
}

  若要创建DataContext,必须首先指定数据上下文和数据库文件的文件位置。DataContext 构造函数值指定数据库文件名称为 ToDo.sdf。该值的 isostore:/ 部分指定该文件位于本地文件夹中。接下来,在 DatabaseExists 方法确认数据库尚不存在之后,使用 CreateDatabase 方法创建数据库。

操作数据库

  在本地数据库创建之后,可以使用 LINQ 和DateContext来处理本地数据库。 操作数据库主要有以下操作:在数据库中查询、插入、更新和删除数据。

数据库查询

  在 Windows Phone 中,使用语言集成查询 (LINQ) 查询数据库。LINQ 可弥补对象部分和数据部分之间的间隙。LINQ to SQL 中查询使用的语法与 LINQ 中的查询相同。 由于 LINQ to SQL 查询中引用的对象被映射到数据库中的记录,因此 LINQ to SQL 在查询的执行方式上与其他 LINQ 技术有所不同。 典型的 LINQ 查询在应用层的内存中执行。通过 LINQ to SQL 使用运行时的对象关系功能,每一个 LINQ 查询都被转换为 Transact-SQL,然后在数据库中直接执行。这样可以提高查询的性能。

插入数据

  将数据插入数据库的过程分为两个步骤。首先在DateContext中添加一个对象,然后DateContext使用InsertOnSubmit执行添加操作。

更新数据

  更新本地数据库中的数据分为三个步骤。首先,在数据库中查询要更新的对象。然后,按需要修改对象。最后,调用 SubmitChanges 方法将更改保存到本地数据库。 如果将DateContext中的对象绑定到页面上的控件,则DateContext会根据用户交互自动进行更新。然后,所需的唯一步骤是在需要时调用 SubmitChanges 方法。 例如下面进行数据更新:

 protected override void OnNavigatedFrom(System.Windows.Navigation.NavigationEventArgs e)
{
base.OnNavigatedFrom(e);
toDoDB.SubmitChanges();
}

删除数据

  删除数据库中的数据也包含三个步骤:首先,在数据库中查询要删除的对象。然后,根据您需要删除一个还是多个对象,分别调用 DeleteOnSubmit 或 DeleteAllOnSubmit 方法,以将这些对象置于挂起删除状态。最后,调用 SubmitChanges 方法将更改保存到本地数据库。

数据库加密

  本地数据库提供了密码保护和加密功能来确保数据库的安全。在对数据库使用密码功能时,整个数据库都会被加密。若要加密数据库,请在创建数据库之前在数据库连接字符串(DateContext构造函数)中提供密码。每次访问数据库时都需要提供密码。在数据库创建之后便无法对其加密。数据库是使用 AES-128 加密的,而密码是使用 SHA-256 进行哈希处理的。 以下代码演示如何通过在数据库连接字符串中指定密码来创建加密数据库。

         ToDoDataContext db = new ToDoDataContext ("Data Source=’isostore:/ToDo.sdf’;Password=’securepassword’");
if (!db.DatabaseExists())
db.CreateDatabase();

  下面通过一个简单的例子更加深入的了解本地数据库:

    MainPage.xaml.cs部分代码:

 namespace SqlCe
{
public partial class MainPage : PhoneApplicationPage, INotifyPropertyChanged
{
private ToDoDataContext toDoDB;
private ObservableCollection<ToDoItem> _toDoItems;
public MainPage()
{
InitializeComponent();
// 连接数据库
toDoDB = new ToDoDataContext(ToDoDataContext.DBConnectionString);
this.DataContext = this;
}
//重定离开页面事件
protected override void OnNavigatedTo(System.Windows.Navigation.NavigationEventArgs e)
{
var toDoItemsInDB = from ToDoItem todo in toDoDB.ToDoItems
select todo;
ToDoItems = new ObservableCollection<ToDoItem>(toDoItemsInDB);
base.OnNavigatedTo(e);
}
//增加数据
private void newToDoAddButton_Click(object sender, RoutedEventArgs e)
{
// 定义数据
ToDoItem newToDo = new ToDoItem { ItemName = newToDoTextBox.Text };
// 添加
ToDoItems.Add(newToDo);
// 保存数据库更改
toDoDB.ToDoItems.InsertOnSubmit(newToDo);
}
//删除数据
private void deleteTaskButton_Click(object sender, RoutedEventArgs e)
{
// 转换为参数
var button = sender as Button; if (button != null)
{
ToDoItem toDoForDelete = button.DataContext as ToDoItem;
// 移动映射表项数据
ToDoItems.Remove(toDoForDelete);
toDoDB.ToDoItems.DeleteOnSubmit(toDoForDelete);
// 保存数据库更改
toDoDB.SubmitChanges();
// Put the focus back to the main page.
this.Focus();
}
}
//更新数据库
protected override void OnNavigatedFrom(System.Windows.Navigation.NavigationEventArgs e)
{
base.OnNavigatedFrom(e);
toDoDB.SubmitChanges();
}
}

SQLCE本地数据库的更多相关文章

  1. Windows Phone本地数据库(SQLCE):14、删除数据(翻译)

    这是“windows phone mango本地数据库(sqlce)”系列短片文章的最后一篇第十四篇. 为了让你开始在Windows Phone Mango中使用数据库,这一系列短片文章将覆盖所有你需 ...

  2. Windows Phone本地数据库(SQLCE):13、更新数据(翻译)

    这是“windows phone mango本地数据库(sqlce)”系列短片文章的第十三篇. 为了让你开始在Windows Phone Mango中使用数据库,这一系列短片文章将覆盖所有你需要知道的 ...

  3. Windows Phone本地数据库(SQLCE):12、插入数据(翻译)

    这是“windows phone mango本地数据库(sqlce)”系列短片文章的第十二篇. 为了让你开始在Windows Phone Mango中使用数据库,这一系列短片文章将覆盖所有你需要知道的 ...

  4. Windows Phone本地数据库(SQLCE):11、使用LINQ查询数据库(翻译) (转)

    这是“windows phone mango本地数据库(sqlce)”系列短片文章的第十一篇. 为了让你开始在Windows Phone Mango中使用数据库,这一系列短片文章将覆盖所有你需要知道的 ...

  5. Windows Phone本地数据库(SQLCE):10、创建数据库(翻译) (转)

    这是“windows phone mango本地数据库(sqlce)”系列短片文章的第十篇. 为了让你开始在Windows Phone Mango中使用数据库,这一系列短片文章将覆盖所有你需要知道的知 ...

  6. Windows Phone本地数据库(SQLCE):9、Connection Strings(翻译) (转)

    这是“windows phone mango本地数据库(sqlce)”系列短片文章的第八篇. 为了让你开始在Windows Phone Mango中使用数据库,这一系列短片文章将覆盖所有你需要知道的知 ...

  7. Windows Phone本地数据库(SQLCE):8、DataContext(翻译)

    这是“windows phone mango本地数据库(sqlce)”系列短片文章的第八篇. 为了让你开始在Windows Phone Mango中使用数据库,这一系列短片文章将覆盖所有你需要知道的知 ...

  8. Windows Phone本地数据库(SQLCE):7、Database mapping(翻译)

    这是“windows phone mango本地数据库(sqlce)”系列短片文章的第七篇. 为了让你开始在Windows Phone Mango中使用数据库,这一系列短片文章将覆盖所有你需要知道的知 ...

  9. Windows Phone本地数据库(SQLCE):6、[Index] attribute(翻译)(转)

    这是“windows phone mango本地数据库(sqlce)”系列短片文章的第六篇. 为了让你开始在Windows Phone Mango中使用数据库,这一系列短片文章将覆盖所有你需要知道的知 ...

随机推荐

  1. MySQL之索引以及正确使用索引

    一.MySQL中常见索引类型 普通索引:仅加速查询 主键索引:加速查询.列值唯一.表中只有一个(不可有null) 唯一索引:加速查询.列值唯一(可以有null) 组合索引:多列值组成一个索引,专门用于 ...

  2. 爬虫系列(九) xpath的基本使用

    一.xpath 简介 究竟什么是 xpath 呢?简单来说,xpath 就是一种在 XML 文档中查找信息的语言 而 XML 文档就是由一系列节点构成的树,例如,下面是一份简单的 XML 文档: &l ...

  3. 【IntelliJ IDEA】idea上安装Translation插件后,需要AppKey才能生效的解决方案

    使用idea安装的翻译插件translation,但是使用的时候并不友好 无奈,如果想使用翻译软件并且更方便的话,可以如下: 可以选择将translation进行卸载 清除缓存并进行重启 然后再启动之 ...

  4. Dajngo——10 请求与响应 文件上传 GET和POST请求 类视图

    Dajngo——10 HttpRequest对象 HttpResponse对象及子类 form标签中的GET和POST GET提交方式 POST提交方式 request得GET和POST属性 文件上传 ...

  5. bupt summer training for 16 #7 ——搜索与DP

    https://vjudge.net/contest/174962#overview A.我们发现重点在于x,y只要累加就ok了 在每个x上只有上下两种状态,所以可以记忆化搜索 f[0/1][i]表示 ...

  6. [繁华模拟赛]Evensgn 剪树枝

    Evensgn 剪树枝 题目 繁华中学有一棵苹果树.苹果树有 n 个节点(也就是苹果),n − 1 条边(也就 是树枝).调皮的 Evensgn 爬到苹果树上.他发现这棵苹果树上的苹果有两种:一 种是 ...

  7. 用R语言 画条形图(基于ggplot2包)

    1.用qplot(x,data=data,geom.=”bar”,weight=y)+scale_y_continuous("y")画出y关于x的条形. 图中提示binwidth这 ...

  8. HBase行键的设计

    rowkey是行的主键,而且hbase只能用rowkey范围即scan来查找数据.rowkey是以字典排序的.可以巧妙设计行键,比如想通过电影的评价进行排序,可以把评分rate和电影id组合起来,ra ...

  9. Linux排查java程序占用cpu过高的线程代码

    分几步骤: 1.通过top,查出占用CPU过高的java进程 ,比如: pid :6666 2.通过ps -mp 6666 -o THREAD,tid,time| sort -n -k1 -r 查看此 ...

  10. SharePoint 2013:解决添加域名后每次都需要登录的问题

    在SharePoint 2013中,当我们添加一个域名给SP后(添加域名的方法请参考此文:http://www.cnblogs.com/jianyus/archive/2013/08/10/32494 ...