ホームページ >バックエンド開発 >PHPチュートリアル >php を mysql に接続するための複数の方法とコード例

php を mysql に接続するための複数の方法とコード例

WBOY
WBOYオリジナル
2016-07-25 08:51:381316ブラウズ
  1. mysql_connect("localhost", "root","1981427") //localhostにあるサーバーに接続します。ユーザー名はrootです
  2. ?>
コードをコピーします

再接続 データベースを選択

  1. @mysql_select_db("test") //データベースmydbを選択
  2. ?>
コードをコピー

これでデータベースに接続できます

コードを実行すると次のように表示されます。 未定義の関数「mysql_connect()」への呼び出し…失敗しました このプロンプト関数が未定義であるということは、mysql_connect() 関数が存在しないことを意味します。

解決策: php_mysql.dll ファイルと libmysql.dll ファイルを c:winntsystem32 にコピーします (libmysql.dll を見逃しました) php.ini で ;extension=php_mysql を見つけ、その前にある「;」を削除します サーバーを再起動します 例 1、conn.php ファイルのコード:

  1. $conn = @mysql_connect("localhost", "root", "root") or die("データベースリンクエラー");
  2. mysql_select_db("data", $conn); //data はデータベース名です
  3. mysql_query("set names 'gbk'"); //gbk 中国語エンコーディングを使用します;
  4. ?>
コードをコピーします
Index.php ファイルのコード:

  1. include("conn.php");// conn.php ファイルを導入します
  2. $sql="select * from `table` order by id desc";
  3. $query=mysql_query ( $sql);
  4. while($row=mysql_fetch_array($query)){
  5. ?>
コードをコピー
データの内容を表示します:

  1. }
  2. ?>
コード

phpをコピーしてmysqlデータベースに接続します

方法1:通常の方法(プロセス重視)

まず、データベースのユーザー情報:

  1. //接続を生成する

  2. $db_connect=mysql_connect($dbhost,$username,$userpass) または die("unable to connect to the mysql!");
  3. //Select操作が必要なデータベース
  4. mysql_select_db($dbdatabase,$db_connect);
  5. //mysqlステートメントを実行
  6. $result=mysql_query("select id,name from user");

  7. // データを抽出します

  8. $row=mysql_fetch_row($result);

コードをコピーします
追加: ①mysql_connect()、mysql_select_db()、その他の関数の前に @ (エラー制御演算子) を使用してシステムによって生成されたエラー メッセージを無視し、その後 die() を使用してエラー メッセージをカスタマイズします。

②データを抽出する場合、上記の mysql_fetch_row に加えて、一般的なものは mysql_fetch_assoc と mysql_fetch_array です。具体的な違いについては、php マニュアルを参照してください。

③mysql_query() 関数の戻り値については、実行されたステートメントに戻り値がある場合 (select、show、describe など)、対応するデータ (成功時) または false (失敗時) が返されます。実行されたステートメント (削除、ドロップ、挿入、更新など) に戻り値がない場合は、true (成功した場合) または false (失敗した場合) を返します。

方法 2: MySQL データベースに接続するための PHP オブジェクト指向メソッド

実際、このメソッドは通常のメソッドと非常に似ており、対応する関数をオブジェクト指向メソッドに置き換えて、コードを直接参照するだけです。

$db=new mysqli($dbhost,$username,$userpass,$dbdatabase);
    if(mysqli_connect_error()){
  1. echo 'データベースに接続できませんでした。';
  2. 終了;
  3. }
  4. $result=$db->query("select id,name from user");
  5. $row=$result->fetch_row();
  6. コードをコピー

ここでは Mysqli が使用されています。これは、mysql の拡張機能を意味します。プロセス指向の方法でもオブジェクト指向の方法でもデータベースと対話できます。唯一の違いは、関数 (オブジェクト メソッド) を呼び出す方法が異なることです。

方法 3: mysql データベースに接続するための php pdo メソッド

pdo は実際には php データベース オブジェクトの略語で、中国語では php データベース オブジェクトです。これは、PHP がデータベースと対話するための統一された方法を提供します。

これは現在、データベースに接続する一般的な方法です。その利点は、データ ソースが正しく提供されている限り、データベースに対する残りの基本操作は同じであることです。言い換えれば、正しいデータ ソースを提供すれば、同じコードで mysql、sqlite3、そしてもちろん postgresql と対話できるということです。 mysqlに接続するコード:

  1. $dsn='mysql:host='.$dbhost.';dbname='.$dbdatabase.';'

  2. $dbh=new pdo($dsn,$username,$ userpass);

  3. sqlite3:

  4. $dsn='sqlite3:"c:sqliteuser.db"';
  5. $dbh=new pdo($dsn);

  6. < p>postgresql:
  7. $dsn='pgsql:host='.$dbhost.' port=5432 dbname='.$username.' パスワード='.$userpass;
  8. $dbh=new pdo($dsn);
コードをコピーします

データベースとの接続を正常に確立したら、データベースからデータを取得するか、データを挿入して更新するだけで済みます。

SQLコード:

  1. $stmt=$dbh->query('ユーザーからID、名前を選択');
  2. $row=$stmt->fetch();
コードをコピー


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