在我们开发程序的时候,出现了这样一种需求,就是需要利用数据库中的数据配合文书模板生成标准文书。这种文书模板又需要根据实际情况经常发生变动,因此不能写死程序来产生文书。我目前想到的解决办法是定义一种标记语言,程序根据标记去数据库查找数据,再替换到文书中。
会有这样几种标记:
1、简单标记,即一个SQL语句产生一个字段的一行数据,比如”select mc from czy where zydm”,程序把”:”打头的参数替代为正确的值后去数据库取值。
2、单行标记,即一个SQL语句产生数个字段的一行数据,比如”select mc,nl from czy where czydm=:czydm”。
3、多行标记,即一个SQL语句产生数个字段的多行数据,比如”select mc,nl from czy”。标记有这样一个要求:
    能够支持嵌套,即能够利用前一层的SQL取得的值作为参数去取下一层的数据。比如,第一层为:"select 部门 from 员工表",第二层为"select 员工姓名 from 员工表 where部门=:取得的部门"。当然作为一个变通的办法,可以一个SQL,”select 部门,员工姓名 from 员工表 order by 部门”,把部门作为分组条件。    现在请大家帮忙给出这种标记语言的定义方法。因为以前缺乏这方面的经验,请有这方面的经验的同学赐教!
    分不够可以再加!

解决方案 »

  1.   

    直接用xml标记语言啊。
    比如说 
    1、简单标记,即一个SQL语句产生一个字段的一行数据,比如”select mc from czy where zydm”,程序把”:”打头的参数替代为正确的值后去数据库取值。
    <row>
       <mc>这行的mc对应的值</mc>//如果要加入字段类型的话:可以写成<mc type="int">值</mc>
    </row>
    3、多行标记,即一个SQL语句产生数个字段的一行数据,比如”select mc,nl from czy where czydm=:czydm”。
    <row>
       <mc>这行的mc对应的值</mc>//如果要加入字段类型的话:可以写成<mc type="int">值</mc>
       <nl>nl的值</nl>
    </row>
    <row>
       <mc>这行的mc对应的值</mc>
       <nl>nl的值</nl>
    </row>支持标记嵌套<员工表row>
       <部门>
             部门的值
             <员工表row>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
       </部门>
       <nl>nl的值</nl>
    </员工表row>
    <员工表row>
       <部门>
             部门的值
             <员工表row>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
       </部门>
       <nl>nl的值</nl>
    </员工表row>
      

  2.   

    xml拥有3种内容。参数,子节点和节点内容。它和关系数据库是等价的。关系数据库的内容都可以通过某种xml完全反映过来。所以你的要求肯定能通过xml实现。最好你自己看看相关网页,大概只有3,4页吧,很快的。不然要理解你的要求,有点困难<root count=3>
    <员工表row>
       <序号>
              row序号值
       </序号>
       <部门 value="开发部" count='3' >
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
       </部门>
       <nl>nl的值</nl>
    </员工表row>
    <员工表row>
       <序号>
              row序号值
       </序号>
       <部门 value="开发部" count='3' >
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
       </部门>
       <nl>nl的值</nl>
    </员工表row>
    <员工表row>
       <序号>
              row序号值
       </序号>
       <部门 value="开发部" count='3' >
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
       </部门>
       <nl>nl的值</nl>
    </员工表row>
      

  3.   

    xml拥有3种内容。参数,子节点和节点内容。它和关系数据库是等价的。关系数据库的内容都可以通过某种xml完全反映过来。所以你的要求肯定能通过xml实现。最好你自己看看相关网页,大概只有3,4页吧,很快的。不然要理解你的要求,有点困难<root count=3>
    <员工表row>
       <序号>
              row序号值
       </序号>
       <部门 value="开发部" count='3' >
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
       </部门>
       <nl>nl的值</nl>
    </员工表row>
    <员工表row>
       <序号>
              row序号值
       </序号>
       <部门 value="开发部" count='3' >
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
       </部门>
       <nl>nl的值</nl>
    </员工表row>
    <员工表row>
       <序号>
              row序号值
       </序号>
       <部门 value="开发部" count='3' >
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
             <员工表row>
                  <序号>
                       员工序号值
                  </序号>
                  <员工姓名>
                       员工姓名 的 值
                  </员工姓名>
             </员工表row>
       </部门>
       <nl>nl的值</nl>
    </员工表row>