「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > phpysql-shim を使用して PHP 7 の「mysql_*」関数の互換性に対処する

phpysql-shim を使用して PHP 7 の「mysql_*」関数の互換性に対処する

2024 年 8 月 7 日に公開
ブラウズ:734

Using phpysql-shim to Address `mysql_*` Function Compatibility in PHP 7

導入

PHP 7 以降、mysql_* 関数は削除されました。これらの機能をまだ使用しているアプリケーションは更新する必要があり、更新しないと互換性の問題が発生します。解決策の 1 つは、php7-mysql-shim を使用することです。これは、mysql_* 関数を同等の mysqli_* にマッピングすることで、PHP 7 で mysql_* 関数を使用できるようにする互換性レイヤーを提供するライブラリです。

php7-mysql-shimとは何ですか?

php7-mysql-shim は、非推奨の mysql_* 関数のドロップイン置換を提供するように設計された PHP ライブラリです。これにより、データベースのやり取りを完全に書き直すことなく、レガシー アプリケーションを PHP 7 以降のバージョンで実行できるようになります。

php7-mysql-shim を使用する利点

  1. シームレスな移行: 大規模なリファクタリングを行わずに、レガシー アプリケーションを最新の PHP バージョンで実行できるようにします。
  2. 最小限の変更: shim ライブラリを含めるだけで済み、既存のコードベースはほとんど変更されません。
  3. コスト効果: mysqli または PDO を使用するコードの書き換えに費やされる時間とリソースを節約します。
インストール

php7-mysql-shim は、PHP の依存関係マネージャーである Composer 経由でインストールできます。

段階的なインストール

  1. コンポーザーのインストール: Composer をまだインストールしていない場合は、getcomposer.org.

    の手順に従ってインストールできます。
  2. php7-mysql-shim が必要です: プロジェクト ディレクトリに移動し、次のコマンドを実行して php7-mysql-shim をプロジェクトに追加します:

作曲家には doozie-akshay/php7-mysql-shim が必要です
   composer require doozie-akshay/php7-mysql-shim
  1. コードに Shim を含めます: PHP スクリプトの先頭に、理想的にはすべてのスクリプトに含まれる構成ファイルに次の行を追加します。
'vendor/autoload.php' が必要です。
   composer require doozie-akshay/php7-mysql-shim
使用例

mysql_* 関数を使用した元のコード

mysql_* 関数を使用した従来のコードの例を次に示します:


// config.php $db_host = 'ローカルホスト'; $db_user = 'ルート'; $db_password = ''; $db_name = 'テスト'; // 接続を確立する $connection = mysql_connect($db_host, $db_user, $db_password); if (!$connection) { die('接続できませんでした: ' .mysql_error()); } mysql_select_db($db_name, $connection);
// config.php
$db_host = 'localhost';
$db_user = 'root';
$db_password = '';
$db_name = 'test';

// Establish connection
$connection = mysql_connect($db_host, $db_user, $db_password);
if (!$connection) {
    die('Could not connect: ' . mysql_error());
}
mysql_select_db($db_name, $connection);
// check_user.php include_once('config.php'); $query = "SELECT * FROM users WHERE username = 'example_user'"; $result = mysql_query($query, $connection); if (!$result) { die('クエリが失敗しました: ' .mysql_error()); } if (mysql_num_rows($result) > 0) { echo "ユーザーが存在します。"; } それ以外 { echo "ユーザーが存在しません。"; } mysql_close($connection);
   composer require doozie-akshay/php7-mysql-shim
php7-mysql-shimでコードを修正

php7-mysql-shim をインストールした後は、自動ロード ファイルをインクルードするだけです:


// config.php 'vendor/autoload.php' が必要です。 $db_host = 'ローカルホスト'; $db_user = 'ルート'; $db_password = ''; $db_name = 'テスト'; // 接続を確立する $connection = mysql_connect($db_host, $db_user, $db_password); if (!$connection) { die('接続できませんでした: ' .mysql_error()); } mysql_select_db($db_name, $connection);
// config.php
$db_host = 'localhost';
$db_user = 'root';
$db_password = '';
$db_name = 'test';

// Establish connection
$connection = mysql_connect($db_host, $db_user, $db_password);
if (!$connection) {
    die('Could not connect: ' . mysql_error());
}
mysql_select_db($db_name, $connection);
// check_user.php include_once('config.php'); $query = "SELECT * FROM users WHERE username = 'example_user'"; $result = mysql_query($query, $connection); if (!$result) { die('クエリが失敗しました: ' .mysql_error()); } if (mysql_num_rows($result) > 0) { echo "ユーザーが存在します。"; } それ以外 { echo "ユーザーが存在しません。"; } mysql_close($connection);
   composer require doozie-akshay/php7-mysql-shim
エラー処理

php7-mysql-shim は、エラー処理やその他のニュアンスを含め、mysql_* 関数との完全な互換性を提供することを目的としています。既存のエラー処理コードが変更されずに有効であることを確認してください。

結論

php7-mysql-shim は、PHP 7 以降のバージョンで mysql_* 関数を使用するレガシー PHP アプリケーションを実行するための簡単で効果的なソリューションを提供します。シムをインストールしてプロジェクトに含めることで、大規模な書き換えを回避し、最新の PHP バージョンとの互換性を確保できるため、スムーズな移行とアプリケーションの機能の継続が可能になります。

リリースステートメント この記事は次の場所に転載されています: https://dev.to/doozieakshay/using-php7-mysql-shim-to-address-mysql-function-compatibility-in-php-7-pi8?1 侵害がある場合は、 Study_golang@163 .comdelete に連絡してください
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3