[置顶] 存储过程 Row_number
自己之前一直是使用的通用的存储过程 ,也是封装好的只要传表名 然后 条件 等等 来到新环境 让自己写一个存储过程, 没办法 自己就需要写一个咯 之前写的比较多的是 按 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() 开窗函数
其中的一些东西也是看前一任 程序员写的, 然后就有在园子里面看看介绍。 自己摘了一部分 因为看别人的东西的时候也没有做到用怀疑的态度去看 去分析 所以贴出来 。如果你看到以后有错误 有误区 欢迎指正!!
对你的能力是一次证明, 对我是一次帮助。 虚心求学。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

本站3月7日訊息,華為資料儲存產品線總裁週躍峰博士日前出席MWC2024大會,專門展示了為溫資料(WarmData)和冷資料(ColdData)設計的新一代OceanStorArctic磁電儲存解決方案。華為資料儲存產品線總裁週躍峰發布系列創新解決方案圖來源:華為本站附上華為官方新聞稿內容如下:該方案的成本比磁帶低20%,功耗比硬碟低90%。根據國外科技媒體blocksandfiles報道,華為發言人也透露了關於該磁電儲存解決方案的資訊:華為的磁電磁碟(MED)是對磁性儲存媒體的重大創新。第一代ME

Vue3+TS+Vite開發技巧:如何進行資料加密和儲存隨著網路技術的快速發展,資料的安全性和隱私保護變得越來越重要。在Vue3+TS+Vite開發環境下,如何進行資料加密和存儲,是每個開發人員都需要面對的問題。本文將介紹一些常用的資料加密和儲存的技巧,幫助開發人員提升應用程式的安全性和使用者體驗。一、資料加密前端資料加密前端加密是保護資料安全性的重要一環。常用

什麼是緩存?快取(發音為ka·shay)是一種專門的高速硬體或軟體元件,用於儲存經常要求的資料和指令,這些資料和指令又可用於更快地載入網站、應用程式、服務和系統的其他部分。快取使最常存取的資料隨時可用。快取檔案與快取記憶體不同。快取文件是指經常需要的文件,如PNG、圖標、徽標、著色器等,多個程式可能需要這些文件。這些檔案儲存在您的實體磁碟機空間中,通常是隱藏的。另一方面,高速緩存記憶體是一種比主記憶體和/或RAM更快的記憶體類型。它極大地減少了資料存取時間,因為與RAM相比,它更靠近CPU並且速度

抖音裡面有使用者會拍攝很多的影片作品,一旦影片作品多了以後,各種優秀的影片作品就會被掩埋了,置頂功能就很有用了,那麼我們怎麼置頂自己的影片作品呢?接下來小編就為大家帶來了抖音置頂自己影片作品方法圖文教程,還不知道怎麼置頂影片的用戶快來看看吧。抖音使用教學抖音怎麼置頂自己影片1、首先我們打開抖音,點選主介面右下角如圖所示的我。 2.接著我們進入個人介面後,找到想要置頂的影片作品,點選進入播放即可。 3、然後我們在視訊介面,點擊右下角如圖所示的三個點選項。 4.最後我們點選新彈出視窗中的置頂即可,回到個人界

Git是一個快速、可靠、適應性強的分散式版本控制系統。它旨在支援分散式的非線性工作流程,使其成為各種規模的軟體開發團隊的理想選擇。每個Git工作目錄都是一個獨立的儲存庫,具有所有更改的完整歷史記錄,並且能夠追蹤版本,即使沒有網路存取或中央伺服器。 GitHub是託管在雲端的Git儲存庫,它提供了分散式修訂控制的所有功能。 GitHub是Git的儲存庫,託管在雲端。與作為CLI工具的Git不同,GitHub有一個基於Web的圖形使用者介面。它用於版本控制,這涉及與其他開發人員協作,並追蹤隨時間推移對腳本和

PHP和swoole如何實現高效率的資料快取和儲存?概述:在Web應用開發中,資料的快取和儲存是非常重要的一部分。而PHP和swoole提供了一種高效率的方法來實現資料的快取與儲存。本文將介紹如何使用PHP和swoole來實現高效的資料快取和存儲,並給出相應的程式碼範例。一、swoole簡介:swoole是一個針對PHP語言開發的,高效能的非同步網路通訊引擎,它可以

如何正確使用sessionStorage儲存敏感訊息,需要具體程式碼範例無論是在Web開發或行動應用程式開發中,我們常常需要儲存和處理敏感訊息,如使用者登入憑證、身分證號碼等。在前端開發中,使用sessionStorage是常見的儲存方案。然而,由於sessionStorage是基於瀏覽器的存儲,需要注意一些安全性的問題,以確保存儲的敏感資訊不會被惡意存取和利用

本文轉載自微信公眾號「活在資訊時代」,作者活在資訊時代。轉載本文請聯絡活在資訊時代公眾號。對於熟悉資料庫操作的同學來說,編寫優美的SQL語句,從資料庫中想辦法找出自己需要的數據,是常規操作了。而對於熟悉機器學習的同學來說,獲取數據,對數據進行預處理,建立模型,確定訓練集和測試集,用訓練好的模型對未來進行一系列的預測,也是一種常規操作了。那麼,我們能否將兩種技術結合起來呢?我們看到資料庫裡儲存了數據,而進行預測需要基於以往的數據。如果我們透過資料庫裡現有的數據,對於未來的數據進行查詢的話,那麼是
