SQLite-INSERTクエリ
SQLite INSERT INTO ステートメントは、データベース内のテーブルにデータの新しい行を追加するために使用されます。
構文
以下は、INSERTINTOステートメントの2つの基本的な構文です。
INSERT INTO TABLE_NAME [(column1, column2, column3,...columnN)]
VALUES (value1, value2, value3,...valueN);
ここで、column1、column2、... columnNは、データを挿入するテーブル内の列の名前です。
テーブルのすべての列に値を追加する場合は、SQLiteクエリで列名を指定する必要がない場合があります。ただし、値の順序がテーブルの列と同じ順序であることを確認してください。SQLite INSERTINTO構文は次のようになります-
INSERT INTO TABLE_NAME VALUES (value1,value2,value3,...valueN);
例
次のように、testDB.dbにCOMPANYテーブルをすでに作成していると考えてください。
sqlite> CREATE TABLE COMPANY(
ID INT PRIMARY KEY NOT NULL,
NAME TEXT NOT NULL,
AGE INT NOT NULL,
ADDRESS CHAR(50),
SALARY REAL
);
ここで、次のステートメントはCOMPANYテーブルに6つのレコードを作成します。
INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (1, 'Paul', 32, 'California', 20000.00 );
INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (2, 'Allen', 25, 'Texas', 15000.00 );
INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (3, 'Teddy', 23, 'Norway', 20000.00 );
INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 );
INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (5, 'David', 27, 'Texas', 85000.00 );
INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (6, 'Kim', 22, 'South-Hall', 45000.00 );
次のように2番目の構文を使用して、COMPANYテーブルにレコードを作成できます。
INSERT INTO COMPANY VALUES (7, 'James', 24, 'Houston', 10000.00 );
上記のすべてのステートメントは、COMPANYテーブルに次のレコードを作成します。次の章では、これらすべてのレコードをテーブルから表示する方法を学習します。
ID NAME AGE ADDRESS SALARY
---------- ---------- ---------- ---------- ----------
1 Paul 32 California 20000.0
2 Allen 25 Texas 15000.0
3 Teddy 23 Norway 20000.0
4 Mark 25 Rich-Mond 65000.0
5 David 27 Texas 85000.0
6 Kim 22 South-Hall 45000.0
7 James 24 Houston 10000.0
別のテーブルを使用して1つのテーブルにデータを入力する
別のテーブルに最初のテーブルを設定するために必要な一連のフィールドがある場合は、別のテーブルのselectステートメントを使用してデータをテーブルに入力できます。これが構文です-
INSERT INTO first_table_name [(column1, column2, ... columnN)]
SELECT column1, column2, ...columnN
FROM second_table_name
[WHERE condition];
今のところ、上記のステートメントはスキップできます。最初に、後続の章で説明するSELECT句とWHERE句について学習しましょう。