千家信息网

ADO.NET实体数据模型怎么实现

发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,这篇文章主要讲解了"ADO.NET实体数据模型怎么实现",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"ADO.NET实体数据模型怎么实现"吧!ADO.N
千家信息网最后更新 2025年11月07日ADO.NET实体数据模型怎么实现

这篇文章主要讲解了"ADO.NET实体数据模型怎么实现",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"ADO.NET实体数据模型怎么实现"吧!

ADO.NET是.NET与数据库互操作的核心,而ADO.NET实体数据库则增强了.NET应用程序与数据库的互联能力,通过ADO.NET实体数据模型我们可以很方便的与底层数据库进行强类型的数据互操作。大大的方便了设计人员,从而也提高了数据库操作的安全性。最近在使用到Silverlight的领域数据服务时遇到一个很特别的问题[在应用程序中的结果和数据库的结果不一样],经过反复的试验,终于找到了问题的根源,那就是ADO.NET实体数据模型依赖于实体键,它的查询会生成实体键的唯一结果集。

现在来看看具体的操作过程和处理方式:

为了对数据库的表进行操作,在数据库的视图中建立了一个连接两个原子表的 vw_DesksAndUsers 的视图,这个视图旨在为了连接已存在的User表和Desk的数据,于是我做了如下的T-SQL的视图,如下所示:

在SQL Server 2008中得到的查询结果如下:

也就是说得到了预期的结果,[这一步很成功]。接下来进行第二步。

第二步:新建一个Silverlight商业应用程序SilverlightDomainDb,在生成的项目中会支持WCF RIA服务。这是对Silverlight领域服务的支持所必须的。

第三步:在Web项目中添加一个ADO.NET实体数据模型的新项,在向导中选择相应的数据库连接和数据表、视图及存储过程等,完成以后会生成相应的实体数据类型和上下文,并得到.edmx的模型图。如下所示:

根据Visual Studio 2010的提示,它为我们生成了两个实体键:DeskId,IsPlaying(这是Desk表中的两个字段);现在重新生成项目。

第四步:根据实体模型添加Web领域服务项。(在这一步需要添加相应的表和元数据信息)

第五步:Silverlight项目中将数据源所在vw_DesksAndUsers 的Datagrid拖到Home.xaml中,完成、调试。并没有得到上面的结果,而是生成了如下的Datagrid:

经过仔细的观察,才发现原来是ADO.NET实体数据模型中的结果集依赖于实体键,也就是说Silverlight领域服务会根据实体键的唯一生成查询的结果集,于是就产生了上面的以DeskId为唯一键的数据。

处理:

根据以上的分析,要得到预期的结果,必须设置合适的实体键,为了不至于影响到底层的SQL数据库,我们只需要修改.edmx模型图中的的实体键即可(点击右键选中或不选中"实体键"):

现在重新生成项目并运行程序,程序得到了预期的结果。

Silverlight商业应用程序作为一个专为数据显示而生的模板,为数据库的呈现提供了友好的界面,由于其优化的数据库的处理方式使得我们在使用时不得不考虑一些它们之间的细微差别[由于在Visual Studio中没能看到有LINQ生成的T—SQL查询语句,所以我也只是提供了一个简单的解决方案而已],我想其深层的原因在于LINQ查询中生成的T-SQL语句与数据库中的T-SQL语句不同而产生。

感谢各位的阅读,以上就是"ADO.NET实体数据模型怎么实现"的内容了,经过本文的学习后,相信大家对ADO.NET实体数据模型怎么实现这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

数据 实体 数据库 模型 结果 生成 程序 视图 项目 服务 查询 应用程序 领域 应用 两个 语句 问题 处理 学习 也就是 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 如何关闭网络安全密匙 芜湖盈和互联网科技有限公司 数据库应用技术车蕾 软件开发项目组长 虹口区网络软件开发内容 服务器网卡聚合联想sr650 羊城杯网络安全2021 水底数据库 北京特色软件开发收费 大数据网络技术服务以客为尊 南天门网络技术有限公司招聘 连接access数据库很慢 数据库prm 学术论文写作数据库 张掖nas存储服务器找哪家 信用卡代还软件开发oem 网络技术命令基本用书 想成为软件开发工程师的理由 韩国服务器处于脱机状态csgo 流媒体服务器流转发耗时 中专计算机和网络技术哪个好 数据库原理与应用的题 腾讯云轻量应用服务器改ip 成都网络安全员培训 数据库每次启动都要更改时间才行 开发测试服务器管理规定 职高学计算机网络技术难学吗 数据库的结构文件类型分为哪几类 互联网基金是科技板块吗 我的世界防沉迷怎么进服务器
0