因为个人原因,好久没写blog。对于移动开发方面的变化只能用日新月异来形容阿。WM7也很快就要推出了,Sql Server CE 都到3.5了,真是跟不上步伐阿。


这篇文章就从如何开始用WM5.0开发基于Sql Server CE 的应用程序吧。


下面先简单介绍下Sql Server CE 的基础吧:

SQL Server 2005 Compact Edition(缩写为SQL Server CE)是微软推出的一个适用于嵌入到移动应用设备的精简数据库产品,Windows Mobile开发人员能够使用SQL Server CE开发出将数据管理能力延展到Window Mobile移动设备上的应用程序。SQL Server CE不但提供了完整的SQL语法,包括内部联接、外部联接和子查询,还内置了数据同步技术的支持。有一点要注意的是,SQL Server 2005 Compact Edition除了可以作为移动数据库在Windows Mobile设备上运行外,它也支持在PC上存放数据,为桌面的应用程序提供数据支持。但可惜貌似不支持视图、存储过程等。


在资料中查到SQL Server CE数据库引擎还提供了两个非常重要的技术,那就是远程数据访问和合并复制。这两种方法都是用来实现与远程数据库进行数据同步的,使得我们可以很容易将远程数据库中的信息加载到设备端的SQL Server CE数据库中,此外我们还可以在离线状态下对SQL Server CE数据库进行插入、删除、更新等修改操作,最后就可以将修改后的数据回发到远程数据库中,确保了设备端和服务器端的数据同步。(在后续文章中会做进一步的讲述)


基础的概述了一番,那从Demo入手,体验一下究竟Sql Server CE吧。

开发环境:VS2008

开发语言:C#

数据库:Sql Server CE3.5

这里使用 VS2008作为开发环境,偷懒了一次。以后文章将使用VS2005的开发环境。


打开VS2008,选择Smart Device,然后在右上角选择.net Framework 2.0,创建一个基于.net Framework2.0的应用程序。


sql server2005 SP3中文版 sql server 15.0.2000.5_数据库


选择平台类型(PPC/Smartphone),这里我选择了PPC。注意下面选项中还能选择使用CF2.0还是CF3.5,这里选择2.0。


sql server2005 SP3中文版 sql server 15.0.2000.5_Server_02


工程创建完毕后,你创建一个Form程序时,就会出现相应的模拟器设备。


sql server2005 SP3中文版 sql server 15.0.2000.5_Sql Server CE_03


接着添加一个数据库,在项目工程界面,添加一个数据库。


sql server2005 SP3中文版 sql server 15.0.2000.5_Sql Server CE_04


这时候,会发现数据库文件的后缀名怎么变成.sdf了。然后,再创建一个对应的DataSet,用来快速开发。(本篇文章主要描述某些功能,实际项目中开发不做参考)

创建好表后,将表拖动到DataSet中,VS会自动生成对应的Adapt和强类型的DataSet。

然后在Form中,拖入一个DataGrid,将DataGrid的Dock设为Fill。大家开发WM时,最好设置Dock,因为这样控件会随着设备的变化而自动调整,WM可以侧过来使用的。


有了数据容器后,自然要绑定数据。

首先,对DataGrid进行设置,这里的DataGrid因为是CF版本,很多属性和方法都比WinForm上的要少很多。

先添加一个TabStyle,用于设置绑定一个DataTable。这里要将GenerateMember设为False,并指定好MappingName(表名)。


sql server2005 SP3中文版 sql server 15.0.2000.5_SQL_05



添加列,在GridColumnStyles中添加,我添加2列dataGridTextColumn,并将GenerateMember设为False,并同样指定好MappingName(列名)。


sql server2005 SP3中文版 sql server 15.0.2000.5_Sql Server CE_06


在Form_Load事件中,用Adapt填充一个table,然后对DataGrid绑定。

如果,在前面没有设置好TableStyle和ColumnStyle的MappingName,这里绑定时,会多出一些列。


sql server2005 SP3中文版 sql server 15.0.2000.5_数据库_07


这就是不想要的效果。


sql server2005 SP3中文版 sql server 15.0.2000.5_Server_08


这就是想要的效果。


DataGrid无法设置某个列的Visible,没有该属性。所以只能通过该方法来屏蔽掉一些列。


DataGrid无法直接进行编辑,那我们如何进行编辑呢,我的处理方式如下:

新建一个Form,将选中的某行信息,作为参数传入到编辑Form,该Form上编辑完后,再回传取得数据即可。



sql server2005 SP3中文版 sql server 15.0.2000.5_数据库_09

简单的数据库访问的应用程序就算做完了。代码如下:

 1using System;
 2
 3using System.Collections.Generic;
 4using System.ComponentModel;
 5using System.Data;
 6using System.Drawing;
 7using System.Text;
 8using System.Windows.Forms;
 9
10namespace SmartDeviceProject1
11{
12    public partial class Form1 : Form
13    {
14        private AppDatabase1DataSet.Sys_UserDataTable table;
15        AppDatabase1DataSetTableAdapters.Sys_UserTableAdapter adapt;
16
17        public Form1()
18        {
19            InitializeComponent();
20        }
21
22        private void menuItem4_Click(object sender, EventArgs e)
23        {
24            Application.Exit();
25        }
26
27        private void menuItem3_Click(object sender, EventArgs e)
28        {
29            adapt = new SmartDeviceProject1.AppDatabase1DataSetTableAdapters.Sys_UserTableAdapter();
30            adapt.Fill(table);
31            this.dataGrid1.DataSource = table;
32        }
33
34        private void Form1_Load(object sender, EventArgs e)
35        {
36            table = new AppDatabase1DataSet.Sys_UserDataTable();
37        }
38
39        private void menuItem5_Click(object sender, EventArgs e)
40        {
41            if (adapt == null)
42                adapt = new SmartDeviceProject1.AppDatabase1DataSetTableAdapters.Sys_UserTableAdapter();
43
44            MessageBox.Show("Effect rows are " + adapt.Update(table).ToString());
45        }
46
47        private void menuItem6_Click(object sender, EventArgs e)
48        {
49            //Form2是编辑Form,通过传入值后,在该Form中修改,然后再去取得数据,写入DataTable中。
50            Form2 form = new Form2();
51            form.User_ID = table[this.dataGrid1.CurrentCell.RowNumber].User_Id;
52            form.User_Name = table[this.dataGrid1.CurrentCell.RowNumber].User_Name;
53            form.Mail = table[this.dataGrid1.CurrentCell.RowNumber].Mail;
54            form.ShowDialog();
55
56            if (form.IsSave)
57            {
58                table[this.dataGrid1.CurrentCell.RowNumber].User_Id = form.User_ID;
59                table[this.dataGrid1.CurrentCell.RowNumber].User_Name = form.User_Name;
60                table[this.dataGrid1.CurrentCell.RowNumber].Mail = form.Mail;
61            }
62        }
63    }
64}