Microsoft SQL Server Compact 3.5开发笔记

卢世松 2008-5-21

1.       SQL Server Compact是基于本地数据文件的嵌入式数据库,它不仅可以在Windwos CEWindows Mobile上运行,也可以运行在Windows 2000/XP/Vista上。与基于服务的SQL ServerSQL Server Express不同,它与应用程序运行在同一个进程中,这意味着不需要为它创建一个单独的服务进程。

2.       数据库文件扩展名为.sdfSQL Server主数据库文件扩展名为.mdf,次数据库扩展名为.ndf

3.       在创建表的过程中不允许插入字段和调整字段顺序,一旦表创建完成,连字段名都不再可修改。

4.       不支持创建视图。

5.       命名空间

using System.Data.SqlServerCe;           //数据库类命名空间

6.       SQL Server Compact支持创建外键约束和索引,在“子表”的外键字段上创建索引可提高查询的性能。

7.       为了能实现在项目中对数据库进行数据绑定,必须首先创建一个项目数据源,然后将它与控件进行绑定。

8.       为避免VS2008每次试图连接项目数据源时询问密码,可在数据源创建时将密码包含在连接字串中,在发布前再进行修改。

9.       强类型DataSet

强类型DataSet是一个从System.Data.DataSet继承而来的对象,但暴露了一些另外的属性,这些属性表征了表地模式,可以通过字段实现对字段的引用。如myDataSet.Orders

强类型DataSetTableAdapterSqlCeResultSet对象都是在创建数据源时由VS2008自动生成。

10.   选择哪个数据源:DataSetSqlCeResultSet

a)         从总体上看,SqlCeResultSet对数据的存储速度快于DataSet。它是SqlCeDataReader的子类。必须工作在数据连接状态下,适操作单个表中的数据和仅仅用于显示和更新GUI中的数据。通过对象本身的ReadUpdate方法来完成数据的读取和更新。

b)        DataSet拥有灵活的功能,支持断开连接的数据操作,输出输入XML,可跨表查询等等。通过数据适配器对象TableAdpaterFillUpdate方法进行数据集的填充和更新。不必管理任何数据库连接,TableAdpaterFillUpdate方法会在执行臆打开数据库连接,在完成时关闭数据连接。

c)        因为SqlCeResultSet实质是SqlCeDataReader,没有Count属性来获知被读取记录的数目,可能通过IListSource接口得到记录数:

((IListSource)productRs).GetList().Count;

但性能上有损失。

建议通过执行SELECT COUNT(*)查询来直接取得记录数将更有效率。

d)        使用SqlCeResultSet必须手工打开和关闭数据连接,在使用完SqlCeResultSet后必须显示释放。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值