位置: 编程技术 - 正文

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

  • 代缴税费
  • 普通发票作废要收回吗
  • 为什么增值税不计入营业税金及附加
  • 什么是代扣代缴申报
  • 股东权益合计在报表哪里看
  • 公司购买汽车的购置税怎么做账
  • 政府发放的人才补贴,企业可以增加条款要求离职返还吗
  • 发票抬头写错了还能改吗
  • 公司可以为非本人开户吗
  • 房地产会计预收账款明细科目
  • 房地产企业融资存在的问题
  • 非货币性资产交换补价大于25%的会计处理
  • 维护费开的普票能全额抵扣吗?
  • 工资一年发一次合法吗
  • 公司交一部分社保个人还要交多少钱
  • 扶贫贷款主要指
  • 评标费由谁支付
  • 4s店上牌费用怎么给
  • 出售股权收入会计分录
  • 公司会议案例
  • win10怎么用wifi上网
  • 控股子公司收购母公司
  • php中数组的常用函数及用法
  • 独生子女父母有意外险吗
  • linux chcon命令
  • 远期结汇账务处理办法
  • php-cgi
  • Windows操作系统出现内存错误解决方法
  • 数据处理教程
  • 非货币性资产对外投资企业所得税例题
  • 差额征税账务处理规定
  • 按税收的计税依据为标准税收分为
  • auto learn
  • 企业非流动资产占比多说明什么
  • vuecli非根目录打包
  • php定义字符串的三种方式
  • CNN卷积神经网络/手写数字识别[VHDL][MATLAB]带源码
  • 小规模免增值税政策从什么时候开始
  • 数据库my sql
  • 暂估入账的原材料有成本差异吗
  • 用于职工福利的固定资产折旧
  • mysql操作步骤
  • 为什么开票需要提供开户许可证
  • 税务局核定税种需要多久
  • 装载机如何计提折旧费用
  • 国有资产保值增值率
  • 销售费用工资是什么科目
  • 补发工资如何计税计算
  • 红冲调整什么意思
  • 固定资产的进项税额可以一次性抵扣吗
  • 一般纳税人增值税申报操作流程
  • 缴纳社保需要办理什么手续
  • 记账凭证负数怎么填写样板
  • 累计折旧用什么账页格式
  • 预收账款为什么不是货币性项目
  • sql server复制表数据
  • mac mysql初始密码
  • sqlserver 索引
  • sqlserver性能优化5种方式
  • mysql local-infile
  • centos docker安装部署
  • uefimbr安装win7
  • win10正版系统禁止设置密码
  • xp系统怎么删除应用程序
  • WIN10系统CPU占用率高
  • msmpeng.exe是什么进程
  • win8怎么恢复出厂设置找不到恢复环境
  • shell脚本while true循环
  • cocos2d开发的知名游戏
  • javascript字体属性
  • 使用多进程web
  • unity 3d代码
  • Python实现以时间换空间的缓存替换算法
  • python str()怎么用
  • javascript零基础
  • jquery网页设计作业
  • 一种新的运算符号类型的题
  • 小规模纳税人一年500万一年怎么算
  • 2021年福建省灵活就业人员养老保险缴费标准
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设