bboss数据库标签系列一 分页列表详细信息标签预编译sql查询数据

简介: 本系列文章详细介绍bboss标签库的数据库标签具体使用方法,涉及到的功能包括: db查询(普通查询、预编译查询,分页查询),db新增、修改、删除、批处理操作(预编译)。 bboss数据库标签系列一 分页列表详细信息标签预编译sql查询数据 beaninfo标签,pager标签,list标签预编译sql获取数据功能相关属性和标签: sqlparamskey-指定将绑定变量参数存储在request 属性集中的变量名称,以便pager,beaninfo,list标签获取sql的绑定变量参数值。
本系列文章详细介绍bboss标签库的数据库标签具体使用方法,涉及到的功能包括:
db查询(普通查询、预编译查询,分页查询),db新增、修改、删除、批处理操作(预编译)。


bboss数据库标签系列一 分页列表详细信息标签预编译sql查询数据
beaninfo标签,pager标签,list标签预编译sql获取数据功能相关属性和标签:
sqlparamskey-指定将绑定变量参数存储在request 属性集中的变量名称,以便pager,beaninfo,list标签获取sql的绑定变量参数值。本节详细介绍如何直接通过预编译sql语句来实现数据展示。
1   详细信息Beaninfo标签
<%@ page contentType="text/html; charset=UTF-8" language="java" import="java.sql.*,java.util.List" errorPage=""%>

1.1 导入标签定义文件

<%@ taglib uri="/WEB-INF/pager-taglib.tld" prefix="pg"%>

<!--
    测试在beaninfo标签上直接执行预编译查询操作,获取详细信息实例
    statement:数据库查询语句
    dbname:查询的相应数据库名称,在poolman.xml文件中进行配置
-->
1.2 定义预编译sql语句

<%
    String table_name="td_sm_user";
    String statement="select * from tableinfo where table_name=${table_name} " ;
    
%>

其中${table_name}为绑定变量,其值将由<pg:sqlparam标签来设定


<html>
<head>
<title>测试在beaninfo标签上直接执行数据库,获取详细信息实例</title>
</head>
<body>
 

    <table>

1.3 通过sqlparams和sqlparam标签指定预编译绑定变量信息

       <pg:sqlparams sqlparamskey="key" pretoken="//$//{" endtoken="//}">

              <pg:sqlparam name="table_name" value="<%= table_name %>" type="string"/>

                  
       </pg:sqlparams> 

Sqlparams标签: sqlparamskey属性用来在request中存放这些绑定变量信息,pretoken="//$//{" endtoken="//}"分别指定了变量的定义前界符和后分界符。
Sqlparam指定了变量table_name的值以及类型为string,table_name必须和sql语句:
select * from tableinfo where table_name=${table_name}中的${table_name}一致。
1.4 Beaninfo标签上执行预编译查询Statement指定预编译sql语句,sqlparamskey指定通过key属性从request中获取预编译参数绑定变量集


      
<pg:beaninfo statement="<%=statement %>" 

              dbname="bspf"

               sqlparamskey="key">

       
           <tr class="cms_data_tr" id="<pg:cell colName="table_name" defaultValue=""/>">

              <td>
                  table_name:
              </td> 
              <td>
                  <pg:cell colName="table_name" defaultValue=""/>

              </td> 
              <td>
                  table_id_name:
              </td>
              <td>
                  <pg:cell colName="table_id_name" defaultValue="" />

              </td>
              <td class="tablecells" align=center height='30' width="5%">

                  table_id_value:
              </td>  
              <td class="tablecells" align=center height='30' width="5%">

                  <pg:cell colName="table_id_value" defaultValue=""/>

              </td>  
           </tr>
       </pg:beaninfo>





2 列表展示list标签
<%@ page contentType="text/html; charset=UTF-8" language="java" import="java.sql.*,java.util.List" errorPage=""%>

2.1 导入标签定义文件

<%@ taglib uri="/WEB-INF/pager-taglib.tld" prefix="pg"%>

<!--
    测试在list标签上直接执行 预编译数据库操作,获取列表信息实例
    statement:数据库预编译查询语句
    dbname:查询的相应数据库名称,在poolman.xml文件中进行配置
-->


2.2 定义预编译sql语句

<%
    String TABLE_ID_TYPE="int";
    String statement="select * from tableinfo where TABLE_ID_TYPE=${TABLE_ID_TYPE} order by table_id_value desc" ;
    
%>

其中${TABLE_ID_TYPE}为绑定变量,其值将由<pg:sqlparam标签来设定


<html>
<head>
<title>测试在list标签上直接执行预编译数据库操作,获取分页列表信息实例</title>
</head>
<body>
 

    <table>

2.3 通过sqlparams和sqlparam标签指定预编译绑定变量信息

     
 <pg:sqlparams sqlparamskey="key" pretoken="//$//{" endtoken="//}">

              <pg:sqlparam name="TABLE_ID_TYPE" value="<%=TABLE_ID_TYPE %>" type="string"/>

                  
       </pg:sqlparams> 

Sqlparams标签: sqlparamskey属性用来在request中存放这些绑定变量信息,pretoken="//$//{" endtoken="//}"分别指定了变量的定义前界符和后分界符。
Sqlparam指定了变量TABLE_ID_TYPE的值以及类型为int,TABLE_ID_TYPE必须和sql语句:
select * from tableinfo where TABLE_ID_TYPE=${TABLE_ID_TYPE} order by table_id_value desc
中的${TABLE_ID_TYPE}一致。
2.4 list标签上执行预编译分页查询Statement指定预编译sql语句,sqlparamskey指定通过key属性从request中获取预编译参数绑定变量集

     
 <pg:list  id="testid" statement="<%=statement%>" sqlparamskey="key"

              dbname="bspf" isList="false" maxPageItems="5">

           <pg:header>
              <pg:title type="td" width="15%" className="headercolor" title="表名" sort="true" colName="table_name"/>

              <pg:title type="td" width="15%" className="headercolor"  sort="true" colName="table_id_name" title="表id名"/>
              <pg:title type="td" width="15%" className="headercolor"  sort="true" colName="table_id_value" title="表id值"/>            
           </pg:header>
           <pg:param name="table_name"/>

           <tr class="cms_data_tr" id="<pg:cell colName="table_name" defaultValue=""/>">

              <td> <pg:rowid offset="false" increament="1"/>

                  <pg:cell colName="table_name" defaultValue=""/>

              </td> 
              <td>
                  <pg:cell colName="table_id_name" defaultValue="" />

              </td>
              <td class="tablecells" align=center height='30' width="5%">

                  <pg:cell colName="table_id_value" defaultValue=""/>

              </td>  
           </tr>
       </pg:list>
       <tr><td><pg:rowcount id="testid"/></td><td colspan="2">yi

       <pg:index custom="true" id="testid"/>

       </td></tr>    
       
    </table>
</body>
</html>

3 分页展示pager标签
<%@ page contentType="text/html; charset=UTF-8" language="java" %>

3.1 导入标签定义文件
<%@ taglib uri="/WEB-INF/pager-taglib.tld" prefix="pg"%>

<!--
    测试在pager标签上直接执行预编译数据库操作,获取列表/分页信息实例
    statement:数据库查询语句
    dbname:查询的相应数据库名称,在poolman.xml文件中进行配置
   
-->

3.2 定义预编译sql语句
<%
    String object_id = "20"; 
    String sql = "select * from sqltest  where object_id=#[object_id] order by object_name";
 %>

其中#[object_id]为绑定变量,其值将由<pg:sqlparam标签来设定


<html>
<head>
<title>测试在pager标签上直接执行数据库操作,获取分页列表信息实例</title>
</head>
<body>
    <table>

3.3 通过sqlparams和sqlparam标签指定预编译绑定变量信息          
<pg:sqlparams sqlparamskey="key" pretoken="#//[" endtoken="//]">

              <pg:sqlparam name="object_id" value="<%=object_id %>" type="int"/>

           </pg:sqlparams>

Sqlparams标签: sqlparamskey属性用来在request中存放这些绑定变量信息,pretoken="#//[" endtoken="//]"分别指定了变量的定义前界符和后分界符。
Sqlparam指定了变量object_id的值以及类型为int,object_id必须和sql语句:
select * from sqltest  where object_id=#[object_id] order by object_name

中的#[object_id]一致。
3.4  Pager标签上执行预编译分页查询Statement指定预编译sql语句,sqlparamskey指定通过key属性从request中获取预编译参数绑定变量集
          
<pg:pager statement="<%=sql %>" 

                 dbname="bspf" 

                 isList="false" 

                 pager_infoName="pager_info11" 

                 sqlparamskey="key" >          

                 <%
                 System.out.println("pager_info11.getDataSize():" + pager_info11.getDataSize());
                 %>
                 <tr><td colspan="3"><pg:index/></td></tr>

           <pg:list >

           <%
                 System.out.println("pager_info11.getDataSize()2:" + pager_info11.getDataSize());
                 %>
              <tr class="cms_data_tr" id="<pg:cell colName="object_id" defaultValue=""/>">

                  <td>
                     <pg:cell colName="owner" defaultValue=""/>

                  </td> 
                  <td>
                     <pg:cell colName="object_id" defaultValue="" />

                  </td>
                  <td class="tablecells" align=center height='30' width="5%">

                     <pg:cell colName="object_name" defaultValue=""/>

                  </td>  
              </tr>
           </pg:list>
           <tr><td colspan="3"><br><br></td></tr>

           <%
                 System.out.println("pager_info11.getDataSize()1:" + pager_info11.getDataSize());
                 %>
           </pg:pager>
       
    </table>
</body>
</html>
目录
相关文章
|
20天前
|
存储 人工智能 Cloud Native
云栖重磅|从数据到智能:Data+AI驱动的云原生数据库
在9月20日2024云栖大会上,阿里云智能集团副总裁,数据库产品事业部负责人,ACM、CCF、IEEE会士(Fellow)李飞飞发表《从数据到智能:Data+AI驱动的云原生数据库》主题演讲。他表示,数据是生成式AI的核心资产,大模型时代的数据管理系统需具备多模处理和实时分析能力。阿里云瑶池将数据+AI全面融合,构建一站式多模数据管理平台,以数据驱动决策与创新,为用户提供像“搭积木”一样易用、好用、高可用的使用体验。
云栖重磅|从数据到智能:Data+AI驱动的云原生数据库
|
10天前
|
SQL 缓存 监控
大厂面试高频:4 大性能优化策略(数据库、SQL、JVM等)
本文详细解析了数据库、缓存、异步处理和Web性能优化四大策略,系统性能优化必知必备,大厂面试高频。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:4 大性能优化策略(数据库、SQL、JVM等)
|
22天前
|
SQL 关系型数据库 数据库
国产数据实战之docker部署MyWebSQL数据库管理工具
【10月更文挑战第23天】国产数据实战之docker部署MyWebSQL数据库管理工具
68 4
国产数据实战之docker部署MyWebSQL数据库管理工具
|
8天前
|
SQL 监控 关系型数据库
SQL语句当前及历史信息查询-performance schema的使用
本文介绍了如何使用MySQL的Performance Schema来获取SQL语句的当前和历史执行信息。Performance Schema默认在MySQL 8.0中启用,可以通过查询相关表来获取详细的SQL执行信息,包括当前执行的SQL、历史执行记录和统计汇总信息,从而快速定位和解决性能瓶颈。
|
11天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第8天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统准备、配置安装源、安装 SQL Server 软件包、运行安装程序、初始化数据库以及配置远程连接。通过这些步骤,您可以顺利地在 CentOS 系统上部署和使用 SQL Server 2019。
|
19天前
|
SQL 存储 缓存
如何优化SQL查询性能?
【10月更文挑战第28天】如何优化SQL查询性能?
69 10
|
12天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第7天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统要求检查与准备、配置安装源、安装 SQL Server 2019、配置 SQL Server 以及数据库初始化(可选)。通过这些步骤,你可以成功安装并初步配置 SQL Server 2019,进行简单的数据库操作。
|
13天前
|
SQL 关系型数据库 MySQL
|
19天前
|
关系型数据库 分布式数据库 数据库
云栖大会|从数据到决策:AI时代数据库如何实现高效数据管理?
在2024云栖大会「海量数据的高效存储与管理」专场,阿里云瑶池讲师团携手AMD、FunPlus、太美医疗科技、中石化、平安科技以及小赢科技、迅雷集团的资深技术专家深入分享了阿里云在OLTP方向的最新技术进展和行业最佳实践。
|
22天前
|
SQL 数据采集 监控
局域网监控电脑屏幕软件:PL/SQL 实现的数据库关联监控
在当今网络环境中,基于PL/SQL的局域网监控系统对于企业和机构的信息安全至关重要。该系统包括屏幕数据采集、数据处理与分析、数据库关联与存储三个核心模块,能够提供全面而准确的监控信息,帮助管理者有效监督局域网内的电脑使用情况。
16 2
下一篇
无影云桌面