sql server 对union连接的结果集分页

<select id="selectListByCondition1" resultType="com.spr.web.system.dto.group.GroupDTO" parameterType="hashmap">
      select * from(
      select row_number() OVER (ORDER BY ${sidx} ${sord}) AS rno ,
       id AS id,
      sort_no AS sortNo,
      group_name AS groupName,
      note AS note,
      status AS status,
      flag AS flag,
      user_id AS userId,
      company_id AS companyId,
      create_by AS createBy,
      update_by AS updateBy,
      gmt_create AS gmtCreate,
      gmt_modified AS gmtModified
  	   from (
  	     select *
	     from c_group
	     <where>
	       <if test="userId!=null">
              AND user_id=#{userId}
           </if>
           <if test="groupName!=null">
              AND group_name=#{groupName}
           </if>
              AND status=0
	     </where>
	     union
	      select *
	     from c_group
	     <where>
           <if test="groupName!=null">
              AND group_name=#{groupName}
           </if>
              AND status=1
	     </where>
  	   )t
  	   )n
  	   <if test="startQuery!=null and endQuery!=null">
  	  	 WHERE n.rno>#{startQuery}  AND n.rno&lt;=#{endQuery}	  	
  	  </if>
  </select>

查询条件根据自己的需求更改

记得修改对应的查询总数的方法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
SQL Server 中,查询树结构的分页操作需要使用递归查询和 ROW_NUMBER() 函数结合使用。以下是一个例子: 假设有一个表格 `Department`,其中包含了各个部门的信息,其中包含了上级部门的 ID,如下所示: | ID | Name | ParentID | | --- | ------------| ---------| | 1 | Company | null | | 2 | HR | 1 | | 3 | Finance | 1 | | 4 | IT | 1 | | 5 | Payroll | 3 | | 6 | Accounting | 3 | | 7 | Development | 4 | 现在,我们想要查询出所有部门的树形结构,并进行分页操作,可以使用以下的 SQL 语句: ``` WITH DepartmentTree AS ( SELECT ID, Name, ParentID, 1 AS Level, ROW_NUMBER() OVER (ORDER BY ID) AS RowNum FROM Department WHERE ParentID IS NULL -- 找到顶级部门 UNION ALL SELECT d.ID, d.Name, d.ParentID, dt.Level + 1, ROW_NUMBER() OVER (ORDER BY d.ID) AS RowNum FROM Department d JOIN DepartmentTree dt ON d.ParentID = dt.ID -- 递归查询子部门 ) SELECT * FROM ( SELECT ID, Name, ParentID, Level, RowNum, ROW_NUMBER() OVER (ORDER BY RowNum) AS PageNum FROM DepartmentTree ) AS Temp WHERE Temp.PageNum BETWEEN @StartRow AND @EndRow; ``` 在这个语句中,我们首先定义了一个名为 `DepartmentTree` 的递归查询,其中使用了 ROW_NUMBER() 函数来为每个部门生成了一个行号。然后,我们在查询结果中为每个部门添加了一个 Level 字段,表示它在树形结构中的深度。接着,我们在最外层的查询中,使用 ROW_NUMBER() 函数再次为结果生成了一个行号,并使用 WHERE 子句对结果进行了分页操作。 需要注意的是,在使用递归查询和 ROW_NUMBER() 函数进行分页操作时,性能可能会受到一定的影响。因此,在实际应用中,可能需要对数据进行缓存或者采用其他的优化方法来提升性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qq_39098505

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值