论坛首页 Java企业应用论坛

利用newxy(新坐标),不写一行java代码实现多项查询

浏览 1812 次
该帖已经被评为隐藏帖
作者 正文
   发表时间:2007-03-08  
DAO

利用newxy(新坐标),不写一行java代码实现多项查询<o:p></o:p>

胡立新<o:p></o:p>

利用newxy(新坐标)技术可以不写一行java代码实现多项查询。(在线演示http://www.newxy.net/zh_cn/samples/sample4/demo.jsp) <o:p></o:p>

  • newxy(新坐标)多项查询利用了NQL查询类。 <o:p></o:p>
  • newxy(新坐标)多项查询用到三个标签,<nlogic:action1><nlogic:action2><nhtml:form /><nhtml:button /> <o:p></o:p>
  • <nhtml:form />标签内不要用 submit之类的标签,如<html:submit value=""></html:submit><input type="submit" value=""/>, 取而代之的是<nhtml:button actionId="" method="find" /> <o:p></o:p>
  • <nhtml:button actionId="" method="find" />不一定要放到<nhtml:form />标签内。 <o:p></o:p>

范例对行业表、企业表联表查询,查询的最基本条件是 企业表的行业代码字段值等于行业表某条主关键字段值。就是:
    enterprise.industry_code=industry.code
用户所选择查询条件与基本条件是 and 关系。根据这样的前提构成的最基本查询语句:
    select a.industry,b.* from industry a,enterprise b where{a.code=b.industry_code}
newxy(
新坐标)将为此创建NQL实例:nql=new NQL(dao,"select a.industry,b.* from industry a,enterprise b where{a.code=b.industry_code}");
注意:where后紧跟的是大括号{}
为了让理解方便,范例中实际是行业大类述为行业代码 <o:p></o:p>

<nlogic:action1/>标签应放在<nhtml:form />标签上面,这两个标签针同一个formBean,因此属性formName值相同,在此formName="enterprise" <o:p></o:p>

<nlogic:action1 id="act1" formName="enterprise"/><o:p></o:p>

<nhtml:form action=""  formName="enterprise"><o:p></o:p>

  <html:hidden property="_dao" value="dao.default"/><o:p></o:p>

  <nhtml:hidden property="_sql"<o:p></o:p>

      value="select a.industry,b.* from industry as a,enterprise as b where{a.code=b.industry_code}"/><o:p></o:p>

  <table border="1"><o:p></o:p>

    <tr><o:p></o:p>

      <td>逻辑</td><o:p></o:p>

      <td><o:p></o:p>

        <html:radio property="lg" value="1">并且</html:radio><o:p></o:p>

        <html:radio property="lg" value="0">或者</html:radio><o:p></o:p>

      </td><o:p></o:p>

    </tr><o:p></o:p>

    <tr><o:p></o:p>

      <td>行业</td><o:p></o:p>

      <td>等于</td><o:p></o:p>

      <td><o:p></o:p>

        <nhtml:hidden property="_item1" value="a.code"/><o:p></o:p>

        <html:hidden property="_item1" value="="/><o:p></o:p>

        <html:select property="_item1"><o:p></o:p>

          <html:option value=""></html:option><o:p></o:p>

          <html:option value="A">农、林、牧、渔业</html:option><o:p></o:p>

          <html:option value="B">采矿业</html:option><o:p></o:p>

          <html:option value="C">制造业</html:option><o:p></o:p>

        </html:select>作为范例,行业没全列出。<o:p></o:p>

      </td><o:p></o:p>

    </tr><o:p></o:p>

    <tr><o:p></o:p>

      <td>企业名称</td><o:p></o:p>

      <html:hidden property="_item2" value="b.name"/><o:p></o:p>

      <td><o:p></o:p>

        <html:select property="_item2"><o:p></o:p>

          <html:option value=""></html:option><o:p></o:p>

          <html:option value="=">等于</html:option><o:p></o:p>

          <html:option value="like">包含</html:option><o:p></o:p>

        </html:select><o:p></o:p>

      </td><o:p></o:p>

      <td><o:p></o:p>

        <html:text property="_item2"><o:p></o:p>

        </html:text><o:p></o:p>

      </td><o:p></o:p>

    </tr><o:p></o:p>

  </table><o:p></o:p>

</nhtml:form><o:p></o:p>

加入标签<nhtml:button actionId="act1" method="find" value="查 询"/>,产生查询铵钮<o:p></o:p>

产生的查询介面如下:

<o:p></o:p>

<v:shapetype id="_x0000_t75" stroked="f" filled="f" path="m@4@5l@4@11@9@11@9@5xe" o:preferrelative="t" o:spt="75" coordsize="21600,21600"><v:stroke joinstyle="miter"></v:stroke><v:formulas><v:f eqn="if lineDrawn pixelLineWidth 0"></v:f><v:f eqn="sum @0 1 0"></v:f><v:f eqn="sum 0 0 @1"></v:f><v:f eqn="prod @2 1 2"></v:f><v:f eqn="prod @3 21600 pixelWidth"></v:f><v:f eqn="prod @3 21600 pixelHeight"></v:f><v:f eqn="sum @0 0 1"></v:f><v:f eqn="prod @6 1 2"></v:f><v:f eqn="prod @7 21600 pixelWidth"></v:f><v:f eqn="sum @8 21600 0"></v:f><v:f eqn="prod @7 21600 pixelHeight"></v:f><v:f eqn="sum @10 21600 0"></v:f></v:formulas><v:path o:connecttype="rect" gradientshapeok="t" o:extrusionok="f"></v:path><o:lock aspectratio="t" v:ext="edit"></o:lock></v:shapetype><o:p></o:p>

如果想知道行成的sql语句,可以用struts标签:<bean:write name="enterprise" property="_sql"/> <o:p></o:p>

说明: <o:p></o:p>

  • <nhtml:form />action属性值为空,是以当前路径为值。可查看产生的静态页面。 <o:p></o:p>
  • <html:hidden property="_dao" value="dao.default"/>
    其作用是指明由哪个DAO类来处理。默认值是dao.default,此处可以不用,只为演示。"_dao"是特定的属性名 <o:p></o:p>
  • <nhtml:hidden property="_sql" value="select a.industry,b.* from industry as a,enterprise as b where{a.code=b.industry_code}"/>
    在此不用struts<html:hidden/>标签或<input type="hidden" name="_sql" value="......"/>,是因为要在静态页面上不显示这条sql语名,达到安全的目的。 范例静态页面上产生的是<input type="hidden" name="_sql" value="_hidden_sql_1">。 其它几处<nhtml:hidden />作用相同。 <o:p></o:p>
  • 而且、或者逻辑关系由 <html:radio property="_lg" value="1">并且</html:radio> <html:radio property="_lg" value="0">或者</html:radio>决定。
    _lg
    是特定的属性名 <o:p></o:p>
  • 其它查询项的组合方法与企业名称行业代码查询项的组合方式相同。
    按照例中的组合,_item1的值可行成类似a.code='A'_item2的值可形成类似b.name like '%公司%'
    必须一组三项,三项用同一属性名,属性名以"_item"开头,后用不同数字区分。 <o:p></o:p>
  • 另有组合方式在后序技术文档中补充,此文档暂不介绍。 <o:p></o:p>

利用<nlogic:iterate id="" name="" property=""></nlogic:iterate>标签、<nlogic:navigate/>标签、<nhtml:TR></nhtml:TR>标签、<nhtml:javascripts/>标签、<nhtml:stylesheets/>标签来分页显示查询结果。
建义<nhtml:javascripts/>标签、<nhtml:stylesheets/>标签两标签放在页首或较前部。如果有javascripts脚本错本且数据列表没有光带, 是因为没有使用<nhtml:javascripts/>标签、<nhtml:stylesheets/>标签。 <o:p></o:p>

<nhtml:javascripts/><o:p></o:p>

<nhtml:stylesheets/><o:p></o:p>

<logic:notEmpty name="enterprise" property="_coll"><o:p></o:p>

  <table><o:p></o:p>

  <nlogic:iterate id="rec" name="enterprise" property="_coll"><o:p></o:p>

    <nhtml:TR><o:p></o:p>

      <td>1</td><o:p></o:p>

      <td><bean:write name="rec" property="industry"/></td><o:p></o:p>

      <td><bean:write name="rec" property="name"/></td><o:p></o:p>

    </nhtml:TR><o:p></o:p>

  </nlogic:iterate><o:p></o:p>

  </table><o:p></o:p>

</logic:notEmpty><o:p></o:p>

<o:p> </o:p>

下图是范例查询结果

<o:p></o:p>

<o:p> </o:p>

<o:p></o:p>

<o:p> </o:p>

范例的完整jsp代码如下:<o:p></o:p>

<o:p> </o:p>

<o:p>

<%@ page contentType="text/html; charset=GBK" %>
<%@ taglib uri="/WEB-INF/struts-bean.tld" prefix="bean" %>
<%@ taglib uri="/WEB-INF/struts-html.tld" prefix="html" %>
<%@ taglib uri="/WEB-INF/struts-logic.tld" prefix="logic" %>
<%@ taglib uri="/WEB-INF/struts-tiles.tld" prefix="tiles" %>
<%@ taglib uri="/WEB-INF/newxy-html.tld" prefix="nhtml"%>
<%@ taglib uri="/WEB-INF/newxy-logic.tld" prefix="nlogic"%>
<%@ taglib uri="/WEB-INF/newxy-bean.tld" prefix="nbean"%>

<nlogic:action1 id="act1" formName="enterprise"/>
<nhtml:form action=""  formName="enterprise">
  <html:hidden property="_dao" value="dao.default"/>
  <nhtml:hidden property="_sql" value="select a.industry,b.* from industry as a,enterprise as b where{a.code=b.industry_code}"/>
  <table border="1">
    <tr>
      <td>逻辑</td>
      <td>
        <html:radio property="_lg" value="1">并且</html:radio>
        <html:radio property="_lg" value="0">或者</html:radio>
      </td>
    </tr>
    <tr>
      <td>行业</td>
      <td>等于</td>
      <td>
        <nhtml:hidden property="_item1" value="a.code"/>
        <html:hidden property="_item1" value="="/>
        <html:select property="_item1">
          <html:option value=""></html:option>
          <html:option value="A">农、林、牧、渔业</html:option>
          <html:option value="B">采矿业</html:option>
          <html:option value="C">制造业</html:option>
        </html:select>作为范例,行业没全列出。
      </td>
    </tr>
    <tr>
      <td>企业名称</td>
      <html:hidden property="_item2" value="b.name"/>
      <td>
        <html:select property="_item2">
          <html:option value=""></html:option>
          <html:option value="=">等于</html:option>
          <html:option value="like">包含</html:option>
        </html:select>
      </td>
      <td>
        <html:text property="_item2">
        </html:text>
      </td>
    </tr>
  </table>
</nhtml:form>
<nhtml:button actionId="act1" method="find" value="查 询"/>

<nhtml:javascripts/>
<nhtml:stylesheets/>
<logic:notEmpty name="enterprise" property="_coll">
  <table>
  <nlogic:iterate id="rec" name="enterprise" property="_coll">
    <nhtml:TR>
      <td>1</td>
      <td><bean:write name="rec" property="industry"/></td>
      <td><bean:write name="rec" property="name"/></td>
    </nhtml:TR>
  </nlogic:iterate>
  </table>
</logic:notEmpty>

</o:p>
新坐标技术网站http://www.newxy.net<o:p></o:p>
<o:p> </o:p>

<o:p> </o:p>

   发表时间:2007-03-08  
你这排版也太难看了,
0 请登录后投票
   发表时间:2007-03-08  
由于排版就隐藏?不合理
0 请登录后投票
   发表时间:2007-03-08  
抛出异常的爱 写道
由于排版就隐藏?不合理

LZ应该要重新摆版。
javaEye有没有办法改进呢
0 请登录后投票
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics