記錄一下自己的游標小腳本

来源:http://www.cnblogs.com/xiaopotian/archive/2017/05/08/6825507.html
-Advertisement-
Play Games

---游標迴圈遍歷-- begin declare @id int,@temp int,@error int set @error=0 begin tran --申明事務 --業務-- update SmartPromoter set CustomerID=a.ID from SmartCustom... ...


---游標迴圈遍歷--
begin
  declare @id int,@temp int,@error int
  set @error=0
  begin tran --申明事務
  --業務--
  update SmartPromoter set CustomerID=a.ID from SmartCustomer a,SmartPromoter b 
     where (a.Mobile=b.Mobile or a.MobileBackup=b.Mobile) and b.CustomerID is null and len(b.Mobile)=11

  declare promoter_cursor cursor for(select ID from SmartPromoter where CustomerID is null and len(Mobile)=11) --申明游標
   --打開游標--
  open promoter_cursor 
  --開始迴圈游標變數--
  fetch next from promoter_cursor into @temp
  while @@FETCH_STATUS=0 --返回被 FETCH語句執行的最後游標的狀態--
    begin
      insert into SmartCustomer([Name],[Gender],[Mobile],[WeChat],[CreateTime],[ChannelID],[Remark],[CreateUserID],[Deposit],[Coupon],[Point],[CurrentExploitUserID],[CurrentManagerUserID],
      [VisitTimes],[ConsultTimes],[IsBlacklist],[IsGreylist],[HasComplain],[HasAppointment],[WechatBindTime],[MemberCategoryID],[CashCardTotalAmount]) 
      select Name,2,Mobile,Wechat,CreateTime,126,Remark,1,0,0,0,2,2,0,0,0,0,0,0,CreateTime,1,0 from SmartPromoter a where ID=@temp select @id = @@IDENTITY
      set @error= @error + @@ERROR --記錄每次運行sql後是否正確,0正確
      update SmartPromoter set CustomerID=@id where ID=@temp
      set @error= @error + @@ERROR --記錄每次運行sql後是否正確,0正確
        fetch next from promoter_cursor into @temp --轉到下一個游標
    end
  --業務--
  insert into SmartPromoter([Name],[Mobile],[Address],[Status],[Account],[Password],[CreateTime],[Wechat],[CustomerID],[Balance])
    select a.Name,a.Mobile,a.Address,1,a.Mobile,'123456',a.CreateTime,a.WeChat,a.ID,0 from SmartCustomer a where  not exists (select ID from SmartPromoter b where a.ID=b.CustomerID) and LEN(Mobile)=11
   if @error=0
      begin
        commit tran   --提交事務
      end
      else
      begin
        rollback tran --回滾事務
      end
  close promoter_cursor  --關閉游標
  deallocate promoter_cursor   --釋放游標
end

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • URL Schemes URL Schemes是蘋果給出的用來跳轉到系統應用或者跳轉到別人的應用的一種機制。同時還可以在應用之間傳數據。 設置一個URL Schemes:選中App工程->Info->URL Types里添加,可以添加多個。 在Info.plist里是這樣的: 打開App的代碼是這樣 ...
  • iOS 使用 UIMenuController 且不隱藏鍵盤的方法 在鍵盤顯示的時候使用 UIMenuController 彈出菜單,保持鍵盤顯示且可輸入的狀態。 實現方法有 1. 修改響應鏈(推薦) 2. 遵循 UIKeyInput 協議 3. 自定義 Menu controller 前兩種方法的 ...
  • 前言 當前 React Native 雖說版本更新比較快,各種組件也提供的很全面了,但是在某些情況下,混合開發的方式才會快速縮短開發周期,原因無非就是原生平臺的“底蘊”無疑更深,擁有眾多且類型豐富的第三方支持庫。很多情況下,運用這些庫可以避免苦逼的重覆勞動。接下來我們以 "jpush react n ...
  •   協議就是一組介面的集合, 遵守一個協議之後就擁有的該協議中所有方法的聲明 。NSObject這個類遵守了NSObject協議,並且實現了NSObject協議里的所有方法,所以NSObject類及其子類都可以調用這些方法。本文主要介紹NSObject協議里的方法。 (1) &e ...
  • 最近在管理一個伺服器,是Windows Server 2012版本的,本來想連接一下資料庫,發現被設置了密碼,而之前的管理人員已經跑路了,沒有辦法只有修改密碼了。以下是修改過程,記錄一下。 1. 首先查看MySQL資料庫服務是否啟動,這個直接在伺服器管理器的“服務”裡面就可以查到。如果啟動,先關閉該 ...
  • 背景 實施開發的同事找到我,反饋說項目中使用Azure sql database 之後,無法使用Profiler來監控自己開發的存儲過程的參數傳參情況。確實profiler這些實例級別的工具在Azure sql database下是不支持的,那我們有沒有辦法,變相實現監控參數情況,特寫一篇博客記錄一 ...
  • 調試的時候,使用的是 LocalDB,SqlConnection 的連接字元串很簡單 Data Source=(localdb)\ProjectsV12;Initial Catalog=master;Integrated Security=True;Connect Timeout=30;Encryp ...
  • 什麼是索引: SQL索引有兩種,聚集索引和非聚集索引,索引主要目的是提高了SQL Server系統的性能,加快數據的查詢速度與減少系統的響應時間。 聚集索引:該索引中鍵值的邏輯順序決定了表中相應行的物理順序。 非聚聚索引:該索引中索引的邏輯順序與磁碟上行的物理存儲順序不同。 下麵舉兩個簡單的例子: ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...