欢迎来到天天文库
浏览记录
ID:40565467
大小:512.83 KB
页数:16页
时间:2019-08-04
《Silverlight中连接MySQL数据库实例详解》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、Silverlight中连接MySQL数据库实例详解2009-12-3111:43 来源:天极网软件频道 作者:天极网开发频道 责任编辑:郑重·yesky 评论(3)本文将重点讲述Silverlight中连接MySQL数据库实例,这在RIA开发中比较基础,但是也是比较重要的内容。希望通过本文能让大家对连接MySQL有更深刻的理解。在银光中国网(SilverlightChina.Net)有一篇"Silverlight与常用数据库互操作系列"文章,其中介绍了使用Silverlight存取不同数据库的方法和步骤。但是对于Silverl
2、ight存取MSSQL介绍的不够全面,这里我想介绍Silverlight如何通过WCF访问MSSQL数据库存储过程的。希望对大家能够有所帮助。我们要实现,用户输入用户名和密码后,点击登录按钮,传递用户名和密码到服务器端,通过WCF访问MSSQL数据库,调用存储过程,在服务器端对用户名和密码进行匹配,匹配成功,则返回登录成功,否则,则是失败。在文章开始前,我们需要做一下准备工作,开发环境需求:VS2008SP1,Silverlight3DevelopToolsforVS2008SP1,客户端Silverlight3Runtime,
3、MSSQL2005SP3;建立例程数据库SilverlightDemo,在数据库中建立一个新表Users,包含以下字段;添加内容到Users表,为了方便起见,密码全部使用明文,在正式项目中,建议对密码字段进行加密使用。这里,我们验证用户名和密码,有两种简单方式,一是使用存储过程读取用户名和密码,然后在服务器端进行用户名和密码匹配校验,如果查找到匹配数据,则返回登录成功,否则,则是登录失败;二是传用户名和密码到存储过程中,在数据库存储过程中进行判断,使用Select语句进行查找,对应用户名和密码,如果查找到匹配结果,则返回用户ID
4、,服务器端接收到用户ID,则返回登录成功,否则,则是失败;在本例中,主要是对Silverlight访问数据库进行讲述,所以,对于验证方法,不进行详细描述和讲解,如果有问题,可以留言给我,我们继续讨论,这里,我将使用第一种验证方法。为此,建立一个简单的存储过程:1.CREATEPROCEDURE[dbo].[Login]2.(@UserNameVarchar(30))3.AS4.SelectcUserName,cPassword5.FromUsers6.WherecUserName=@UserName1.RETURN2.SETNO
5、COUNTON在完成上面的准备工作后,开始建立新的Silverlight项目,1.建立一个新项目"SilverlightDBDemo",2.在MainPage中建立简单的登录界面,如下:3.在Web项目中添加新选项4.添加一个简单的用户信息类Users,作为WCF的契约成员,当我们从数据库中读取信息后,将赋值给该类的契约成员,方便客户端进行调用;VS2008将自动生成Users类代码,在类命名前添加数据契约属性[DataContract()]。为了能够使绑定数据返回修改通知,这里需要继承INotifyPropertyChange
6、d接口,该步骤不添加对本教程也没有影响,为了以后例程代码完整性,这里我继承了该接口。在接口上点击右键,生成代码。代码如下:1.namespaceSilverlightDBDemo.Web2.{3.[DataContract()]4.publicclassUsers:INotifyPropertyChanged5.{6.7.#regionINotifyPropertyChangedMembers8.1.publiceventPropertyChangedEventHandlerPropertyChanged;2.#endregio
7、n3.}4.}5.在Users类中,添加契约成员1.privatestringuserName;2.[DataMember()]3.publicstringUserName4.{5.get{returnuserName;}6.set{userName=value;}7.}8.9.privatestringpassword;10.[DataMember()]11.publicstringPassword12.{13.get{returnpassword;}14.set{password=value;}15.}6.建立构造函数pub
8、licUsers(stringsUserName,stringsPassword),传递用户名和密码给契约成员;1.usingSystem;2.usingSystem.ComponentModel;3.usingSystem.Runtime.Serializat
此文档下载收益归作者所有