zoukankan      html  css  js  c++  java
  • 【网络收集】存储过程中自动生成主键

    -主键用随机数难以保证唯一,在生成主键上要多做校验工作
    
    --处理示例
    
    --创建一个视图,生成编号
    create view v_getNo
    as
    select No=convert(char(6),getdate(),12)
    +replace(convert(varchar(12),getdate(),14),':','')
    +right(newid(),6)
    go
    
    --创建一个函数,目的是得到不重复的一个编号
    create function f_No() returns char(21)
    as
    begin
    declare @re char(21)
    select @re=No from v_getNo
    while exists(select * from tb where bh=@re)
    select @re=No from v_getNo
    return(@re)
    end
    go
    
    --创建表,使用这具函数
    create table tb(bh char(21) primary key default dbo.f_no(),name varchar(10))
    insert tb(name) values('张三')
    insert tb(name) values('李三')
    select * from tb
    go
    
    使用时 注意修改 表名 列名。
    
    ----------------------------------
    
    
    
    
    在学习中遇到这个问题 
    数据库里有编号字段 
    BH00001 
    BH00002 
    BH00003 
    BH00004 
    如何实现自动增长
      
       
      
    --下面的代码生成长度为8的编号,编号以BH开头,其余6位为流水号。
    --得到新编号的函数
    CREATE FUNCTION f_NextBH()
    RETURNS char(8)
    AS
    BEGIN
        RETURN(SELECT 'BH'+RIGHT(1000001+ISNULL(RIGHT(MAX(BH),6),0),6) FROM tb WITH(XLOCK,PAGLOCK))
    END
    GO
      
    --在表中应用函数
    CREATE TABLE tb(
    BH char(8) PRIMARY KEY DEFAULT dbo.f_NextBH(),
    col int)
      
    --插入资料
    BEGIN TRAN
        INSERT tb(col) VALUES(1)
        INSERT tb(col) VALUES(2)
        INSERT tb(col) VALUES(3)
        DELETE tb WHERE col=3
        INSERT tb(col) VALUES(4)
        INSERT tb(BH,col) VALUES(dbo.f_NextBH(),14)
    COMMIT TRAN
      
    --显示结果
    SELECT * FROM tb
    /*--结果
    BH         col 
    ---------------- ----------- 
    BH000001  1
    BH000002  2
    BH000003  4
    BH000004  14
    --*/
      
       
      
    create table tb
    (id int identity,
    name varchar(10),
    code as 'BH'+right('0000'+cast(id as varchar),5))
    go
    insert tb(name) select 'A'
    union all select 'B'
    union all select 'C'
    union all select 'D'
      
    select * from tb
      
    drop table tb
      
    /*
    id          name       code         
    ----------- ---------- ------------ 
    1           A          BH00001
    2           B          BH00002
    3           C          BH00003
    4           D          BH00004
      
    (所影响的行数为 4 行)
  • 相关阅读:
    face-morpher过程函数分析
    python,在路径中引用变量的方法
    【django学习】request.POST与request.POST.get两者主要区别
    微信小程序wx.uploadFile的两个坑
    python PIL/cv2/base64相互转换
    OpenCV-Python cv2.imdecode()和cv2.imencode() 图片解码和编码
    cv2.imread()
    详解Ubuntu Server下启动/停止/重启MySQL数据库的三种方式(ubuntu 16.04)
    python使用post请求发送图片并接受图片
    前端 img标签显示 base64格式的 图片
  • 原文地址:https://www.cnblogs.com/xiaozizi/p/5816821.html
Copyright © 2011-2022 走看看