私はしばらくの間、これを正しくしようとしてきましたが、役に立ちませんでした。
mssql データベースにテーブルがあり、ストアド プロシージャを使用して新しい行を挿入したい
CREATE TABLE "Customers" (
"CustomerID" NCHAR(5) NOT NULL,
"CompanyName" NVARCHAR(40) NOT NULL,
"ContactName" NVARCHAR(30) NULL,
"ContactTitle" NVARCHAR(30) NULL,
"Address" NVARCHAR(60) NULL,
"City" NVARCHAR(15) NULL,
"Region" NVARCHAR(15) NULL,
"PostalCode" NVARCHAR(10) NULL,
"Country" NVARCHAR(15) NULL,
"Phone" NVARCHAR(24) NULL,
"Fax" NVARCHAR(24) NULL,
PRIMARY KEY ("CustomerID")
);
問題は、各レコード (ALFKI、BERGS、BERGS など) に固有の文字列を含む CustomerID フィールドです。
新しいデータを含む行を挿入し、一意の CustomerID を作成するストアド プロシージャを作成したいと考えています。文字列の長さを 5 文字にする必要があるため、組み込み関数は問題外です。
次のように5文字のIDを生成する手順があります
begin
declare @chars char(26) = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
declare @i int = 0
declare @id varchar(max) = ''
while @i < 5
begin
set @id = @id + substring(@chars, cast(ceiling(rand() * 26) as int), 1)
set @i = @i + 1
end
Select (cast(@id as nvarchar(400)))
end
そして、私が無駄に働かせようとしたもの。一意のIDを選択することになっています( set @id = 'ANATR' は、ループに入るために意図的に存在します
begin
declare @randID varchar(5) = ''
declare @selectID varchar(20) = ''
declare @chars char(26) = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
declare @i int = 0
declare @id varchar(10) = ''
while @i < 5
begin
set @id = @id + substring(@chars, cast(ceiling(rand() * 26) as int), 1)
set @i = @i + 1
end
select @id
set @id = 'ANATR'
SET @selectID = (SELECT CustomerID FROM CUSTOMERS WHERE CustomerID = @id)
while @selectID <> 'NULL'
begin
set @id = ''
while @i < 5
begin
set @id = @id + substring(@chars, cast(ceiling(rand() * 26) as int), 1)
set @i = @i + 1
end
SET @selectID = (SELECT CustomerID FROM CUSTOMERS WHERE CustomerID = @id)
SELECT @id
end
end
これが私が現時点で持っている挿入手順です
CREATE PROCEDURE [dbo].[InsertCustomers]
(
@CustomerID nchar(5),
@CompanyName nvarchar(40),
@ContactName nvarchar(30) = NULL,
@ContactTitle nvarchar(30) = NULL,
@Address nvarchar(60) = NULL,
@City nvarchar(15) = NULL,
@Region nvarchar(15) = NULL,
@PostalCode nvarchar(10) = NULL,
@Country nvarchar(15) = NULL,
@Phone nvarchar(24) = NULL,
@Fax nvarchar(24) = NULL
)
AS
SET NOCOUNT OFF;
INSERT INTO [dbo].[Customers] ([CustomerID], [CompanyName], [ContactName], [ContactTitle], [Address], [City], [Region], [PostalCode], [Country], [Phone], [Fax]) VALUES (@CustomerID, @CompanyName, @ContactName, @ContactTitle, @Address, @City, @Region, @PostalCode, @Country, @Phone, @Fax);