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

来源: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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...