ホームページ >バックエンド開発 >PHPチュートリアル >【PHP】MySQLは挿入データの主キー(自己増加ID)を取得する

【PHP】MySQLは挿入データの主キー(自己増加ID)を取得する

WBOY
WBOYオリジナル
2016-06-23 13:38:061581ブラウズ

主キーの競合を防ぐため、DB設計時にはオートインクリメント(auto_increment型)フィールドがよく使われます。したがって、データを挿入する前には、レコードの主キーが何であるかわからないことがよくあります。後続のクエリまたはカスケード クエリを容易にするために、レコードの行を挿入した後に DB によって自動的に生成された主キーを取得する必要があります。以下にいくつかのメソッドを示します:

  • 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 の概念は関連しています:

  • mysql と mysqli は両方とも PHP の関数セットであり、mysql データベースとはほとんど関係がありません。
  • php5 バージョンより前は、mysql データベースを駆動するために php の mysql 関数が一般的に使用されていました。たとえば、mysql_query() 関数はプロセス指向です。 3. php5 バージョン以降、mysqli の関数関数が追加されました。ある意味、これは mysql システム関数の強化版であり、より安定し、効率的で安全な mysql_query() に対応する mysqli_query() はオブジェクト指向であり、オブジェクトを使用して mysql データベースを操作および駆動します
  • b. mysql と mysqli の違い:

  • mysql は、接続されるたびに接続プロセスを開きます。
  • mysqli は永続的な接続機能です。mysqli を複数回実行すると同じ接続プロセスが使用されるため、サーバーのオーバーヘッドが軽減されます。 mysqli は、トランザクションなどの一部の高度な操作をカプセル化し、DB 操作プロセスで使用可能な多くのメソッドもカプセル化します。
  • c. mysql と mysqli の使用法:

  • mysql (手続き型モード):
  • $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 ステートメント、「リソース識別」) はオプションであり、デフォルト値は最後に開かれた接続またはリソースです。

  • mysqli (オブジェクト モード):
  • $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 コンストラクターにパラメーターとして渡すことができます
  • mysqli_query() または mysqli If query() メソッドを使用してオブジェクトをクエリする場合は、接続識別子が必要です。
  • JDBC 2.0: insertRow()

    すごい

    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 { ... }

  • 声明:
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。