新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论XSL,XSLT,XSL-FO,CSS等技术
    [返回] 计算机科学论坛XML.ORG.CN讨论区 - XML技术『 XSL/XSLT/XSL-FO/CSS 』 → [讨论]问题的提出与解决方案!元素名变量化&动态组合查询条件 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 23451 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: [讨论]问题的提出与解决方案!元素名变量化&动态组合查询条件 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     Qr 帅哥哟,离线,有人找我吗?
      
      
      威望:9
      等级:博士二年级(版主)
      文章:4392
      积分:29981
      门派:XML.ORG.CN
      注册:2004/5/15

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Qr发送一个短消息 把Qr加入好友 查看Qr的个人资料 搜索Qr在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 访问Qr的主页 引用回复这个贴子 回复这个贴子 查看Qr的博客楼主
    发贴心情 [讨论]问题的提出与解决方案!元素名变量化&动态组合查询条件

    最近用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编辑过]

       收藏   分享  
    顶(0)
      




    ----------------------------------------------
    没人帮忙,那就靠自己,自己才是最好的老师!本人拒绝回答通过站内短消息提出的问题!

    blog:http://Qr.blogger.org.cn

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/4/29 12:44:00
     
     doubleG 帅哥哟,离线,有人找我吗?
      
      
      威望:7
      等级:大三(面向对象是个好东东!)
      文章:591
      积分:4119
      门派:XML.ORG.CN
      注册:2004/5/27

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给doubleG发送一个短消息 把doubleG加入好友 查看doubleG的个人资料 搜索doubleG在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看doubleG的博客2
    发贴心情 
    >>1、元素名用变量来表示的问题
    在apply-template中是不能用$的,只能考虑使用call-template然后传入查询条件参数了。

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

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/4/29 17:05:00
     
     Qr 帅哥哟,离线,有人找我吗?
      
      
      威望:9
      等级:博士二年级(版主)
      文章:4392
      积分:29981
      门派:XML.ORG.CN
      注册:2004/5/15

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Qr发送一个短消息 把Qr加入好友 查看Qr的个人资料 搜索Qr在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 访问Qr的主页 引用回复这个贴子 回复这个贴子 查看Qr的博客3
    发贴心情 
    以下是引用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!?早有所闻,不过具体没有仔细研究,先看看再说:)

    ----------------------------------------------
    没人帮忙,那就靠自己,自己才是最好的老师!本人拒绝回答通过站内短消息提出的问题!

    blog:http://Qr.blogger.org.cn

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/4/29 17:34:00
     
     Qr 帅哥哟,离线,有人找我吗?
      
      
      威望:9
      等级:博士二年级(版主)
      文章:4392
      积分:29981
      门派:XML.ORG.CN
      注册:2004/5/15

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Qr发送一个短消息 把Qr加入好友 查看Qr的个人资料 搜索Qr在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 访问Qr的主页 引用回复这个贴子 回复这个贴子 查看Qr的博客4
    发贴心情 条条大路通罗马——变通的解决方案(第一个问题)!
    元素不能用变量代替,偶个认为,是对象不能使用变量代替。因此想了个变通的方案(Xpath):
    <xsl:param name="pnIndex">5</xsl:param><!--这里可以动态赋值,用于接受用户提交的查询类型-->
    <xsl:apply-templates select="mail[node()[number($pnIndex)]='123']"/><!--因而这里可根据$pnIndex动态指定被查询的元素-->

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


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

    ----------------------------------------------
    没人帮忙,那就靠自己,自己才是最好的老师!本人拒绝回答通过站内短消息提出的问题!

    blog:http://Qr.blogger.org.cn

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/4/30 20:17:00
     
     Qr 帅哥哟,离线,有人找我吗?
      
      
      威望:9
      等级:博士二年级(版主)
      文章:4392
      积分:29981
      门派:XML.ORG.CN
      注册:2004/5/15

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Qr发送一个短消息 把Qr加入好友 查看Qr的个人资料 搜索Qr在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 访问Qr的主页 引用回复这个贴子 回复这个贴子 查看Qr的博客5
    发贴心情 
    以下是引用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编辑过]

    ----------------------------------------------
    没人帮忙,那就靠自己,自己才是最好的老师!本人拒绝回答通过站内短消息提出的问题!

    blog:http://Qr.blogger.org.cn

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/5/1 8:01:00
     
     Qr 帅哥哟,离线,有人找我吗?
      
      
      威望:9
      等级:博士二年级(版主)
      文章:4392
      积分:29981
      门派:XML.ORG.CN
      注册:2004/5/15

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Qr发送一个短消息 把Qr加入好友 查看Qr的个人资料 搜索Qr在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 访问Qr的主页 引用回复这个贴子 回复这个贴子 查看Qr的博客6
    发贴心情 
    冒泡:)

    ----------------------------------------------
    没人帮忙,那就靠自己,自己才是最好的老师!本人拒绝回答通过站内短消息提出的问题!

    blog:http://Qr.blogger.org.cn

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/5/8 17:18:00
     
     yours1213 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(猛啃高等数学)
      文章:25
      积分:146
      门派:XML.ORG.CN
      注册:2005/4/20

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给yours1213发送一个短消息 把yours1213加入好友 查看yours1213的个人资料 搜索yours1213在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看yours1213的博客7
    发贴心情 
    <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>为什么呢。该怎么写
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/5/12 13:34:00
     
     netet 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(猛啃高等数学)
      文章:23
      积分:176
      门派:XML.ORG.CN
      注册:2005/2/27

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给netet发送一个短消息 把netet加入好友 查看netet的个人资料 搜索netet在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看netet的博客8
    发贴心情 
    高手快出手啊,为中国的xml事业做点贡献把
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/6/12 14:21:00
     
     孤独 帅哥哟,离线,有人找我吗?
      
      
      威望:7
      等级:大三(面向对象是个好东东!)(版主)
      文章:826
      积分:4220
      门派:XML.ORG.CN
      注册:2004/1/14

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给孤独发送一个短消息 把孤独加入好友 查看孤独的个人资料 搜索孤独在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看孤独的博客9
    发贴心情 
    用模板传值,就是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>

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

    ----------------------------------------------
    <?xml version="1.0" encoding="gb2312"?>
    <个人签名>
      <Website>[url=http://www.mahaobo.cn]
    MaHaobo.cn[/url]
    </Website>
    <Email>aloning(at)gmail.com</Email>
      <Qq >32113739</Qq>
    </个人签名>

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/6/15 8:07:00
     
     Qr 帅哥哟,离线,有人找我吗?
      
      
      威望:9
      等级:博士二年级(版主)
      文章:4392
      积分:29981
      门派:XML.ORG.CN
      注册:2004/5/15

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Qr发送一个短消息 把Qr加入好友 查看Qr的个人资料 搜索Qr在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 访问Qr的主页 引用回复这个贴子 回复这个贴子 查看Qr的博客10
    发贴心情 
    TO 孤独:<xsl:call-template><xsl:with-param></xsl:with-param></xsl:call-template>能实现多条件动态查询?还是有点想不明白,请指教!

    ----------------------------------------------
    没人帮忙,那就靠自己,自己才是最好的老师!本人拒绝回答通过站内短消息提出的问题!

    blog:http://Qr.blogger.org.cn

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/6/16 17:03:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2025/12/20 10:21:20

    本主题贴数16,分页: [1] [2]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    113.281ms