设为首页 收藏本站
查看: 993|回复: 0

[经验分享] Windows Mobile 5.0访问Sql Server 3.5(1)

[复制链接]

尚未签到

发表于 2015-6-30 08:46:32 | 显示全部楼层 |阅读模式
因为个人原因,好久没写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的应用程序。
DSC0000.jpg
选择平台类型(PPC/Smartphone),这里我选择了PPC。注意下面选项中还能选择使用CF2.0还是CF3.5,这里选择2.0。
DSC0001.jpg
工程创建完毕后,你创建一个Form程序时,就会出现相应的模拟器设备。
DSC0002.jpg
接着添加一个数据库,在项目工程界面,添加一个数据库。
DSC0003.jpg
这时候,会发现数据库文件的后缀名怎么变成.sdf了。然后,再创建一个对应的DataSet,用来快速开发。(本篇文章主要描述某些功能,实际项目中开发不做参考)
创建好表后,将表拖动到DataSet中,VS会自动生成对应的Adapt和强类型的DataSet。
然后在Form中,拖入一个DataGrid,将DataGrid的Dock设为Fill。大家开发WM时,最好设置Dock,因为这样控件会随着设备的变化而自动调整,WM可以侧过来使用的。

有了数据容器后,自然要绑定数据。
首先,对DataGrid进行设置,这里的DataGrid因为是CF版本,很多属性和方法都比WinForm上的要少很多。
先添加一个TabStyle,用于设置绑定一个DataTable。这里要将GenerateMember设为False,并指定好MappingName(表名)。
DSC0004.jpg
添加列,在GridColumnStyles中添加,我添加2列dataGridTextColumn,并将GenerateMember设为False,并同样指定好MappingName(列名)。
DSC0005.jpg
在Form_Load事件中,用Adapt填充一个table,然后对DataGrid绑定。
如果,在前面没有设置好TableStyle和ColumnStyle的MappingName,这里绑定时,会多出一些列。
DSC0006.jpg
这就是不想要的效果。
DSC0007.jpg
这就是想要的效果。

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

DataGrid无法直接进行编辑,那我们如何进行编辑呢,我的处理方式如下:
新建一个Form,将选中的某行信息,作为参数传入到编辑Form,该Form上编辑完后,再回传取得数据即可。
DSC0008.jpg
简单的数据库访问的应用程序就算做完了。代码如下:


DSC0009.gif DSC00010.gif Code
1 DSC00011.gif using 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 DSC00012.gif {
12 DSC00013.gif     public partial class Form1 : Form
13 DSC00014.gif DSC00015.gif     {
14        private AppDatabase1DataSet.Sys_UserDataTable table;
15        AppDatabase1DataSetTableAdapters.Sys_UserTableAdapter adapt;
16
17        public Form1()
18        {
19            InitializeComponent();
20 DSC00016.gif         }
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 DSC00017.gif }

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-81809-1-1.html 上篇帖子: [SQL Server]关于15517号错误的一点想法 下篇帖子: SQL Server 2008支持将数据导出为脚本
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表