찾다
데이터 베이스MySQL 튜토리얼[置顶] 存储过程 Row_number
[置顶] 存储过程 Row_numberJun 07, 2016 pm 02:50 PM
저장상단에 고정소유하다프로세스

自己之前一直是使用的通用的存储过程 ,也是封装好的只要传表名 然后 条件 等等 来到新环境 让自己写一个存储过程, 没办法 自己就需要写一个咯 之前写的比较多的是 按 top 来分页 现在公司要求是使用Row_number 当然 后者效率还是高一点 。至于索引什么的

自己之前一直是使用的通用的存储过程 ,也是封装好的只要传表名 然后 条件 等等
来到新环境 让自己写一个存储过程, 没办法 自己就需要写一个咯 之前写的比较多的是 按 top 来分页 现在公司要求是使用Row_number 当然 后者效率还是高一点 。至于索引什么的 暂时还没有用到 (有什么需求 现学也是可以的)其中也有 with(nolock) 但是会容易造成数据脏读。如果你有用到索引 或者你想看到你的语句查询开销 你可以使用(ctrl+M)键调出来。至于你看到这些占用啥的 懵了? 那就请你移驾 自行查找(我也不会你信吗?)

<code class=" hljs sql"> USE [JHMinGameDB]
GO
<span class="hljs-operator"><span class="hljs-keyword">SET</span> ANSI_NULLS <span class="hljs-keyword">ON</span>
<span class="hljs-keyword">GO</span>

<span class="hljs-keyword">SET</span> QUOTED_IDENTIFIER <span class="hljs-keyword">ON</span>
<span class="hljs-keyword">GO</span>
-- =============================================
-- Author:      yanyunhai
-- <span class="hljs-keyword">Create</span> <span class="hljs-keyword">date</span>: <span class="hljs-number">2016</span>-<span class="hljs-number">04</span>-<span class="hljs-number">13</span>
-- Description: 新手送豆
-- =============================================
<span class="hljs-keyword">CREATE</span> <span class="hljs-keyword">PROCEDURE</span> [dbo].[Web_Active_Buyu_CardLog_page] --创建该存储过程名字(如已经存在 要改的时候就把 <span class="hljs-keyword">create</span> 变成 <span class="hljs-keyword">Alter</span>)
@State <span class="hljs-keyword">int</span>, 
@startTime datetime,
@endTime datetime,
@pageSize <span class="hljs-keyword">int</span>,      
@pageIndex <span class="hljs-keyword">int</span>,     
@recd <span class="hljs-keyword">int</span> <span class="hljs-keyword">output</span>,--输出参数
@totalpeas <span class="hljs-keyword">int</span> <span class="hljs-keyword">output</span> --输出参数

<span class="hljs-keyword">AS</span>
<span class="hljs-keyword">set</span> @recd=<span class="hljs-number">0</span>   --赋值为<span class="hljs-number">0</span>是避免查询结果为<span class="hljs-number">0</span> 时 显示为<span class="hljs-keyword">null</span> 
<span class="hljs-keyword">set</span> @totalpeas=<span class="hljs-number">0</span>
<span class="hljs-keyword">Declare</span> @recdst <span class="hljs-keyword">int</span>=<span class="hljs-number">0</span>,@recdend <span class="hljs-keyword">int</span>=<span class="hljs-number">0</span> --@recdst起始条数
<span class="hljs-keyword">Set</span> @recdst=@pageSize * (@pageIndex-<span class="hljs-number">1</span>)+<span class="hljs-number">1</span>  -- @recdend 结束条数
<span class="hljs-keyword">Set</span> @recdend=@pageSize + @recdst-<span class="hljs-number">1</span>
<span class="hljs-keyword">BEGIN</span>
--在对于时间判断时建议 少用 between <span class="hljs-keyword">and</span>  因为 <span class="hljs-number">0</span>:<span class="hljs-number">00</span>-<span class="hljs-number">23</span>:<span class="hljs-number">59</span>
<span class="hljs-keyword">declare</span> @SumNum1 <span class="hljs-keyword">int</span>,@SumNum2 <span class="hljs-keyword">int</span>,@SumNum3 <span class="hljs-keyword">int</span>
<span class="hljs-keyword">select</span> @SumNum1=<span class="hljs-aggregate">COUNT</span>(*) <span class="hljs-keyword">from</span> Active_CardLog <span class="hljs-keyword">with</span>(nolock) <span class="hljs-keyword">where</span> [State]=<span class="hljs-number">0</span>
<span class="hljs-keyword">select</span> @SumNum2=<span class="hljs-aggregate">COUNT</span>(*) <span class="hljs-keyword">from</span> Active_CardLog <span class="hljs-keyword">with</span>(nolock) <span class="hljs-keyword">where</span> [State]=<span class="hljs-number">1</span>
<span class="hljs-keyword">select</span> @SumNum3=<span class="hljs-aggregate">COUNT</span>(*) <span class="hljs-keyword">from</span> Active_CardLog <span class="hljs-keyword">with</span>(nolock) <span class="hljs-keyword">where</span> [State]=<span class="hljs-number">1</span> <span class="hljs-keyword">and</span> UpTime>=@startTime <span class="hljs-keyword">and</span> UpTime<@endTime

<span class="hljs-keyword">if</span> @State>=<span class="hljs-number">0</span>
<span class="hljs-keyword">begin</span>
    <span class="hljs-keyword">select</span> row_number() over(<span class="hljs-keyword">order</span> <span class="hljs-keyword">by</span> UpTime <span class="hljs-keyword">desc</span>) <span class="hljs-keyword">as</span> rowid,a.id,CardID, CardPwd, CardNum, State, UserID, IP, UpTime, CreateTime,b.myname <span class="hljs-keyword">into</span> #tmp <span class="hljs-keyword">from</span>  Active_CardLog a 
    <span class="hljs-keyword">left</span> <span class="hljs-keyword">join</span> JH_member b <span class="hljs-keyword">on</span> b.idx=a.UserID 
     <span class="hljs-keyword">where</span> State=@State --<span class="hljs-keyword">and</span> UpTime>=@startTime <span class="hljs-keyword">and</span> UpTime<@endTime 

    <span class="hljs-keyword">select</span> @totalpeas=isnull(<span class="hljs-aggregate">SUM</span>(CardNum),<span class="hljs-number">0</span>),@recd=<span class="hljs-aggregate">count</span>(<span class="hljs-number">1</span>) <span class="hljs-keyword">from</span> #tmp 
    <span class="hljs-keyword">select</span> rowid,CardID, CardPwd, CardNum, State, UserID, IP, UpTime, CreateTime,myname,@totalpeas sumnum,@recd sumRowID,@SumNum1 SumNum1,@SumNum2 SumNum2,@SumNum3 SumNum3 <span class="hljs-keyword">from</span> #tmp
     <span class="hljs-keyword">where</span> rowid between @recdst <span class="hljs-keyword">and</span> @recdend  --根据rowid 来确定显示区间    
    <span class="hljs-keyword">drop</span> <span class="hljs-keyword">table</span> #tmp
<span class="hljs-keyword">end</span> 
    <span class="hljs-keyword">else</span> <span class="hljs-keyword">if</span> @State<<span class="hljs-number">0</span>
    <span class="hljs-keyword">begin</span>   
    <span class="hljs-keyword">select</span> row_number() over(<span class="hljs-keyword">order</span> <span class="hljs-keyword">by</span> UpTime <span class="hljs-keyword">desc</span>) <span class="hljs-keyword">as</span> rowid,a.id,CardID, CardPwd, CardNum, State, UserID,
     IP, UpTime, CreateTime,b.myname <span class="hljs-keyword">into</span> #temp <span class="hljs-keyword">from</span> Active_CardLog a
      <span class="hljs-keyword">left</span> <span class="hljs-keyword">join</span> JH_member b <span class="hljs-keyword">on</span> b.idx=a.UserID 
       <span class="hljs-keyword">where</span> UpTime>=@startTime <span class="hljs-keyword">and</span> UpTime<@endTime  

    <span class="hljs-keyword">select</span> @totalpeas=isnull(<span class="hljs-aggregate">SUM</span>(CardNum),<span class="hljs-number">0</span>),@recd=<span class="hljs-aggregate">count</span>(<span class="hljs-number">1</span>) <span class="hljs-keyword">from</span> #temp 
     <span class="hljs-keyword">where</span> rowid between @recdst <span class="hljs-keyword">and</span> @recdend  --根据rowid 来确定显示区间    
    <span class="hljs-keyword">drop</span> <span class="hljs-keyword">table</span> #temp
    <span class="hljs-keyword">end</span>
<span class="hljs-keyword">END</span>
- -其实上问可以用不用判断也可以解决这个问题 那就是用 <span class="hljs-keyword">where</span>(([State]=<span class="hljs-number">2</span>)<span class="hljs-keyword">or</span>([State]=@state))
- -有人在使用时 会出现 Rowid 报错?自己找找子查询
<span class="hljs-keyword">GO</span>   </span></code>

这里写图片描述
——————– with (nolock)—-数据多的时候可以《索引之后的选择》—————–
使用情况: 当我们在下SQL Command时,在语法中加一段WITH (NOLOCK)可以改善在线大量查询的环境中数据集被LOCK的现象藉此改善查询的效能。
不过有一点千万要注意的就是,WITH (NOLOCK)的SQL SELECT有可能会造成数据脏读。
用法:select * from table with(nolock) left join table with(nolock) 表名后面接上 with (nolock)
注意事项:①也就是说当使用NoLock时,它允许阅读那些已经修改但是还没有交易完成的数据。因此如果有需要考虑transaction事务数据的实时完整性时,使用WITH (NOLOCK)就要好好考虑一下
②:with(nolock)的写法非常容易再指定索引。
跨服务器查询语句时 不能用with (nolock) 只能用nolock
同一个服务器查询时 则with (nolock)和nolock都可以用
比如:
select * from [IP].a.dbo.table1 with (nolock) 这样会提示用错误
select * from a.dbo.table1 with (nolock) 这样就可以
当然 你也可以看看 over() 开窗函数

其中的一些东西也是看前一任 程序员写的, 然后就有在园子里面看看介绍。 自己摘了一部分 因为看别人的东西的时候也没有做到用怀疑的态度去看 去分析 所以贴出来 。如果你看到以后有错误 有误区 欢迎指正!!
对你的能力是一次证明, 对我是一次帮助。 虚心求学。

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
Vue3+TS+Vite开发技巧:如何进行数据加密和存储Vue3+TS+Vite开发技巧:如何进行数据加密和存储Sep 10, 2023 pm 04:51 PM

Vue3+TS+Vite开发技巧:如何进行数据加密和存储随着互联网技术的快速发展,数据的安全性和隐私保护变得越来越重要。在Vue3+TS+Vite开发环境下,如何进行数据加密和存储,是每个开发人员都需要面对的问题。本文将介绍一些常用的数据加密和存储的技巧,帮助开发人员提升应用的安全性和用户体验。一、数据加密前端数据加密前端加密是保护数据安全性的重要一环。常用

如何在 Windows 11 上清理缓存:详细的带图片教程如何在 Windows 11 上清理缓存:详细的带图片教程Apr 24, 2023 pm 09:37 PM

什么是缓存?缓存(发音为ka·shay)是一种专门的高速硬件或软件组件,用于存储经常请求的数据和指令,这些数据和指令又可用于更快地加载网站、应用程序、服务和系统的其他部分。缓存使最常访问的数据随时可用。缓存文件与缓存内存不同。缓存文件是指经常需要的文件,如PNG、图标、徽标、着色器等,多个程序可能需要这些文件。这些文件存储在您的物理驱动器空间中,通常是隐藏的。另一方面,高速缓存内存是一种比主内存和/或RAM更快的内存类型。它极大地减少了数据访问时间,因为与RAM相比,它更靠近CPU并且速度

抖音怎么置顶自己视频抖音怎么置顶自己视频Mar 26, 2024 pm 01:21 PM

抖音里面有用户会拍摄很多的视频作品,一旦视频作品多了以后,各种优秀的视频作品就会被掩埋了,置顶功能就很有用了,那么我们怎么置顶自己的视频作品呢?接下来小编就为大家带来了抖音置顶自己视频作品方法图文教程,还不知道怎么置顶视频的用户快来看看吧。抖音使用教程抖音怎么置顶自己视频1、首先我们打开抖音,点击主界面右下角如图所示的我。2、接着我们进入个人界面后,找到想要置顶的视频作品,点击进入播放即可。3、然后我们在视频界面,点击右下角如图所示的三个点选项。4、最后我们点击新弹出窗口中的置顶即可,返回个人界

PHP和swoole如何实现高效的数据缓存和存储?PHP和swoole如何实现高效的数据缓存和存储?Jul 23, 2023 pm 04:03 PM

PHP和swoole如何实现高效的数据缓存和存储?概述:在Web应用开发中,数据的缓存和存储是非常重要的一部分。而PHP和swoole提供了一种高效的方法来实现数据的缓存与存储。本文将介绍如何使用PHP和swoole来实现高效的数据缓存和存储,并给出相应的代码示例。一、swoole简介:swoole是一个针对PHP语言开发的,高性能的异步网络通信引擎,它可以

使用PHP数组实现数据缓存和存储的方法和技巧使用PHP数组实现数据缓存和存储的方法和技巧Jul 16, 2023 pm 02:33 PM

使用PHP数组实现数据缓存和存储的方法和技巧随着互联网的发展和数据量的急剧增长,数据缓存和存储成为了我们在开发过程中必须要考虑的问题之一。PHP作为一门广泛应用的编程语言,也提供了丰富的方法和技巧来实现数据缓存和存储。其中,使用PHP数组进行数据缓存和存储是一种简单而高效的方法。一、数据缓存数据缓存的目的是为了减少对数据库或其他外部数据源的访问次数,从而提高

一文读懂人工智能表:从MindsDB说起一文读懂人工智能表:从MindsDB说起Apr 12, 2023 pm 12:04 PM

本文转载自微信公众号「活在信息时代」,作者活在信息时代。转载本文请联系活在信息时代公众号。对于熟悉数据库操作的同学来说,编写优美的SQL语句,从数据库中想方设法找出自己需要的数据,是常规操作了。而对于熟悉机器学习的同学来说,获取数据,对数据进行预处理,建立模型,确定训练集和测试集,用训练好的模型对未来进行一系列的预测,也是一种常规操作了。那么,我们能否将两种技术结合起来呢?我们看到数据库里存储了数据,而进行预测需要基于以往的数据。如果我们通过数据库里现有的数据,对于未来的数据进行查询的话,那么是

闲鱼怎么置顶商品闲鱼怎么置顶商品Mar 09, 2024 pm 07:30 PM

置顶功能可以让我们在软件闲鱼中的商品出现在列表最前面,有些用户并不清楚闲鱼怎么置顶商品,在个人页长按商品,点击置顶宝贝即可,今天小编为各位玩家带来了置顶商品帖子方法的介绍,有需要这个文章的玩家快来看看吧。闲鱼怎么置顶商品答:在个人页长按商品,点击置顶宝贝即可。详情介绍:1、进入软件,点击右下【我的】。2、点击上方的【头像】。3、长按想要置顶的商品。4、再点击【置顶宝贝】即可。5、这样该商品就回到列表的最前面了。

威刚工控新一代高性能存储赋能AI时代威刚工控新一代高性能存储赋能AI时代Sep 22, 2023 pm 10:29 PM

9月19日,中国国际工业博览会的第二十三届正式开幕。本届工博会的主题是“碳循新工业、数聚新经济”,规模庞大,能级高,展品丰富,共有2800多家国内外展商参展。其中,威刚工控作为工业嵌入式存储领导品牌,围绕人工智能应用需求,重点展示了高性能存储解决方案,并展示了网络安全人工智能边缘计算设备、人工智能视觉控制器以及人工智能大数据分析设备的客户样机成功案例。通过展示有效解决人工智能场景中的难题和痛点的解决方案,为人工智能时代提供了新一代高性能存储技术的支持威刚展台的C位区域全面展示了各种主流规格的存储

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경