首先、要说到的是,windows phone 7.1上基本的数据库功能是SQL Compact关于Mango的一个实现,使用linq to sql访问存储在数据库上的数据。

 

1、LINQ to SQL是什么

LINQ to SQL 是一个作为.NET Framework上的一部分的ORM(对象关系映射)框架。它允许你映射你的业务对象(business object)(模型类)到数据库中的表,然后可以不用写单一的SQL语句来访问或查询数据库中的数据。随着Mango的更新,LINQ to SQL现在可以用于Windows Phone。

     你可以使用LINQ to SQL:
     1、映射你的业务对象(business object)到数据库中的表
     2、使用LINQ查询数据库
     3、使用LINQ to SQL的API插入数据到数据库中
     4、使用LINQ to SQL的API更新数据
     5、使用LINQ to SQL的API删除数据
 
     虽然windows phone 支持LINQ to SQL的大部分特性,但是它也有一些局限性。你可以看一下完整的MSDN文档http://msdn.microsoft.com/zh-cn/library/hh202872(v=vs.92).aspx。下面给出其中的一些:
    1、不支持ExecuteCommand :Windows Phone 不支持执行原始 Transact-SQL、数据定义语言 (DDL) 或数据建模语言 (DML) 语句。    
     2、不支持ADO.NET(例如DataReader):LINQ to SQL查询的所有数据都将在DataContext指定的类型集合中返回    
     3、仅支持Microsoft SQL Server Compact Edition (SQL CE)数据类型:SQLCE是本地数据库的基础数据库技术。有关SQLCE数据类型的完整列表请看:http://msdn.microsoft.com/zh-cn/library/ms172424(v=sql.110).aspx

      4、不支持Table.IListSource.GetList :若要绑定到表中的所有内容,请查询整个表并绑定到查询。使用业务逻辑处理插入和删除。
      5、不支持BinaryFormatter(二进制类型):若要将自定义类型转换为SQL Server Binary或VarBinary数据类型,您的数据上下文属性可以实现LINQ to SQL CustomType,或者可以为byte[]或System.Data.Linq.Binary 类型。若要实现 LINQ to SQL CustomType,请首先创建实现 ToString() 和 Parse() 的自定义类,然后将该类用作您数据上下文中的属性。LINQ to SQL 可从 CustomType 映射到任何 SQL Server 字符串类型,例如,Char、NChar、NVarChar、Text 和 XML。
      6、Take() 在LINQ查询中需要使用常数值:SQL CE 不支持在 Transact-SQL TOP 会话中使用查询值。如果您要在 Take 方法中使用变量值,请在未使用 Take 方法的其他查询中计算该值。
      7、Skip()和Take()需要使用排序列表:这些方法依赖于排序返回一致的结果。

2、它是怎么工作的

简单地说,LINQ是一组扩展方法,让你可以在C#或VB中使用特殊的查询语法来查询数据库中的数据。为了表示查询而使用标准的LINQ查询运算符,基本的查询语法是一个方便的陈述性的简写。在你开始之前,你需要了解一些基本的东西:

       1、LINQ to SQL 查询表达式通常以“from”子句开始,以“select”子句结束
    2、“from”子句表示你想要查询的数据(通常你从collection/datacontext中查询数据)
    3、“select”子句表示你想要返回的数据,并且它应该是什么样的格式
    4、每当你想要过滤数据时你可以使用“where”子句
    5、通过“orderby”子句对数据进行排列
注释:LINQ to SQL在数据库层完成所有的过滤和排序,这让它变得非常高效。为此,你可以在C#代码中编写LINQ查询,它会自动翻译成SQL,然后SQL runtime会执行语句,所以当你执行下面的LINQ 查询
1 var query = from p in context.Persons where p.Age > 18 select p;

在实际执行之前,LINQ to SQL runtime会自动将它翻译成下面的SQL查询

1 SELECT [t0].[ID], [t0].[FirstName], [t0].[LastName], [t0].[Age]
2 FROM [dbo].[People] AS [t0]
3 WHERE [t0].[Age] > @p0

注释:关于更多的关于完整的LINQ语法你可以看一下官方文档:http://msdn.microsoft.com/zh-cn/library/bb308959.aspx

这篇文章我谈了有关在windows phone mango本地数据库中使用LINQ to SQL。请继续关注接下来的文章。

Windows Phone本地数据库(SQLCE):2、LINQ to SQL(翻译)(转)的更多相关文章

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

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

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

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

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

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

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

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

  5. Windows Phone本地数据库(SQLCE):5、[Association]attribute(翻译)(转)

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

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

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

  7. Windows Phone本地数据库(SQLCE):3、[table]attribute(翻译) (转)

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

  8. Windows Phone本地数据库(SQLCE):1、介绍(翻译)(转)

    一只大菜鸟,最近要学习windows phone数据库相关的知识,找到了一些比较简短的教程进行学习,由于是英文的,顺便给翻译了.本身英语水平就不好,估计文中有不少错误,如果有不幸读到的童鞋请保持对翻译 ...

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

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

随机推荐

  1. [uart]1.Linux中tty框架与uart框架之间的调用关系剖析

    转自:http://developer.51cto.com/art/201209/357501_all.htm 目录 1.tty框架 2.uart框架 3.自底向上 4.自顶向下 5.关系图 在这期间 ...

  2. rank over partition by

    高级函数,分组排序 over: 在什么条件之上. partition by e.deptno: 按部门编号划分(分区). order by e.sal desc: 按工资从高到低排序(使用rank() ...

  3. sublime text 3 使用简介

    2014年1月22日 09:47:50 2用了一段时间感觉不错,就是自带的高亮显示匹配标签或者代码块儿时有点儿不清楚,所以一直是sublime 开PHP,notepad++开html 现在想只用一个编 ...

  4. jstack查看Java堆栈信息

    命令 jps 查看进程id jstack 1234 查看该进程的线程堆栈信息 对于每个线程,都有如下信息: 线程名,如“main”线程属性(如果是Daemon线程,会有Daemon标识,否则,什么都没 ...

  5. Restful对于URL的简化

    REST是英文representational state transfer(表象性状态转变)或者表述性状态转移,它是web服务的一种架构风格.使用HTTP,URI,XML,JSON,HTML等广泛流 ...

  6. http://blog.csdn.net/u011001723/article/details/45621027

    http://blog.csdn.net/u011001723/article/details/45621027 scp  + 脚本 config 外置 http://www.cnblogs.com/ ...

  7. goodrain云平台 mysql主从同步应用创建

    mysql 主从同步原理 1)在Slave 服务器上执行sart slave命令开启主从复制开关,开始进行主从复制. 2)此时,Slave服务器的IO线程会通过在master上已经授权的复制用户权限请 ...

  8. SqlServer中 CREATE PARTITION FUNCTION使用

    表分区的操作三步走: 1.创建分区函数 CREATE PARTITION FUNCTION xx1(int) 解释:在当前数据库中创建一个函数,该函数可根据指定列的值将表或索引的各行映射到分区. 语法 ...

  9. CAS单点登录安装笔记

    http://lib.iteye.com/blog/166619 https://www.cnblogs.com/zhenyulu/archive/2013/01/22/2870838.html

  10. html屏幕旋转事件监听

    近期做微信服务号开发,在做图片展示的时候需要横竖屏的检测实现图片大小不同的展示. 添加屏幕旋转事件侦听,可随时发现屏幕旋转状态(左旋.右旋还是没旋). 摘自:http://bbs.phonegap10 ...