c# – 自定义Linq-to-SQL MappingSource
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c# – 自定义Linq-to-SQL MappingSource,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1535字,纯文字阅读大概需要3分钟。
内容图文
我有一个项目,它将已编译的实体框架域与动态定义的外部数据库混合在一起.用户可以在运行时提供连接字符串,表名和列名以访问外部系统.我以前一直使用动态生成的SQL来访问外部系统(当然是为了避免SQL注入而精心设计),并将感兴趣的表读入DataTable并将这些表实现为POCO.
现在,90%的视图使用IQueryable对象来检查数据库查询的结构,并有效地格式化/分页/操作视图.这使我在执行查询之前可以对查询进行大量的工作.对于涉及外部系统记录的视图,我只是咬紧牙关并使用了IEnumerable.AsQueryable().
我非常想使用不同的解决方案.我倾向于Linq-to-SQL(我对其他建议持开放态度),但我坚持创建一个动态的MappingSource.此外,有些列是可选的,如果我没有为每列提供映射,我不知道Linq-to-SQL是否会爆炸.
public class ExternalMappingSource : MappingSource
{
public string[] KeyColumns { get; set; }
public string NameColumn { get; set; }
public string DescriptionColumn { get; set; }
public string TimestampColumn { get; set; }
protected override MetaModel CreateModel(Type dataContextType)
{
// ???
}
}
我无法在网上找到任何好的资源.如何清除这门课程?
解决方法:
如果您事先知道相关结构(表和字段值),则可以基于该数据提供自定义映射源,而无需事先获得该对象.对我来说,由于不同的原因,我最终使用了XmlMappingSource对象,因为它有一个.FromXml()方法,可以用来提供任意的Xml.如果您查看sqlmetal生成的映射文件,您可以了解所需的Xml结构:
>打开VS命令提示符(它位于开始菜单中的Visual Studio Tools文件夹中).
>将目录更改为项目.
>输入命令“sqlmetal /map:whatever.map / code yourlinqtosql.dbml”.这将生成带有格式化Xml的whatever.map文件.
根据需要以编程方式输入XmlMappingSource.FromXml()方法.然后,您可以使用相关的连接字符串和更改的映射源创建上下文.
内容总结
以上是互联网集市为您收集整理的c# – 自定义Linq-to-SQL MappingSource全部内容,希望文章能够帮你解决c# – 自定义Linq-to-SQL MappingSource所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。