質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

91.01%

  • Oracle

    518questions

    Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。

オラクルのシーケンスを1から挿入したい。

解決済

回答 5

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 309

tkshp

score 31

前提・実現したいこと

Oracleでシーケンスを1から挿入するにはどうしたらよいのでしょうか?
また、シーケンスとは、通常、1つのテーブルに対して、それ専用のシーケンスを1個作るのが基本なのでしょうか?

試したこと

CREATE TABLE SEARCH_KEYWORD (
    ID    NUMBER    NOT NULL,
    KEYWORD VARCHAR2(120)    NOT NULL,
    DT    DATE DEFAULT SYSDATE,
    PRIMARY KEY(ID)
)
CREATE SEQUENCE search_key_seq
START WITH 1
INCREMENT BY 1
NOMAXVALUE;

ここで、下記を実行するとシーケンスが2から挿入されます。

INSERT INTO SEARCH_KEYWORD (ID, KEYWORD) VALUES(search_key_seq.nextval, 'キーワード'); 


しかし、最初だけ調整のためにシーケンス1で下記を実行すると、次に上記を実行した際に、
「一意制約に反しています」というエラーが出てしまいます。

INSERT INTO SEARCH_KEYWORD (ID, KEYWORD) VALUES(1, 'キーワード'); 

また、下記で実行すると、次のようなエラーが出ます。

CREATE SEQUENCE search_key_seq
START WITH 0
INCREMENT BY 1
NOMAXVALUE;
START WITHMINVALUEより小さい値は指定できません。

補足情報(言語/FW/ツール等のバージョンなど)

Oracle

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 5

checkベストアンサー

0

ついでですが、12c ですとこんなのもありますけどね。

SQL> create table search_keyword_12c (
  2  id number generated as identity not null,
  3  keyword varchar2(120) not null,
  4  dt date default sysdate,
  5  primary key(id)
  6  );

Table created.

SQL> insert into search_keyword_12c (keyword)
  2  values ('abcdef');

1 row created.

SQL> commit;

Commit complete.

SQL> select * from search_keyword_12c;

        ID
----------
KEYWORD
--------------------------------------------------------------------------------
DT
---------
         1
abcdef
16-OCT-17


SQL>

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/10/16 14:11

    ご回答ありがとうございます。
    シーケンスの使い方についてですが、通常、1つのテーブルに対して、それ専用のシーケンスを1個作るのが基本なのでしょうか?
    シーケンスを使うテーブルごとに、個別にシーケンスを作っていくのが一般的でしょうか?

    キャンセル

  • 2017/10/16 14:14

    毎回テーブルごとに明示的に作らなくてもよくなったというのがここで示した例なのですが。。

    11g 以前では必要な分だけ作るというのが普通だったと思います。

    キャンセル

  • 2017/10/16 15:04

    ご回答ありがとうございます。
    すみません、理解できてませんでした。
    generatedとは、そういう意味だったのですね。
    ありがとうございます。

    キャンセル

0

START WITH 0

は試されましたか?

通常は質問に記載の対応で1から発番されるかとは思います。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/10/16 13:45

    ご回答ありがとうございます。
    試すと「START WITHにMINVALUEより小さい値は指定できません。」というエラーになりました。本文に追記しました。

    キャンセル

  • 2017/10/16 13:58

    すみません、同じことをもう1度やり直したら、今度は1番から発番されました。逆になぜ最初は2番から発番されたのか不明です。

    キャンセル

0

わたしも試しました。Oracle DB 12.1.0.1.0 です。

1からになりますね。

SQL> create table search_keyword (                   
  2  id number not null,
  3  keyword varchar2(120) not null,
  4  dt date default sysdate,
  5  primary key(id)
  6  );

Table created.

SQL> create sequence search_key_seq
  2  start with 1
  3  increment by 1
  4  nomaxvalue;

Sequence created.

SQL> insert into search_keyword (id, keyword)         
  2  values (search_key_seq.nextval, 'キーワード');

1 row created.

SQL> commit;

Commit complete.

SQL> select id from search_keyword;

        ID
----------
         1

SQL> 

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

すでにシーケンスを参照して、値が1になっていませんか?

シーケンスの現在値の確認方法をググって、調べてみてください。

「一意制約に反しています」

これは、シーケンスの問題でなく、SEARCH_KEYWORDテーブルにすでにIDが1のデータが入っているから。
たぶん、このデータいれるときにシーケンス使ったので、初期値が違うのでは?

「START WITHにMINVALUEより小さい値は指定できません。」

エラーのままの意味です。
オラクルのCREATE SEQUENCEのリファレンスを調べてください。
MINVALUEの値を設定すれば良いかと。

その他

oracle 12c だと、テーブル定義時に自動で、sequence作ってくれる宣言があるようです。
CREATE TABLEのリファレンスを見てください。

この句を使用すると、ID列を作成できます。このID列には、それ以降のINSERT文ごとに、順序ジェネレータからの増加または減少する整数値が割り当てられます。identity_options句を使用すると、順序ジェネレータを構成できます。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

旧OTN-Japan の使えるCode Tips シーケンスの初期化/再設定
良く理解した上でお使いください。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 91.01%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • Oracle

    518questions

    Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。