gpt4 book ai didi

mysql - 如何从 XSL 文档进行 SQL 查询?

转载 作者:行者123 更新时间:2023-11-29 19:37:51 25 4
gpt4 key购买 nike

如何从 XSLT 文档进行 SQL 查询。建议我如何在 SQL 查询中检索此内容。我不明白该 View 如何显示。如何从 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"

只需点击此链接,您就会进入一个名为文档、发现和互操作的平台,该平台提供对调查、文档等数据的公共(public)访问。我没有深入研究,但这似乎是一个加载数据的公共(public)源,很可能是以 XML 格式提供的。

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

您的样式表 - 至少我是这么认为 - 不会从任何经典 RDBMS 调用任何数据,而是从某处获取 XML 并将其转换HTML - table 。这在网页内向用户显示。您的应用程序可能正在将所需的数据作为参数 $file 传递.

Read the getting started section for DDI here

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

关于mysql - 如何从 XSL 文档进行 SQL 查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41480553/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com