如何从XSL文档中进行SQL查询



如何从XSLT文档中进行SQL查询。建议我如何在SQL查询中检索它。我不明白这个观点是怎么表现出来的。如何从SQL查询中进行选择。这是代码,它给出了错误。

数据集Xsl格式:

<xsl:stylesheet version="1.0" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:i18n="http://toolkit.sf.net/i18n/messages" xmlns:ddi="http://www.icpsr.umich.edu/DDI" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:outline="http://worldbank.org/toolkit/cdrom/outline" exclude-result-prefixes="ddi outline">
<xsl:include href="gettext.xslt"/>
<xsl:output method="html" version="1.0" encoding="UTF-8" indent="yes"/>
<!--file id -->
<xsl:param name="file" select="'F5'"/>
<xsl:template match="/">
<div id="variable-list">
<xsl:apply-templates select="//ddi:codeBook/ddi:fileDscr[@ID=$file]"/>
<h2><xsl:call-template name="gettext"><xsl:with-param name="msg">Variables</xsl:with-param></xsl:call-template></h2>
<table border="1" style="border-collapse:collapse;width:100%;border:1px solid silver;" cellpadding="2" class="table-variable-list">
<tr class="var-th">
<td><xsl:call-template name="gettext"><xsl:with-param name="msg">ID</xsl:with-param></xsl:call-template></td>
<td><xsl:call-template name="gettext"><xsl:with-param name="msg">Name</xsl:with-param></xsl:call-template></td>
<td><xsl:call-template name="gettext"><xsl:with-param name="msg">Label</xsl:with-param></xsl:call-template></td>
<td><xsl:call-template name="gettext"><xsl:with-param name="msg">Type</xsl:with-param></xsl:call-template></td>
<td><xsl:call-template name="gettext"><xsl:with-param name="msg">Format</xsl:with-param></xsl:call-template></td>
<td><xsl:call-template name="gettext"><xsl:with-param name="msg">Question</xsl:with-param></xsl:call-template></td>
</tr>
<xsl:apply-templates select="//ddi:codeBook/ddi:dataDscr/ddi:var[@files=$file]"/>
</table>
</div>    
</xsl:template> 
<xsl:template match="ddi:var">
<xsl:variable name="class">
<xsl:choose>
<xsl:when test="position() mod 2 = 0">
<xsl:value-of select="'row-color1'"/>
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="'row-color2'"/>
</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<xsl:variable name="id" select="@ID"/>
<xsl:variable name="link">#<xsl:value-of select="@files"/><xsl:value-of select="$id"/></xsl:variable>
<tr valign="top" class="{$class}" style="cursor:pointer"  id="{$id}" >          
<td><xsl:value-of select="@ID"/></td>
<td><xsl:value-of select="@name"/></td>
<td><xsl:value-of select="ddi:labl"/></td>
<td><xsl:value-of select="@intrvl"/></td>
<td><xsl:value-of select="ddi:varFormat/@type"/></td>
<td><xsl:value-of select="ddi:qstn/ddi:qstnLit"/></td>
</tr>
</xsl:template>
<!-- 4.3 FILE -->
<xsl:template match="ddi:fileDscr">
<xsl:variable name="file" select="@ID"/>
<h2><xsl:value-of select="substring-before(ddi:fileTxt/ddi:fileName,'.NSDstat')"/></h2>
<table class="datafile-info" cellpadding="4" >
<tr valign="top">
<td style="width:100px"><xsl:call-template name="gettext"><xsl:with-param name="msg">Content</xsl:with-param></xsl:call-template></td>
<td>
<div style="width:100%;height:80px; overflow:auto;border:1px solid silver;background-color:none;">
<div style="padding:5px;">
<xsl:value-of select="normalize-space(ddi:fileTxt/ddi:fileCont)"/>
</div>
</div>
</td>
</tr>
<tr valign="top">
<td><xsl:call-template name="gettext"><xsl:with-param name="msg">Cases</xsl:with-param></xsl:call-template></td>
<td><xsl:value-of select="ddi:fileTxt/ddi:dimensns/ddi:caseQnty"/></td>
</tr>
<tr valign="top">
<td><xsl:call-template name="gettext"><xsl:with-param name="msg">Variable(s)</xsl:with-param></xsl:call-template></td>
<td><xsl:value-of select="ddi:fileTxt/ddi:dimensns/ddi:varQnty"/></td>
</tr>
<tr valign="top">
<td><xsl:call-template name="gettext"><xsl:with-param name="msg">Structure</xsl:with-param></xsl:call-template></td>
<td><xsl:call-template name="gettext"><xsl:with-param name="msg">Type</xsl:with-param></xsl:call-template>: <xsl:value-of select="ddi:fileTxt/ddi:fileStrc/@type"/><br/>
<xsl:call-template name="gettext"><xsl:with-param name="msg">Keys</xsl:with-param></xsl:call-template>: 
<xsl:call-template name="getVariableById"><xsl:with-param name="str"><xsl:value-of select="ddi:fileTxt/ddi:fileStrc/ddi:recGrp/@keyvar"/></xsl:with-param></xsl:call-template>
</td>
</tr>
<tr valign="top">
<td><xsl:call-template name="gettext"><xsl:with-param name="msg">Version</xsl:with-param></xsl:call-template></td>
<td><xsl:value-of select="ddi:fileTxt/ddi:verStmt/ddi:version"/></td>
</tr>
<tr valign="top">
<td><xsl:call-template name="gettext"><xsl:with-param name="msg">Producer</xsl:with-param></xsl:call-template></td>
<td><xsl:value-of select="ddi:fileTxt/ddi:filePlac"/></td>
</tr>
<tr valign="top">
<td><xsl:call-template name="gettext"><xsl:with-param name="msg">Missing Data</xsl:with-param></xsl:call-template></td>
<td>    <div style="width:100%;height:80px; overflow:auto;border:1px solid silver;background-color:white;">
<div style="padding:5px;">
<xsl:value-of select="ddi:fileTxt/ddi:dataMsng"/>
</div>
</div>
</td>
</tr>
</table>
</xsl:template> 
<!-- FileRef -->
<xsl:template name="fileRef">
<xsl:param name="fileId"/>
<xsl:apply-templates select="/ddi:codeBook/ddi:fileDscr[@ID=$fileId]/ddi:fileTxt/ddi:fileName"/>
</xsl:template>
<!-- Filename -->
<xsl:template match="ddi:fileName">
<!-- this template removes the .NSDstat extension -->
<xsl:variable name="filename" select="normalize-space(.)"/>
<xsl:choose>
<xsl:when test=" contains( $filename , '.NSDstat' )">
<xsl:value-of select="substring($filename,1,string-length($filename)-8)"/>
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="$filename"/>
</xsl:otherwise>
</xsl:choose>
</xsl:template>

<xsl:template name="getVariableById">
<xsl:param name="str"/>
<xsl:variable name="delimeter" select="' '"/>
<xsl:choose>
<xsl:when test="contains($str,$delimeter)">
<xsl:variable name="varid"><xsl:value-of select="substring-before($str,$delimeter)"/></xsl:variable>
<xsl:variable name="var" select="//ddi:codeBook/ddi:dataDscr/ddi:var[@ID=$varid]"/>
<xsl:value-of select="$var/@name"/>(<xsl:value-of select="normalize-space($var/ddi:labl)"/>), 
<xsl:call-template name="getVariableById"> 
<xsl:with-param name="str" select="substring-after($str,$delimeter)"/>
<xsl:with-param name="delimeter" select="$delimeter"/>
</xsl:call-template>
</xsl:when>
<xsl:otherwise>
<xsl:variable name="var" select="//ddi:codeBook/ddi:dataDscr/ddi:var[@ID=$str]"/>
<xsl:value-of select="$var/@name"/>(<xsl:value-of select="normalize-space($var/ddi:labl)"/>)
</xsl:otherwise>
</xsl:choose>
</xsl:template>

正如我在评论中告诉你的,你的问题绝对不清楚。。。这个答案是盲目的,用我神奇的玻璃灯泡。。。还有一些研究。。。

你的样式表在这里检索到一些东西:

<xsl:apply-templates select="//ddi:codeBook/ddi:fileDscr[@ID=$file]"/>

命名空间ddi:用声明在顶部

xmlns:ddi="http://www.icpsr.umich.edu/DDI"

只需点击此链接,您就可以访问一个名为Document,Discover and Interoperate的平台,该平台提供对调查、文档等数据的公共访问。我没有深入了解,但这似乎是一个加载数据的公共源,很可能是以XML格式提供的。

如前所述:我没有潜得更深。。。这可能是无稽之谈,DDI只是一种以可互换格式描述此类数据的通用格式/接口。在这种情况下,答案可能是此处包含的文件<xsl:include href="gettext.xslt"/>。。。

您的样式表——至少我认为是这样——不从任何经典的RDBMS中调用任何数据,而是从某个地方获取XML,并将其转换为HTML表。这将在网页中显示给用户。您的应用程序可能正在将所需的数据作为参数$file进行传递。

阅读此处的DDI的入门部分

我的魔法玻璃灯泡现在需要新电池。。。

最新更新