位置: 编程技术 - 正文

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 的方法(远程连接局域网内的电脑)

  • 增值税和城建税怎么算
  • 财务软件进什么费用
  • 增值税小规模纳税人免征增值税政策
  • 短期借款的实际资金成本
  • 非盈利组织企业所得税主表如何填列
  • 员工继续教育培训费计什么科
  • 手机超过多少钱可以报警立案
  • 人力费可以计入劳务费吗
  • 销售退回的货物应当由什么部门清点
  • 施工单位奖金分配方案
  • 小规模无票收入怎么做账
  • 子公司注销是利空吗
  • 计提社保个人部分需要计提吗
  • 高速公路的发票怎么补
  • 为什么有的公司没有一金
  • 不能抵扣的进项税怎么做账
  • 远程清卡显示清卡失败,证书已挂失怎么回事
  • 所有者权益合计是负数是什么意思
  • 支出税费
  • 事业单位工资及薪酬好的单位有哪些
  • 固定资产清理是什么项目
  • linux 判断语句
  • 购买产品优惠计入什么科目
  • 服务业结转成本与收入如何配比
  • 待抵扣进项税额和待认证进项税额的区别
  • 上市公司发行股票是好还是坏
  • php新手入门
  • php匿名函数为何不匿名
  • php判断数组是否为空的函数
  • php ffi
  • 报废车怎么上路
  • Python的aiohttp模块如何使用?
  • vue多平台
  • php 文件处理
  • 个体户利润分配会计分录怎么做
  • 劳务报酬所得与工资薪金所得纳税的区别
  • 其他货币资金是什么科目
  • 小企业会计准则和一般企业会计准则的区别
  • 汇算清缴是怎么弄的
  • 税法规定的增值税是指
  • 定期定额户要交哪些税
  • 坏账准备的核销的分录怎么做
  • 有限合伙企业收入怎么做账
  • 投资方收到股票怎么处理
  • 事业单位职工福利费
  • 进项抵扣后的附加税
  • 成品油预付卡销售*成品油卡 怎么入账
  • 管理费用如何分摊到项目
  • 公司购买手表入什么科目
  • 应收账款和应付账款属于什么科目
  • 公司开收据盖什么章
  • mysql 5.7.24安装
  • mysql 绿色版安装
  • winsock2
  • win10装老版本
  • win8怎么安装不了win10
  • centos6.8升级centos7
  • 怎么降到windows7
  • kb2859537是什么文件
  • Win10 Mobile build 10586.338安装/上手体验视频
  • win7定时开关怎么定时
  • linux整理磁盘
  • 手机屏幕尺寸测量工具
  • python生成器有几种写法
  • 从零开始学什么好
  • android 侧滑页面
  • jquery网页设计
  • 孙其功陪你学之——unity3d进程暂停
  • JQuery给select添加/删除节点的实现代码
  • android 自定义style
  • javascript define的用法
  • 交通费用包括
  • 公务员中了彩票怎么领取
  • 数字证书使用方法
  • 虚假新闻造成的真实伤害
  • 税票是什么发票
  • 地方税务局几点下班
  • 电子税务局开电子发票如何更换开票人
  • 甘肃税务政策
  • 关于啤酒包装物押金,下列正确的是( )
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设