Pro*_*ofK 3 xml xpath entity-framework
我正在尝试编写一个ProviderManifestToken
在EDMX文档Schema元素中自动设置属性的实用程序,但即使是我的基本XPath也无法正常工作.我究竟做错了什么?
XML:
<?xml version="1.0" encoding="utf-8"?>
<edmx:Edmx Version="1.0" xmlns:edmx="http://schemas.microsoft.com/ado/2007/06/edmx">
<!-- EF Runtime content -->
<edmx:Runtime>
<!-- SSDL content -->
<edmx:StorageModels>
<Schema Namespace="PvmmsModel.Store" Alias="Self" Provider="System.Data.SqlClient" ProviderManifestToken="2005
Run Code Online (Sandbox Code Playgroud)
我的尝试:
var edmx = new XmlDocument();
edmx.Load(@"C:\Development\Provantage\PvmmsApp\Model.edmx");
var nsm = new XmlNamespaceManager(edmx.NameTable);
nsm.AddNamespace("edmx", "http://schemas.microsoft.com/ado/2007/06/edmx");
var x = edmx.SelectSingleNode("//edmx:Edmx/edmx:Runtime/edmx:StorageModels", nsm);
Run Code Online (Sandbox Code Playgroud)
这有效,但只要我追加Schema
查询.然后我得到一个null结果.
这是一个完整的Schema
元素实际看起来如何(你的片段似乎被修剪);
<Schema xmlns="http://schemas.microsoft.com/ado/2009/02/edm/ssdl"
Namespace="Model1.Store"
Alias="Self"
Provider="System.Data.SqlClient"
ProviderManifestToken="2005">
Run Code Online (Sandbox Code Playgroud)
注意xmlns
部分.所以它实际上在命名空间中,尽管缺少前缀.
现在,在XPath中,缺少前缀总是意味着"不在任何名称空间中".因此,您需要专门为您的XPath绑定一些前缀,并在查询中使用它:
...
nsm.AddNamespace("ssdl", "http://schemas.microsoft.com/ado/2009/02/edm/ssdl");
var x = edmx.SelectSingleNode(
"//edmx:Edmx/edmx:Runtime/edmx:StorageModels/ssdl:Schema", nsm)
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
1121 次 |
最近记录: |