oracle 中生成流水號 方法

来源:http://www.cnblogs.com/shouce/archive/2016/06/06/5562694.html
-Advertisement-
Play Games

思路: 通過一個流水號表,記錄當前最大的流水號,以便下次取用。每次取號時,將流水號表更新成大的。 涉及的表: 流水號表hp_no: 欄位 類型 TYPE_NAME VARCHAR2(100) START_NO VARCHAR2(100) CURRENT_NO VARCHAR2(100) 代碼: 1) ...


思路:

 通過一個流水號表,記錄當前最大的流水號,以便下次取用。每次取號時,將流水號表更新成大的。

涉及的表:

   流水號表hp_no:  

欄位 類型
TYPE_NAME VARCHAR2(100)
START_NO VARCHAR2(100)
CURRENT_NO VARCHAR2(100)

 

 代碼:

1)通過函數得到最大值。 有三個參數,

  第一個參數是類型,便於得到不同的流水號。

  第二個參數是首碼,用於在流水號前邊放置特別的字元。

  第三個參數是生成的流水號長度。

 

複製代碼 代碼 CREATE OR REPLACE FUNCTION Hp_Test_GetNo(
   P_TYPE_NAME   
IN   VARCHAR2 DEFAULT '',  --類型 參數1
   P_START_NO    IN   VARCHAR2,  --首碼 參數2
   P_LENGTH      IN   NUMBER    --得到流水號長度 參數3
)
   
RETURN VARCHAR2      --返回類型
IS
   V_RESULT       
VARCHAR2 (100) := '';   --結果   變數1
   V_CURRENT_NO   VARCHAR2 (100) := '';  --當前值  變數2
   V_NUM          NUMBER         := 0;  --補值    變數3
   V_START_NO   VARCHAR2(100);    --首碼    變數4
   V_ROWID        VARCHAR2 (100);    --要更新行的RowID  變數4
BEGIN
   V_START_NO :
=P_START_NO;  --參數值賦給變數

   
SELECT COUNT (*)
     
INTO V_NUM
     
FROM HP_NO
    
WHERE TYPE_NAME = P_TYPE_NAME AND START_NO = P_START_NO;    --得到類型與首碼相同值的數量,主要用於判斷是否產生過流水號

--判斷是否有資料 沒有則產生初始值插入庫中
   IF V_NUM = 0  --沒有記錄過時
   THEN
      V_CURRENT_NO :
= LPAD ('1', P_LENGTH, '0');  --得到P_length長的0001流水號
      V_RESULT := V_CURRENT_NO;  --將首碼與流水號相連起來

      
INSERT INTO HP_NO(TYPE_NAME, START_NO, CURRENT_NO)
           
VALUES (P_TYPE_NAME, P_START_NO, V_CURRENT_NO);  --將新的最大值記錄下來
   ELSE  
      
SELECT ROWID, CURRENT_NO + 1
      
INTO V_ROWID, V_CURRENT_NO
        
FROM HP_NO
       
WHERE TYPE_NAME = P_TYPE_NAME AND START_NO = P_START_NO; --得到最大值加1

      V_CURRENT_NO :
= LPAD (V_CURRENT_NO, P_LENGTH, '0');     
      
      
      
UPDATE HP_NO
         
SET CURRENT_NO = V_CURRENT_NO
       
WHERE ROWID = V_ROWID;    --更新最大值
   END IF;  

   
IF V_START_NO IS NULL OR V_START_NO='' THEN
      V_RESULT :
= V_CURRENT_NO;
   
ELSE
      V_RESULT :
=V_START_NO || V_CURRENT_NO;
   
END IF;
   
   
RETURN V_RESULT;
END;
複製代碼

 

使用存儲過程調用函數的方法:

複製代碼 代碼 --調用function存儲過程
CREATE OR REPLACE PROCEDURE Hp_Pro_GetTestNo
(
      v_FirstLetter 
in varchar2,
      v_Result out  
varchar2
)
   
IS
      v_FirstValue 
varchar2(30);
      v_SystDate 
varchar2(30);
BEGIN
     
select to_char(sysdate,'yyyymm'into v_SystDate from dual;
     v_FirstValue:
=(v_FirstLetter || v_SystDate);
     v_Result:
=hp_test_getno('HpTest' ,v_FirstValue,4);
END;
複製代碼

 

結果:

   調用存儲過程Hp_Pro_GetTestNo('hp',4);

  結果為:hp2016060001

 

其它思考

一、新增時無須顯示流水號,如得到得到連續流水號

 方法:

  採用流水號子表,此表用於保存沒有用過的流水號。當用戶取號時,首選判斷子表是否含有流水號,當有時,取出一個,並刪除此個(防止別另外用戶取用);否則調用主表得到新流水號。

當插入失敗則將當前流水號保存到流水號子表中,供下次取用。

當刪除時,將當前流水號保存到流水號子表中,供下次取用。

 

二、新增時須顯示流水號,如得到得到連續流水號

方法:

  採用流水號子表,此表用於保存沒有用過的流水號。當用戶取號時,首選判斷子表是否含有流水號,當有時,取出一個,並刪除此個(防止別另外用戶取用);否則調用 主表得到新流水號。

當用戶不保存或插入失敗則將當前流水號保存到流水號子表中,供下次取用。

當刪除時,將當前流水號保存到流水號子表中,供 下次取用。

 

其它思考的代碼我沒有寫,有興趣的朋友可以自己寫。

 

 

 


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

-Advertisement-
Play Games
更多相關文章
  • android系統架構 1.Linux內核層(LINUX KERNEL) 這是系統架構的最低層,這層為android設備的硬體提供了驅動 2.系統運行庫層(LIBRARIES) 這一層為倒數第二層,利用一些c/c++庫來為android系統提供一些主要的特性支持,比如說SQLite庫提供了對資料庫的 ...
  • 最近把四大組件,網路編程,以及一些常用的控制項都學完了,不過感覺還不是特別牢固,所以決定再花一點時間重新過一遍,你們有這樣的感覺嗎? ...
  • 前言: 受颱風影響今天學校不上課,在家閑的蛋疼沒事做,使用Mac系統一段時間了發現它和Windows系統的操作風格還是有很大不同的,遂決定將Mac系統與Xcode的一些常用操作收集整理一下,方便自己日後查找使用。 一、Mac系統(OS X 10.10以上版本)操作篇 1)F11 開啟多個程式時可快速 ...
  • 程式執行需要讀取到安全敏感項必需在androidmanifest.xml中聲明相關許可權請求, 完整列表如下:android.permission.ACCESS_CHECKIN_PROPERTIES允許讀寫訪問”properties”表在 checkin資料庫中,改值可以修改上傳( Allows re ...
  • OC 類簇與複合 類簇: 類簇是Foundation框架中廣泛使用的設計模式。類簇將一些私有的、具體的子類組合在一個公共的、抽象的超類下麵,以這種方法來組織類可以簡化一個面向對象框架的公開架構,而又不減少功能的豐富性。 簡單的來說,NSString是個“工廠類”,然後它在外層提供了很多方法介面,但是 ...
  • 當用戶需要訪問資料庫時,在客戶端要建立一個用戶進程-在伺服器端,需要為用戶進程分配一個伺服器進程,兩個進程之間建立連接,伺服器進程處理用戶進程的請求。客戶端應用程式可以是SQL*Plus 、EM 、RMAN ,或者用戶自己,開發的Java應用程式。用戶進程必須通過伺服器進程才能訪問資料庫實例。伺服器 ...
  • 1. 首先,當然是下載 MongoDBMongoDB的官方網站是:http://www.mongodb.org/,最新版本下載在:http://www.mongodb.org/downloads 。請註意下載適合自己系統的安裝包,我選擇的是:Windows 64-bit 2008 R2+。下載後的文 ...
  • mysqldump -hhostname -uusername -ppassword databasename > backupfile.sql備份MySQL資料庫為帶刪除表的格式備份MySQL資料庫為帶刪除表的格式,能夠讓該備份覆蓋已有資料庫而不需要手動刪除原有資料庫。 mysqldump -–a ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...