以文本方式查看主题

-  中文XML论坛 - 专业的XML技术讨论区  (http://bbs.xml.org.cn/index.asp)
--  『 XSL/XSLT/XSL-FO/CSS 』  (http://bbs.xml.org.cn/list.asp?boardid=8)
----  [讨论]问题的提出与解决方案![B]元素名变量化&动态组合查询条件[/B]  (http://bbs.xml.org.cn/dispbbs.asp?boardid=8&rootid=&id=17678)


--  作者:Qr
--  发布时间:4/29/2005 12:44:00 PM

--  [讨论]问题的提出与解决方案![B]元素名变量化&动态组合查询条件[/B]
最近用XML作为后台数据库写了一个小程序,只差查询功能的最后实现了。具体的要求是,使用XML+XSL方式,将查询结果输出为HTML方式的报表。由于程序要求达到让用户自定义查询方式的功能,因此,实际编程中,遇到两个亟待解决的难题。

1、元素名用变量来表示的问题

<xsl:param name="edate">date</xsl:param>
<xsl:apply-templates select="mail[substring-before($edate,'-')='2005']"/><!--yyyy-mm-dd-->
结论:好象不能使用变量来代替元素名。
有没有一个好的解决办法?

2、动态生成组合查询条件的问题

<xsl:apply-templates select="mail[substring-before(date,'-')='2005' and number(substring(date,6,2))&amp;lt;7]"/>

代码本身没有错误,是正解,但过滤的条件是定死的,没能实现“动态组合查询”,更无法让用户自定义查询条件了。要是“[]”中的过滤条件能动态组合形成,那简直太了不起了。经测试,“操作符”和“逻辑运算符”没法使用变量代替的,因此,组合条件的难度是相当大的。
有没有朋友做到类似的查询功能,请指教。


[此贴子已经被作者于2005-4-30 20:20:26编辑过]

--  作者:doubleG
--  发布时间:4/29/2005 5:05:00 PM

--  
>>1、元素名用变量来表示的问题
在apply-template中是不能用$的,只能考虑使用call-template然后传入查询条件参数了。

>>2、动态生成组合查询条件的问题
仅仅靠XSLT来实现估计是难度太大了,没有尝试过,而且本身XSLT不是用来查询而是依靠XPath来进行的,所以查询的功能还是考虑XQuery吧。


--  作者:Qr
--  发布时间:4/29/2005 5:34:00 PM

--  
以下是引用doubleG在2005-4-29 17:05:13的发言:
>>1、元素名用变量来表示的问题
在apply-template中是不能用$的,只能考虑使用call-template然后传入查询条件参数了。

>>2、动态生成组合查询条件的问题
仅仅靠XSLT来实现估计是难度太大了,没有尝试过,而且本身XSLT不是用来查询而是依靠XPath来进行的,所以查询的功能还是考虑XQuery吧。



1、在apply-template中也是能用$的:)
代码改如下:
<xsl:param name="YEAR">2005</xsl:param>
<xsl:apply-templates select="mail[substring-before(date,'-')=$YEAR]"/><!--yyyy-mm-dd-->
所以,偶想应该不是doubleG斑主说的问题。


2、XQuery!?早有所闻,不过具体没有仔细研究,先看看再说:)



--  作者:Qr
--  发布时间:4/30/2005 8:17:00 PM

--  条条大路通罗马——变通的解决方案(第一个问题)!
元素不能用变量代替,偶个认为,是对象不能使用变量代替。因此想了个变通的方案(Xpath):
<xsl:param name="pnIndex">5</xsl:param><!--这里可以动态赋值,用于接受用户提交的查询类型-->
<xsl:apply-templates select="mail[node()[number($pnIndex)]='123']"/><!--因而这里可根据$pnIndex动态指定被查询的元素-->

由此,单一条件的动态查询可解决:)


各位有更好的解决方法,欢迎参与讨论!


--  作者:Qr
--  发布时间:5/1/2005 8:01:00 AM

--  
以下是引用Qr在2005-4-29 12:44:24的发言:
2、动态生成组合查询条件的问题

<xsl:apply-templates select="mail[substring-before(date,'-')='2005' and number(substring(date,6,2))&amp;lt;7]"/>



退一步来说,“操作符”和“逻辑符”不变,当用户没有填某项目的查询关键词,如“2005”,则不对该项目进行查询,或者说是substring-before(date,'-')!='' ),用Xpath如何解决?谢谢!


[此贴子已经被作者于2005-5-2 19:43:29编辑过]

--  作者:Qr
--  发布时间:5/8/2005 5:18:00 PM

--  
冒泡:)
--  作者:yours1213
--  发布时间:5/12/2005 1:34:00 PM

--  
<SELECT style="Z-INDEX: 105; LEFT: 344px; WIDTH: 128px; POSITION: absolute; TOP: 112px; HEIGHT: 24px">
    <OPTION><xsl:param name="xq">大一上学期</xsl:param></OPTION>
                                <OPTION ><xsl:param name="xq">大一下学期</xsl:param></OPTION>
                                <OPTION ><xsl:param name="xq">大二上学期</xsl:param></OPTION>
                                <OPTION ><xsl:param name="xq">大二下学期</xsl:param></OPTION>
                                <OPTION ><xsl:param name="xq">大三上学期</xsl:param></OPTION>
                                <OPTION ><xsl:param name="xq">大三下学期</xsl:param></OPTION>
                                <OPTION ><xsl:param name="xq">大四上学期</xsl:param></OPTION>
                                <OPTION ><xsl:param name="xq">大四下学期</xsl:param></OPTION>
   </SELECT>
ie说这里不支持<xsl:param>为什么呢。该怎么写
--  作者:netet
--  发布时间:6/12/2005 2:21:00 PM

--  
高手快出手啊,为中国的xml事业做点贡献把
--  作者:孤独
--  发布时间:6/15/2005 8:07:00 AM

--  
用模板传值,就是call的那种模板,然后哪个节点的值都可取到
<?xml version="1.0"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
 <xsl:output method="html" encoding="utf-8"/>
 <xsl:template match="/People">
  <xsl:for-each select="Relation" >
   Relation<xsl:value-of select="SonID" />'s parent is
   <xsl:call-template name="do">
    <xsl:with-param name="ParentID" select="ParentID"></xsl:with-param>
   </xsl:call-template>
  </xsl:for-each>
 </xsl:template>
 <xsl:template name="do">
  <xsl:param name="ParentID"/>
  <xsl:for-each select="../person[ID=$ParentID]" >
  <xsl:value-of select="name"/>
  </xsl:for-each>
  
 </xsl:template>
</xsl:stylesheet>

<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type='text/xsl' href='people.xsl'?>
<People>
<person>
  <name>Person2</name>
  <ID>2</ID>
</person>

<person>
  <name>Person3</name>
  <ID>3</ID>
</person>

<person>
  <name>Person4</name>
  <ID>4</ID>
</person>

<Relation>
  <SonID>4</SonID>
  <ParentID>2</ParentID>
</Relation>
<Relation>
  <SonID>4</SonID>
  <ParentID>3</ParentID>
</Relation>
</People>

我刚帮人写了个,贴这好了:)


--  作者:Qr
--  发布时间:6/16/2005 5:03:00 PM

--  
TO 孤独:<xsl:call-template><xsl:with-param></xsl:with-param></xsl:call-template>能实现多条件动态查询?还是有点想不明白,请指教!
--  作者:孤独
--  发布时间:6/16/2005 10:48:00 PM

--  
1、元素名用变量来表示的问题
<xsl:variable name="edate" select="{date}"/>
<xsl:apply-templates select="mail[substring-before($edate,'-')='2005']"/>
这样也许可以

2.
<xsl:choose>
 <xsl:when test="t=1">
  <xsl:apply-templates select="mail[substring-before(date,'-')=$a and number(substring(date,$b,节点))&lt;7]"/>
 </xsl:when>
 <xsl:when test="t=2">
  <xsl:apply-templates select="mail[substring-after(date,'-')=$a and number(substring(date,$b,节点))&lt;7]"/>
 </xsl:when>
</xsl:choose>
我能想到的最好办法了..


--  作者:Qr
--  发布时间:6/16/2005 11:09:00 PM

--  
substring(date,$b,节点)一句是什么意思?
--  作者:孤独
--  发布时间:6/16/2005 11:31:00 PM

--  
就是值可以是一个变量,也可以是节点里面的一个值啊:)这样我想比较动态了...
--  作者:Qr
--  发布时间:6/16/2005 11:36:00 PM

--  
以下是引用孤独在2005-6-16 23:31:41的发言:
就是值可以是一个变量,也可以是节点里面的一个值啊:)这样我想比较动态了...


高!
--  作者:孤独
--  发布时间:6/16/2005 11:57:00 PM

--  
以下是引用Qr在2005-6-16 23:36:43的发言:
[quote]以下是引用孤独在2005-6-16 23:31:41的发言:
就是值可以是一个变量,也可以是节点里面的一个值啊:)这样我想比较动态了...
[/quote]
高!


过奖:)最近搞什么东西呢?
--  作者:Qr
--  发布时间:6/17/2005 12:03:00 AM

--  
呵呵,局域网改造,还有就是要写一个站点,类似于邮件系统,XML做列表的那种。
W 3 C h i n a ( since 2003 ) 旗 下 站 点
苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
4,765.625ms