位置: 编程技术 - 正文

SQL Server自动生成日期加数字的序列号(sql server自动生成id)

编辑:rootadmin
USE MASTER GO IF EXISTS(SELECT * FROM dbo.sysdatabases WHERE name='my_test_database') DROP DATABASE [my_test_database] GO CREATE DATABASE [my_test_database] GO USE [my_test_database] GO CREATE TABLE [my_table] ([my_id] VARCHAR()) GO --存储过程开始 : CREATE PROCEDURE get_new_id @NEW_ID VARCHAR() OUTPUT AS BEGIN DECLARE @DATE DATETIME DECLARE @YYYY VARCHAR(4) DECLARE @MM VARCHAR(2) DECLARE @DD VARCHAR(2) --保存取得的当前时间 : SET @DATE = GETDATE() SET @YYYY = DATEPART(yyyy, @DATE) SET @MM = DATEPART(mm, @DATE) SET @DD = DATEPART(dd, @DATE) --位数不够的前面补0 SET @YYYY = REPLICATE('0', 4 - LEN(@YYYY)) + @YYYY SET @MM = REPLICATE('0', 2 - LEN(@MM)) + @MM SET @DD = REPLICATE('0', 2 - LEN(@DD)) + @DD --取出表中当前日期的已有的最大ID SET @NEW_ID = NULL SELECT TOP 1 @NEW_ID = [my_id] FROM [my_table] WHERE [my_id] LIKE @YYYY+@MM+@DD+'%' ORDER BY [my_id] DESC --如果未取出来 IF @NEW_ID IS NULL --说明还没有当前日期的编号,则直接从1开始编号 SET @NEW_ID = (@YYYY+@MM+@DD+'') --如果取出来了 : ELSE BEGIN DECLARE @NUM VARCHAR(8) --取出最大的编号加上1 : SET @NUM = CONVERT(VARCHAR, (CONVERT(INT, RIGHT(@NEW_ID, 8)) + 1)) --因为经过类型转换,丢失了高位的0,需要补上 SET @NUM = REPLICATE('0', 8 - LEN(@NUM)) + @NUM --最后返回日期加编号 : SET @NEW_ID = @YYYY+@MM+@DD + @NUM END END GO --执行次调用及插入数据测试 : DECLARE @N INT SET @N = 0 WHILE @N < BEGIN DECLARE @NEW_ID VARCHAR() EXECUTE get_new_id @NEW_ID OUTPUT INSERT INTO [my_table] ([my_id]) VALUES (@NEW_ID) SET @N = @N + 1 END SELECT * FROM [my_table] GO --输出结果

推荐整理分享SQL Server自动生成日期加数字的序列号(sql server自动生成id),希望有所帮助,仅作参考,欢迎阅读内容。

SQL Server自动生成日期加数字的序列号(sql server自动生成id)

文章相关热门搜索词:sql server自动生成id,sql server自动生成行号,sqlserver自动生成编号,SQL server自动生成36个id,SQL server自动生成36个id,sql server自动生成id,SQL server自动生成36个id,sql server自动生成语句,内容如对您有帮助,希望把文章链接给更多的朋友!

远程连接局域网内的SQL Server 的方法 第一个错误"SQLServer不存在或访问被拒绝"通常是最复杂的,错误发生的原因比较多,需要检查的方面也比较多。一般说来,有以下几种可能性:1、SQLServer

SQL Server 索引维护sql语句 使用以下脚本查看数据库索引碎片的大小情况:DBCCSHOWCONTIGWITHFAST,TABLERESULTS,ALL_INDEXES,NO_INFOMSGS以下使用脚本来处理维护作业:/*Performa'USEdatabasename'toselectt

从两种SQL表连接写法来了解过去 例如:一个二表连接的SQL,有两种写法:(1)selectA.c1,A.c2,B.c1,B.c2fromtable1A,table2BwhereA.id=B.id(2)selectA.c1,A.c2,B.c1,B.c2fromtable1Ajointable2BonA.id=B.id哪种写法好呢?现在提

标签: sql server自动生成id

本文链接地址:https://www.jiuchutong.com/biancheng/349427.html 转载请保留说明!

上一篇:AspNetPager分页控件 存储过程(asp 分页)

下一篇:远程连接局域网内的SQL Server 的方法(远程连接局域网内的电脑)

  • 企业所得税研发费用加计扣除条件
  • 工程监理费开什么发票
  • 汇算清缴利润调整会计分录
  • 个人转让房产两年内全额计税是什么意思
  • 一般纳税人什么情况可以开3%的发票
  • 收到赠送的商品并销售
  • 其他应收款如何清理
  • 发票进项和销项差一个字
  • 是否独立核算取决于什么
  • 建筑业预缴税款是什么意思
  • 汽车折旧年限 税法
  • 独立核算分公司注销与总公司账务
  • 哪些补贴可以不交个税
  • 卷式发票要注意什么
  • 公司往来款现金流量表
  • 工厂投产前的准备工作有哪些
  • 海关进口增值税计算公式
  • 增值税附加税怎么报税
  • 仓储费专用发票可以抵扣吗?
  • 不需要抵扣的怎么直接进费用
  • 房产税税率和应纳税额
  • 通讯费计入什么部门
  • 自己从自己公司直接拿钱是犯罪吗知乎
  • 进项税额转出期限是多久
  • 奖励费收入是什么
  • 财产转让所得个人所得税纳税地点
  • 企业所得税季报人数怎么填
  • 用人单位垫付生育津贴的凭证怎么做
  • 出差补贴怎么算
  • 去银行打印公户流水需要带什么
  • 事业单位坏账怎么处理
  • 结转本期损益要过账吗
  • 2021年8月现在还能去武汉吗
  • 认证未抵扣的发票购买方能开红字信息表吗
  • linux怎么测试端口
  • 经营性支出属于哪个科目
  • 如何设置路由器步骤要详细
  • 住房贷款利息支出专项附加抵扣
  • 提取的坏账准备使用完后如何处理
  • 克拉克湖国家公园
  • 财行〔2019〕11号代扣代缴手续费的解读
  • 低调低调
  • 瀑布流实现方式
  • php for each
  • 如何在idea上运行python
  • 流动比率取值是取期末
  • 销售返利账务处理及注意事项
  • python27文件夹
  • python中的列表和元祖有什么区别
  • 银行收到几分钱怎么做账
  • 开发日志模板
  • 销售防疫物资是什么意思
  • 外勤会计是做什么的
  • 当master down掉后,pt-heartbeat不断重试会导致内存缓慢增长的原因及解决办法
  • 事业单位净资产变动表
  • 公司给员工租的房子计入什么科目
  • 注册资本没有全额投入,公司银行贷款贷款利息怎么入账
  • 存货过期处理怎么做分录
  • 零售行业折扣销售方案
  • 暂估入库做账
  • 可抵扣的税票
  • 机票行程单可以抵扣进项税吗?
  • 配置是什么意思
  • centos 安装选择
  • 如何更改桌面文件存放位置
  • xp系统镜像文件怎么制作
  • win10预览版好吗
  • win1010586升级到最新
  • xp系统提升性能
  • 使用灭火器人要站在上风口还是下风口
  • javascript entries
  • Append、Debug、Diskcomp命令的使用说明
  • 游戏开发那些事
  • opengl transform
  • Javascript Throttle & Debounce应用介绍
  • time模块 python
  • 北京12366纳税服务平台
  • 政府主管部门对企业检查要求
  • 企业支付的年度报告审计费
  • 发票多久作废不了
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设