SQL处理数据并发,解决ID自增
1 创建MaxIdProcess表,由于存储ID的最大值
CREATE TABLE [dbo].[MaxIdProcess](
[Id] [bigint] IDENTITY(1,1) NOT NULL, --自增ID
[TableNM] [nvarchar](200) NOT NULL, --存储表明
[Prefix] [nvarchar](50) NULL, --ID前缀
[Radix] [char](2) NULL, --
[MaxId] [nvarchar](50) NULL, --存储最大ID
[CreateDatetime] [datetime] NULL, --创建时间
[LastModifyDatetime] [datetime] NULL,
[LastModifyBy] [nvarchar](50) NULL,
CONSTRAINT [PK_MaxIdProcess] PRIMARY KEY CLUSTERED
(
[Id] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
2、创建存储过程 Pro_GetTableNextMaxIdByTableName 获取最大ID
CREATE procedure [dbo].[Pro_GetTableNextMaxIdByTableName]
@TableName char(50), --table名称
@Prefix char(3), --ID前缀
@NextId char(16) out --ID输出
AS begin
--if not exists (select * from MaxIdProcess where TableName=@TableName)
--begin
-- insert into MaxIdProcess values(@TableName,null)
--end
-- update MaxIdProcess
-- set @NextId= isnull(MaxId, @Prefix + '0000000000001'),
-- MaxId = dbo.Fun_GetMaxId(MaxId,@Prefix)
-- where TableName=@TableName --检查系统表中是否存在该表,如果不存在则调用Pro_GetRandomStr存储过程获取一个随机ID
IF EXISTS (SELECT object_id FROM sys.objects(nolock) WHERE type='U' AND name=@TableName)
BEGIN
EXEC Pro_GetRandomStr @NextId output
RETURN
END --检查MaxIdProcess表中是否存有需要获取ID的表名,如果不存在则插入数据
if not exists (select * from MaxIdProcess where TableNM=rtrim(@TableName))
begin
insert into MaxIdProcess values(@TableName,@Prefix,'',0,getdate(),getdate(),'Auto')
end declare @temp bigint
update MaxIdProcess
set @temp=cast(rtrim(MaxId) as bigint),MaxId=MaxId+1
where rtrim(TableNM)=rtrim(@TableName)
set @NextId=@Prefix+right(cast(1000000000000000+@temp as nvarchar(16)),13)
end
3、创建执行存储过程,如插入新增用户
CREATE PROCEDURE [dbo].[Pro_User_Insert]
@UserId CHAR(16) OUT ,
@UserNM NVARCHAR(50) ,
@Description NVARCHAR(255)
AS BEGIN TRY
BEGIN
DECLARE @Name NVARCHAR(50);
SELECT @UserId = UsersTb.UserId ,
@Name = UsersTb.Description
FROM dbo.UsersTb
WHERE UsersTb.UserNM = @UserNM;
IF NOT ISNULL(@UserId, '') = ''
BEGIN
SELECT @UserNM + @Name + '已经存在';
--SELECT '用户已经存在';
RETURN;
END;
DECLARE @MaxId CHAR(16);
EXEC dbo.GetTableNextMaxIdByTableName 'User', 'Usr', @MaxId OUT;
SET @UserId = @MaxId; INSERT INTO UsersTb
(
[UserId] ,
[UserNM] ,
[Description]
)
VALUES
(
@UserId ,
@UserNM,
@Description
);
SELECT '执行成功';
END
END TRY
BEGIN CATCH
SELECT ERROR_MESSAGE();
END CATCH
4、执行新增用户存储过程
DECLARE @UserId int;
EXEC Pro_User_Insert @UserId output,'zhangsan','张三' ;
5、完成
关于 Pro_GetRandomStr 存储过程
CREATE Procedure [dbo].[Pro_GetRandomStr]
@RandomStr varchar(16) output
as
BEGIN
set nocount on declare @s varchar(61)
declare @r varchar(16)
declare @pos int
declare @len int
set @s = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ012345678'
set @len = len(@s);
set @r = ''
while len(@r) < 16
begin
set @pos = cast(rand()*61 as int);
--while @pos > @len or @pos <1
--begin
-- if(@pos < 1)
-- set @pos = cast(rand()*61 as int);
-- else
-- set @pos = cast(@pos /2 as int);
--end
set @r = @r + substring(@s, @pos, 1)
--select @r
end
set @RandomStr = upper(@r)
END
c# 实现存储过程
string strcon = "Data Source=(local)\\SQLEXPRESS; Initial Catalog=TestDatabase; ";
strcon += "Integrated Security=True;";
using (SqlConnection con = new SqlConnection(strcon))
{
con.Open();
SqlParameter[] parameters =
{
new SqlParameter("@UserId", SqlDbType.Char,),
new SqlParameter("@UserNM", SqlDbType.NVarChar),
new SqlParameter("@Description", SqlDbType.NVarChar),
}; //parameters[0].Value = null;
parameters[].Direction = ParameterDirection.Output;
parameters[].Value = "zhangsan";
parameters[].Value = "张三"; SqlCommand cmd = new SqlCommand();
cmd.CommandType = CommandType.StoredProcedure;
cmd.CommandText = "Pro_User_Insert";
cmd.Connection = con;
cmd.Parameters.AddRange(parameters);
object obj = cmd.ExecuteScalar();
//string msg = cmd.ExecuteScalar().ToString();
con.Close(); }
SQL处理数据并发,解决ID自增的更多相关文章
- sql Server插不进数据,以及Id自增的教程及注意事项
参考于:https://jingyan.baidu.com/article/fec4bce244f902f2608d8b7a.html 使用SQL Server 2014 数据库做web的项目出现错误 ...
- sql 删除表数据并使ID自增重置
方法1:truncate table 你的表名//这样不但将数据全部删除,而且重新定位自增的字段 方法2:delete from 你的表名dbcc checkident(你的表名,reseed,0) ...
- 2016.6.11 ASP提交数据到SQL server数据乱码解决方法
1.检查数据库排序规则 China-PRE-90-CS-AI 2.ASP文档中,写入数据的页面的编码和检查提交数据页面的编码一致:
- oracle 新增一条数据时设置id自增
CREATE SEQUENCE test_seq --创建一个test_seq序列INCREMENT BY 1 --每次加1START WITH 1 --从1开始NOMAXVALUE ...
- mysql实现id自增
用下面这句话就可以实现插入mysql数据时候实现id自增 create table shuju (id int(10) auto_increment primary key,name varchar( ...
- 解决在mysql表中删除自增id数据后,再添加数据时,id不会自增1的问题
https://blog.csdn.net/shaojunbo24/article/details/50036859 问题:mysql表中删除自增id数据后,再添加数据时,id不会紧接.比如:自增id ...
- SQL Server中Id自增列的最大Id是多少
什么是自增列 在SQL Server中可以将Id列设为自增.即无需为Id指定值,由SQL Server自动给该列赋值,每新增一列Id的值加一,初始值为1. 需要注意的是即使将原先添加的所有数据都删除, ...
- [SQL]SQL Server数据表的基础知识与增查删改
SQL Server数据表的基础知识与增查删改 由张晨辉(学生) 于19天 前发表 | 阅读94次 一.常用数据类型 .整型:bigint.int.smallint.tinyint .小数:decim ...
- SQL反模式学习笔记18 减少SQL查询数据,避免使用一条SQL语句解决复杂问题
目标:减少SQL查询数据,避免使用一条SQL语句解决复杂问题 反模式:视图使用一步操作,单个SQL语句解决复杂问题 使用一个查询来获得所有结果的最常见后果就是产生了一个笛卡尔积.导致查询性能降低. 如 ...
随机推荐
- Selenium原理初步--Android自动化测试学习历程
章节:自动化基础篇——Selenium原理初步(第五讲) 注:其实所有的东西都是应该先去用,但是工具基本都一样,底层都是用的最基础的内容实现的,测试应该做的是: (1)熟练使用工具,了解各个工具的利弊 ...
- tomcat启动时端口占用的问题怎么解决
PS:web项目在启动的时候,一般会报Address already in use: bind,常规的处理思路为:删除任务管理器中的javaw.exe进程即可:当删除仍然解决不了时,一般处理思路如下, ...
- go实现的简易TCP的客户端和服务器
今天介绍golang版本的通信基础:基于TCP的客户端和服务器实现,参考书籍:The Way To Go 那时学习java的时候也是做过通信的,当时是socket编程,服务器监听某一个端口,然后客户机 ...
- 强制另存文件和加扩展名的代码c#
强制另存为文件+扩展名的代码using System;using System.Collections.Generic;using System.Linq;using System.Web; name ...
- a标签的四个伪类
A标签的css样式 CSS为一些特殊效果准备了特定的工具,我们称之为“伪类”.其中有几项是我们经常用到的,下面我们就详细介绍一下经常用于定义链接样式的四个伪类,它们分别是: :link :v ...
- 1000多块整个插板,arduino + android 蓝牙插板的实现--屌丝版
需求描述 儿子有一堆充电玩具,基本上都是锂电池,经常插上去充电忘了到时拔下来,所以需要一块能设置接通时间的插板以保障电池的安全. 硬件设计: 首先需要一块插板,接着需要一个继电器,然后采用a ...
- Netty学习第三节Netty的入门级学习
1.原生NIO存在哪些缺陷 (1)NIO的类库和API繁杂,使用也比较麻烦,需要熟练掌握selector.ServerSocketChannel.SocketChannel.ByteBuffe ...
- qmake -简介
qmake 简化了在不同平台下开发项目时构建处理的过程. qmake 自动产生Makefiles文件,只需要几行信息来构建每个Makefile.qmake可以被用于任何软件项目,不管是否使用Qt. q ...
- QDesktopWidget
在Qt中提供了QDesktopWidget类,提供屏幕的有关信息. 可以这么作: QDesktopWidget *d=QApplication::desktop(); int width=d-> ...
- 大文件webuploader的基本使用
webuploader的简单使用 需要的文件 自备 百度很多 webuploader.js uploader.swf jQuery <!DOCTYPE html> <htm ...