主キーの競合を防ぐため、DB設計時にはオートインクリメント(auto_increment型)フィールドがよく使われます。したがって、データを挿入する前には、レコードの主キーが何であるかわからないことがよくあります。後続のクエリまたはカスケード クエリを容易にするために、レコードの行を挿入した後に DB によって自動的に生成された主キーを取得する必要があります。以下にいくつかのメソッドを示します:
一般:
SELECT max(id) FROM user;
このメソッドの欠点は、高い同時実行性に適していないことです。同時に挿入した場合、返される値は正確ではない可能性があります。
MySQL:
SELECT LAST_INSERT_ID();
重要: INSERT ステートメントを使用して複数の行を挿入する場合、LAST_INSERT_ID() はデータの最初の行が挿入されたときに生成された値のみを返します。その理由は、他のサーバーに依存して同じ INSERT ステートメントを複製することが容易になるためです。
MS-SQL SERVER:
select @@IDENTITY;
@@identity は、ID 属性を持つテーブル (つまり、自動インクリメント列) にデータが最後に挿入されたときの、対応する自動インクリメント列の値を表します。システムのグローバル変数によって定義されます。通常、システム定義のグローバル変数は @@ で始まり、ユーザー定義変数は @ で始まります。たとえば、自動インクリメント列が id であるテーブル A があり、テーブル A にデータ行を挿入した後、自動インクリメント列の値が 101 に自動的に増加すると、@ を選択して取得された値になります。 @identityは101になります。 @@identity を使用するための前提条件は、挿入操作の実行後、select @@identity を実行するときに接続が閉じられていないことです。そうでない場合、結果は NULL 値になります。
追加:
SCOPE_IDENTITY、IDENT_CURRENT、および @@IDENTITY は、すべて IDENTITY 列に挿入された値を返すという点で機能的に似ています。
IDENT_CURRENT はスコープとセッションによって制限されませんが、指定されたテーブルによって制限されます。 IDENT_CURRENT は、任意のセッションおよびスコープ内の特定のテーブルに対して生成された値を返します。詳細については、「IDENT_CURRENT」を参照してください。
SCOPE_IDENTITY および @@IDENTITY は、現在のセッションのテーブル内で生成された最後の ID 値を返します。ただし、SCOPE_IDENTITY は現在のスコープに挿入された値のみを返します。@@IDENTITY は特定のスコープに制限されません。
PHP: mysql_insert_id(connection); または mysqli_insert_id(connection);
パラメータ connection
説明 必須。使用する MySQL 接続を指定します。
<?php$con = mysql_connect("localhost", "hello", "321");if (!$con) { die('Could not connect: ' . mysql_error()); }$db_selected = mysql_select_db("test_db",$con);$sql = "INSERT INTO person VALUES ('Carter','Thomas','Beijing')";$result = mysql_query($sql,$con);echo "ID of last inserted record is: " . mysql_insert_id();mysql_close($con);?>
<?php$con=mysqli_connect("localhost","my_user","my_password","my_db");// Check connectionif (mysqli_connect_errno($con)){echo "Failed to connect to MySQL: " . mysqli_connect_error();}mysqli_query($con,"INSERT INTO Persons (FirstName,LastName,Age) VALUES ('Glenn','Quagmire',33)");// Print auto-generated idecho "New record has id: " . mysqli_insert_id($con); mysqli_close($con);?>
補足:
PHP-MySQL は、MySQL データベースを操作するための PHP の最も独創的な Extension であり、Extension としては比較的高度な機能を提供します。懸念されますが、セキュリティ自体も追加されます。
a. mysql と mysqli の概念は関連しています:
b. mysql と mysqli の違い:
c. mysql と mysqli の使用法:
$conn = mysql_connect('localhost', 'user', 'password'); //连接mysql数据库mysql_select_db('data_base'); //选择数据库$result = mysql_query('select * from data_base');//第二个可选参数,指定打开的连接$row = mysql_fetch_row( $result ) ) //只取一行数据echo $row[0]; //输出第一个字段的值
PS: mysqli は手続き型モードで動作し、一部の関数は mysqli_query (リソース識別子、SQL ステートメントなど) を指定する必要があります。 ) であり、 リソース識別パラメータは の前に配置され、mysql_query のリソース識別 (SQL ステートメント、「リソース識別」) はオプションであり、デフォルト値は最後に開かれた接続またはリソースです。
$conn = new mysqli('localhost', 'user', 'password','data_base'); //要使用new操作符,最后一个参数是直接指定数据库//假如构造时候不指定,那下一句需要$conn -> select_db('data_base')实现$result = $conn -> query( 'select * from data_base' );$row = $result -> fetch_row(); //取一行数据echo row[0]; //输出第一个字段的值
new mysqli('localhost', usenamer', 'password', 'databasename'); を使用すると、次のプロンプトでエラーが報告されます:
Fatal error: Class 'mysqli ' が見つかりません...
通常、mysqli クラスはデフォルトで有効になっていないため、php.ini を変更し、php_mysqli.dll の前にある「;」を削除する必要があります。 , mysqli をコンパイルする必要があります。
d. mysql_connect() および mysqli_connect()
mysqli を使用すると、mysqli_connect() 関数または mysqli コンストラクターにパラメーターとして渡すことができますすごい
JDBC 3.0:getGeneratedKeys()
Statement stmt = null;ResultSet rs = null;try { stmt = conn.createStatement(java.sql.ResultSet.TYPE_FORWARD_ONLY, java.sql.ResultSet.CONCUR_UPDATABLE); // ... // 省略若干行(如上例般创建demo表) // ... stmt.executeUpdate( "INSERT INTO autoIncTutorial (dataField) " + "values ('Can I Get the Auto Increment Field?')", Statement.RETURN_GENERATED_KEYS); // 向驱动指明需要自动获取generatedKeys! int autoIncKeyFromApi = -1; rs = stmt.getGeneratedKeys(); // 获取自增主键! if (rs.next()) { autoIncKeyFromApi = rs.getInt(1); } else { // throw an exception from here } rs.close(); rs = null; System.out.println("Key returned from getGeneratedKeys():" + autoIncKeyFromApi);} finally { ... }