INSERT ステートメント
新しいレコードを作成するには、INSERT ステートメントを使用します。
INSERT 構文
INSERT ステートメントは、挿入するカラムと新しいカラム値を指定します。複数のカラム値は、次の例に示すように、VALUES 句のカンマ区切りリストで指定できます。
INSERT INTO <table_name>
( <column_reference> [ , ... ] )
VALUES
( { <expression> | NULL } [ , ... ] )
<expression> ::=
| @ <parameter>
| ?
| <literal>
次の例に示すように、ExecuteNonQuery メソッドを使って、データ操作コマンドを実行し影響を受けた行を取得できます。
C#
String connectionString = "AuthScheme=OAuth;InitiateOAuth=GETANDREFRESH;WorkerAppEnvironmentId=eebc33a8-xxxx-4f3a-yyyy-d3e5262fd49e;Region=NA;OAuthClientId=client_id;OAuthClientSecret=client_secret;";
using (PingOneConnection connection = new PingOneConnection(connectionString)) {
int rowsAffected;
PingOneCommand cmd = new PingOneCommand("INSERT INTO [CData].[Administrators].Users (Email) VALUES ('John')", connection);
rowsAffected = cmd.ExecuteNonQuery();
}
VB.NET
Dim connectionString As [String] = "AuthScheme=OAuth;InitiateOAuth=GETANDREFRESH;WorkerAppEnvironmentId=eebc33a8-xxxx-4f3a-yyyy-d3e5262fd49e;Region=NA;OAuthClientId=client_id;OAuthClientSecret=client_secret;"
Using connection As New PingOneConnection(connectionString)
Dim rowsAffected As Integer
Dim cmd As New PingOneCommand("INSERT INTO [CData].[Administrators].Users (Email) VALUES ('John')", connection)
rowsAffected = cmd.ExecuteNonQuery()
End Using
生成されたId の取得
最後に挿入されたレコードのId を取得するには、次の例に示すように、SCOPE_IDENTITY 関数を使用します。C#
cmd = connection.CreateCommand(); cmd.CommandText = "SELECT SCOPE_IDENTITY()"; Object returnedValues = cmd.ExecuteScalar(); String Id = (String)returnedValues;
VB.NET
cmd = connection.CreateCommand() cmd.CommandText = "SELECT SCOPE_IDENTITY()" Dim returnedValues As [Object] = cmd.ExecuteScalar() Dim Id As [String] = returnedValues