SQLServer2005 を使用し、ストアドプロシージャを作成しています。
select ~ into ~ で一時テーブルを作成、データ挿入するのですが、
この命令で作成された一時テーブルにプライマリキーを作成したいと
考えております。
目的は、挿入される件数が多くなりそうなので、
検索を速くする為です。
プライマリキーを作成するのは、
ALTER TABLE ~ CONSTRAINT PK_xxx PRIMARY KEY CLUSTERED ( ~ )
で作成できる事は、理解しております。
これらの処理をストアドプロシージャで行いたいのですが、
注意点としては、当ストアドプロシージャが
並行して実行される事を考慮しておかなくてはなりません。
以下のようなサンプルを作成し、テストしてみたのですが、
セション1でストアドプロシージャ実行後、
セション2でストアドプロシージャを実行してみたのですが、
以下のエラーメッセージが表示されてしまいます。
ここで質問ですが、
制約名をどのようにすれば実現できるのでしょうか。
たとえば、制約名を省略すれば、システム内で一意な名称を
命名してくれるような書き方はないのでしょうか。
ご存じの方、ご回答宜しくお願いします。
-- サンプルストアドプロシージャ
create procedure proc_test as
select getdate() AS sysdate into #worktable
alter table #worktable with nocheck add
constraint pk_xxx primary key clustered ([sysdate])
waitfor time '23:59' -- テストの為待機
-- セション1ストアドプロシージャ実行
exec proc_test
-- セション2ストアドプロシージャ実行
exec proc_test
-- セション2の実行結果
(1 行処理されました)
メッセージ 2714、レベル 16、状態 4、プロシージャ proc_test、行 6
データベースに 'pk_xxx' という名前のオブジェクトが既に存在します。
メッセージ 1750、レベル 16、状態 0、プロシージャ proc_test、行 6
制約を作成できませんでした。以前のエラーを調べてください。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL PHPとMySQLを使った掲示板の作り方 1 2022/06/02 13:00
- MySQL MySQLのテーブル作成で 自信がありません。 2 2022/08/28 05:35
- その他(IT・Webサービス) EXCELVBAでシートを他のブックにコピーする命令を出すと毎回存在しないシート名の問合わせがある 1 2022/05/07 15:12
- Excel(エクセル) EXCELVBAでシートを他のブックにコピーする命令を出すと毎回存在しないシート名の問合わせがある 2 2022/05/07 17:16
- Ruby pandasでsqlite3にテーブル作成・追加・読み出しでindexの取り扱い方教えてください 5 2023/03/08 09:57
- Excel(エクセル) 【マクロ】エラーが発生⇒実行時エラー58既に同名のファイルが存在 5 2022/08/31 10:03
- Access(アクセス) Accessテーブルの結合で別々のテーブルのフィールドを組み合わせて値を出す方法について 2 2022/07/20 19:43
- その他(データベース) pythonでsqlight勉強中、クエリー結果の利用法教えて下さい 1 2022/04/28 20:38
- PHP ここでの ②if($su_d<>"")の比較演算子 を使う理由は 1 2022/03/26 02:33
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/07/21 09:42
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教える店舗&オフィスのセキュリティ対策術
中・小規模の店舗やオフィスのセキュリティセキュリティ対策について、プロにどう対策すべきか 何を注意すべきかを教えていただきました!
-
PRIMARY KEYのコピー
MySQL
-
【Transact-sql】 where条件、inのパタメータを変数に持たせる方法
SQL Server
-
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
-
4
テーブル(構造)のコピー
SQL Server
-
5
SQL 複数テーブルのupdate
Oracle
-
6
データベースのINT型項目にNULLはNG?
MySQL
-
7
処理件数を非表示にしたい
SQL Server
-
8
VB.NETで DataRow()を利用して、値からコードを取得したい。
Visual Basic(VBA)
-
9
csv出力について
Java
-
10
主キーにインデックスは貼らないと駄目でしょうか?
SQL Server
-
11
配列で格納したものをmsgboxで表示する方法について
Access(アクセス)
-
12
特定条件でWHERE句の条件を変更したい
SQL Server
-
13
検索結果の列数を動的に変更したい
SQL Server
-
14
JavaScriptで、コピーボタンを配置し、その行のテキストデータを取得したいのです。
JavaScript
-
15
別ブックをダイアログボックスで指定してそこにあるシートをコピーしたい
Excel(エクセル)
-
16
sqlserverで集計結果をUPDATEしたいです
SQL Server
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ACCESS2007 フォーム 「バリア...
-
Access VBA [リモートサーバー...
-
ACCESSのODBCリンクテーブルに...
-
Accessでクエリを完了できませ...
-
AccessのテーブルをSQL Server...
-
Win XP で SQlServer Enterpris...
-
accessでSQL実行時のテーブル名...
-
SQL Serverのテーブルってどう...
-
Oracleデータベーストリガーの...
-
pgAdmin IIIでDELETEするために...
-
Access Update文の副問い合わせ
-
実行時エラー3086 削除クエリ...
-
PhpMyAdminで作成して実行せよ...
-
Select ~ into ~ で作成した...
-
「マスタ」と「テーブル」の違...
-
2つのテーブルから条件に一致...
-
SELECT時の行ロックの必要性に...
-
accessテーブル作成クエリを実...
-
データの二重表示の原因
-
重複するキーから一番古い年月...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Access VBA [リモートサーバー...
-
ACCESS2007 フォーム 「バリア...
-
Accessでクエリを完了できませ...
-
実行時エラー3086 削除クエリ...
-
大きなテーブルに対する問い合...
-
ユニオンクエリで繋げられるテ...
-
VBAの実行時エラー'2522'について
-
Select ~ into ~ で作成した...
-
ACCESSのODBCリンクテーブルに...
-
SQL Serverのテーブルってどう...
-
SQL SERFVER で外部キーのエラ...
-
accessでSQL実行時のテーブル名...
-
AccessのテーブルをSQL Server...
-
Access Update文の副問い合わせ
-
Oracleデータベーストリガーの...
-
ACCESSにてテーブルをEXCEL形式...
-
PhpMyAdminで作成して実行せよ...
-
TRY CATCHでシステムエラーを検...
-
SSIS 変数の値をSQL実行タスク...
-
Access VBA 読み取り専用かチェ...
おすすめ情報