下面是模板的一般形式,显示了指定 sql 查询和 xpath 查询的方式:
<root xmlns:sql="urn:schemas-microsoft-com:xml-sql"
sql:xsl='xsl filename' >
<sql:header>
<sql:param>..</sql:param>
<sql:param>..</sql:param>...n
</sql:header>
<sql:query>
sql statement(s)
</sql:query>
<sql:xpath-query mapping-schema="schemafilename.xml">
xpath query
</sql:xpath-query>
</root>
模板中的任何元素都是可选的。元素 <header>、<param>、<query>、<xpath-query> 和特性映射架构在 sql 命名空间中定义。因此,必须在命名空间中声明 xmlns:sql="urn:schemas-microsoft-com:xml-sql"。可对命名空间任意命名;sql 只是一个别名。
<root>
指定此标记以提供所得到的 xml 文档的单个顶层元素(也称为根标记)。<root> 标记可以是任何名称。
<sql:header>
此标记用于保存所有标题值。在目前的实施方案中,只能在此标记中指定 <sql:param> 元素。<sql:header> 用作包含标记,使您得以定义多个参数。所有的参数定义都在一个位置中,这使得处理参数定义更有效。
<sql:param>
该元素用于定义在模板内传递到查询的参数。每个 <param> 元素定义一个参数。可以在 <sql:header> 标记中定义多个 <param> 元素。
<sql:query>
该元素用于指定 sql 查询。可以在模板中指定多个 <sql:query> 元素。
<sql:xpath-query>
该元素用于指定 xpath 查询。因为 xpath 查询是在带批注的 xml 数据简化 (xdr) 架构上执行,所以必须使用 mapping-schema 特性指定架构文件名。
sql:xsl
该特性用于指定将应用于所得到的 xml 文档的可扩展样式表语言 (xsl) 样式表。在指定映射架构文件时,可以指定相对或绝对路径。指定的相对路径是相对于与 template 类型的虚拟名称关联的目录。例如,如果与 template 类型的虚拟名称相关联的目录是 c:\template,那么为 sql:xsl 指定的相对路径 xyz/myxsl.xml 将映射到 c:\template\xyz\myxsl.xml。
mapping-schema
该特性用于标识带批注的 xdr 架构。仅当在模板中执行 xpath 查询时才指定该特性。xpath 查询在带批注的 xdr 架构上执行。在指定映射架构文件时,可以指定相对或绝对路径。指定的相对路径是相对于与 template 类型的虚拟名称关联的目录。例如,如果与 template 类型的虚拟名称关联的目录是 c:\template,则相对路径(为 mapping-schema 指定的 schema/mschema.xml)映射到 c:\template\schema\mschema.xml。
说明 每个 <sql:query> 或 <sql:xpath-query> 表示单独的事务。因此,如果在模板中有多个 <sql:query> 或 <sql:xpath-query> 标记,当一个标记失败时,其它标记将继续。
如果设置了 contenttype,则 sqlisapi.dll 将标题信息返回给浏览器。如果没有设置 contenttype,则 urlmon 使用模板文件中的第一个字符确定内容类型。如果模板中的第一个字符是 < 字符或 unicode 字节顺序标志 (0xfffe),则将 text/xml 作为内容类型返回给浏览器,且浏览器显示结果。否则,sqlisapi.dll 不发送用以指导浏览器如何显示结果的内容类型标题信息;因此,在浏览器中将看不到结果。
可以在 url 模板中指定模板之前,必须使用用于 sql server 的 iis 虚拟目录管理实用工具创建 template 类型的虚拟名称。有关更多信息,请参见使用用于 sql server 的 iis 虚拟目录管理实用工具。
存储模板
模板存储在与 template 类型的虚拟名称关联的目录或它的一个子目录中:
模板存储在与 template 类型的虚拟名称关联的目录或它的一个子目录中:
如果模板存储在与 template 类型的虚拟名称关联的目录中,则 url 查询的形式如下:
http://iisserver/nwind/templatevirtualname/templatefile.xml
http://iisserver/nwind/templatevirtualname/templatefile.xml
如果模板存储在与 template 类型 (xyz) 的虚拟名称关联的子目录中,则 url 查询的形式如下:
http://iisserver/nwind/templatevirtualname/xyz/templatefile.xml
http://iisserver/nwind/templatevirtualname/xyz/templatefile.xml
对于在 url 中直接指定的 xpath 查询,不支持命名空间。如果希望在 xpath 查询中使用命名空间,则应使用 template,欢迎访问网页设计爱好者web开发。
标签: