Rumah pembangunan bahagian belakang tutorial php PHP入门教程之使用Mysqli操作数据库的方法(连接,查询,事务回滚等)

PHP入门教程之使用Mysqli操作数据库的方法(连接,查询,事务回滚等)

Dec 22, 2016 am 11:47 AM

本文实例讲述了PHP入门教程之使用Mysqli操作数据库的方法。分享给大家供大家参考,具体如下:

Demo1.php

<?php
  //使用 mysqli 对象操作数据库
  //创建 mysqli 对象(资源句柄)
  $_mysqli = new mysqli();
  //连接数据库 1.主机名(ip) 2.账户 3.密码 4.数据库
  //mysqli_connect 函数 == $_mysqli -> connect();
  $_mysqli -> connect(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;guest&#39;);
  //断开 MySQL mysqli_close() == $_mysqli -> close();
  $_mysqli -> close();
?>
Salin selepas log masuk

Demo2.php

<?php
  //不用 connect ,直接使用构造方法
  $_mysqli = new mysqli(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;guest&#39;);
  //单独选择一个数据库
  //这里选择的数据库会替代上面的数据库
  //为了避免这些麻烦,尽量不用去单独指向了
  //$_mysqli -> select_db(&#39;school&#39;);
  $_mysqli -> close();
?>
Salin selepas log masuk

Demo3.php

<?php
  header ( &#39;Content-Type:text/html; charset=utf-8;&#39; );
  //连接 mysql
  //当你参数出现错误,导致连接错误的时候,
  //$_mysqli 这个对象就没有创建成功,也就是说,没有资源句柄的功能
  //就是没有调用 mysqli 下的方法和属性的能力了
  @$_mysqli = new mysqli(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;guest&#39;);
  //为什么要用函数去捕捉呢?
  //为什么不用面向对象的方式去捕捉呢?
  if(mysqli_connect_errno()){
    echo &#39;数据库连接出现了错误,错误的信息是:&#39;.mysqli_connect_error();
    exit();
  }
  $_mysqli->close();
?>
Salin selepas log masuk

Demo4.php

<?php
  header ( &#39;Content-Type:text/html; charset=utf-8;&#39; );
  //连接 mysql
  //当你参数出现错误,导致连接错误的时候,
  //$_mysqli 这个对象就没有创建成功,也就是说,没有资源句柄的功能
  //就是没有调用 mysqli 下的方法和属性的能力了
  @$_mysqli = new mysqli(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;guest&#39;);
  //为什么要用函数去捕捉呢?
  //为什么不用面向对象的方式去捕捉呢?
  if(mysqli_connect_errno()){
    echo &#39;数据库连接出现了错误,错误的信息是:&#39;.mysqli_connect_error();
    exit();
  }
  //$_mysqli -> select_db(&#39;fsdfd&#39;);
  //数据库操作时发生的错误
  if($_mysqli -> errno){
    echo &#39;数据库操作错误:&#39;.$_mysqli -> error;
  }
  $_mysqli->close();
?>
Salin selepas log masuk

Demo5.php

<?php
  header ( &#39;Content-Type:text/html; charset=utf-8;&#39; );
  $_mysqli = new mysqli(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;testguest&#39;);
  //数据库连接时发生的错误
  if(mysqli_connect_errno()){
    echo &#39;数据库连接出现了错误,错误的信息是:&#39;.mysqli_connect_error();
    exit();
  }
  //设置一下编码
  $_mysqli -> set_charset(&#39;utf8&#39;);
  //创建一句 SQL ,获取数据库的表的数据
  $_sql = "SELECT * FROM tg_user";
  //执行 SQL 语句,把结果集赋给 $_result
  $_result = $_mysqli -> query($_sql);
  //var_dump($_result); //object(mysqli_result)#2 (0) { }
  //通过结果集,我要取得第一行数据
  //fetch_row();是返回的一个数组,里面是第一条数据的集合
  print_r( $_result -> fetch_row());
  //运行一次,指针下移一条
  print_r( $_result -> fetch_row());
  //销毁结果集
  $_result -> free();
  $_mysqli->close();
?>
Salin selepas log masuk

Demo6.php

<?php
  header ( &#39;Content-Type:text/html; charset=utf-8;&#39; );
  $_mysqli = new mysqli(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;testguest&#39;);
  //数据库连接时发生的错误
  if (mysqli_connect_errno()) {
    echo &#39;数据库连接出现了错误.错误的信息是:&#39;.mysqli_connect_error();
    exit();
  }
  //设置一下编码
  $_mysqli->set_charset(&#39;utf8&#39;);
  //创建一句SQL,获取数据库的表的数据
  $_sql = "SELECT * FROM tg_user";
  //创建一个结果集
  $_result = $_mysqli->query($_sql);
  //使用索引数组取值
  //print_r($_result->fetch_row());
  $_row = $_result->fetch_row();
  echo $_row[3];
  //遍历,下标很难记[3]
  while (!!$_row = $_result->fetch_row()) {
    echo $_row[3].&#39;<br />&#39;;
  }
  $_mysqli->close();
?>
Salin selepas log masuk

Demo7.php

<?php
  header ( &#39;Content-Type:text/html; charset=utf-8;&#39; );
  $_mysqli = new mysqli(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;testguest&#39;);
  //数据库连接时发生的错误
  if (mysqli_connect_errno()) {
    echo &#39;数据库连接出现了错误.错误的信息是:&#39;.mysqli_connect_error();
    exit();
  }
  //设置一下编码
  $_mysqli->set_charset(&#39;utf8&#39;);
  //创建一句SQL,获取数据库的表的数据
  $_sql = "SELECT * FROM tg_user";
  //创建一个结果集
  $_result = $_mysqli->query($_sql);
  //使用关联数组取值
  //print_r($_result->fetch_assoc());
  $_assoc = $_result->fetch_assoc();
  echo $_assoc[&#39;tg_username&#39;];
  //遍历
  while (!!$_assoc = $_result->fetch_assoc()) {
    echo $_assoc[&#39;tg_username&#39;].&#39;<br />&#39;;
  }
  $_mysqli->close();
?>
Salin selepas log masuk

Demo8.php

<?php
  header ( &#39;Content-Type:text/html; charset=utf-8;&#39; );
  $_mysqli = new mysqli(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;testguest&#39;);
  //数据库连接时发生的错误
  if (mysqli_connect_errno()) {
    echo &#39;数据库连接出现了错误.错误的信息是:&#39;.mysqli_connect_error();
    exit();
  }
  //设置一下编码
  $_mysqli->set_charset(&#39;utf8&#39;);
  //创建一句SQL,获取数据库的表的数据
  $_sql = "SELECT * FROM tg_user";
  //创建一个结果集
  $_result = $_mysqli->query($_sql);
  //使用索引+关联数组取值
  //print_r($_result->fetch_array());
  $_array = $_result->fetch_array();
  echo $_array[3];
  echo $_array[&#39;tg_username&#39;];
  //遍历.....
  $_mysqli->close();
?>
Salin selepas log masuk

Demo9.php

<?php
  header ( &#39;Content-Type:text/html; charset=utf-8;&#39; );
  $_mysqli = new mysqli(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;testguest&#39;);
  //数据库连接时发生的错误
  if (mysqli_connect_errno()) {
    echo &#39;数据库连接出现了错误.错误的信息是:&#39;.mysqli_connect_error();
    exit();
  }
  //设置一下编码
  $_mysqli->set_charset(&#39;utf8&#39;);
  //创建一句SQL,获取数据库的表的数据
  $_sql = "SELECT * FROM tg_user";
  //创建一个结果集
  $_result = $_mysqli->query($_sql);
  //使用OOP的方法object
  //print_r($_result->fetch_object());
  echo $_result->fetch_object()->tg_username;
  //使用OOP遍历
  while (!!$_object = $_result->fetch_object()) {
    echo $_object->tg_username.&#39;<br />&#39;;
  }
  $_mysqli->close();
?>
Salin selepas log masuk

Demo10.php

<?php
  header ( &#39;Content-Type:text/html; charset=utf-8;&#39; );
  $_mysqli = new mysqli(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;testguest&#39;);
  //数据库连接时发生的错误
  if (mysqli_connect_errno()) {
    echo &#39;数据库连接出现了错误.错误的信息是:&#39;.mysqli_connect_error();
    exit();
  }
  //设置一下编码
  $_mysqli->set_charset(&#39;utf8&#39;);
  //创建一句SQL,获取数据库的表的数据
  $_sql = "SELECT * FROM tg_user limit 0,10";
  //创建一个结果集
  $_result = $_mysqli->query($_sql);
  //我要看下我选择了多少行
  echo $_result->num_rows;
  //我影响了多少行呢
  echo $_mysqli->affected_rows;
  $_mysqli->close();
?>
Salin selepas log masuk

Demo11.php

<?php
  header ( &#39;Content-Type:text/html; charset=utf-8;&#39; );
  $_mysqli = new mysqli(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;testguest&#39;);
  //数据库连接时发生的错误
  if (mysqli_connect_errno()) {
    echo &#39;数据库连接出现了错误.错误的信息是:&#39;.mysqli_connect_error();
    exit();
  }
  //设置一下编码
  $_mysqli->set_charset(&#39;utf8&#39;);
  //创建一句SQL,获取数据库的表的数据
  $_sql = "UPDATE tg_user SET tg_username=&#39;一站式建网站&#39; WHERE tg_id=5";
  //创建一个结果集
  $_result = $_mysqli->query($_sql);
  //我要看下我选择了多少行
  echo $_result->num_rows;
  echo &#39;|&#39;;
  //我影响了多少行呢
  echo $_mysqli->affected_rows;
  $_mysqli->close();
?>
Salin selepas log masuk

Demo12.php

<?php
  header ( &#39;Content-Type:text/html; charset=utf-8;&#39; );
  $_mysqli = new mysqli(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;testguest&#39;);
  //数据库连接时发生的错误
  if (mysqli_connect_errno()) {
    echo &#39;数据库连接出现了错误.错误的信息是:&#39;.mysqli_connect_error();
    exit();
  }
  //设置一下编码
  $_mysqli->set_charset(&#39;utf8&#39;);
  //创建一句SQL,获取数据库的表的数据
  $_sql = "SELECT * FROM tg_user";
  //创建一个结果集
  $_result = $_mysqli->query($_sql);
  //求出表中有多少个字段
  echo $_result->field_count;
  //获取字段的名字
// $_field = $_result->fetch_field();
// echo $_field->name;
// $_field = $_result->fetch_field();
// echo $_field->name;
//
// while (!!$_field = $_result->fetch_field()) {
//   echo $_field->name.&#39;<br />&#39;;
// }
  //一次性取得所有的字段
  $_fields = $_result->fetch_fields();
  //echo $_fields[0]->name;
  foreach ($_fields as $_field) {
    echo $_field->name.&#39;<br />&#39;;
  }
  $_mysqli->close();
?>
Salin selepas log masuk

Demo13.php

<?php
  header ( &#39;Content-Type:text/html; charset=utf-8;&#39; );
  $_mysqli = new mysqli(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;testguest&#39;);
  //数据库连接时发生的错误
  if (mysqli_connect_errno()) {
    echo &#39;数据库连接出现了错误.错误的信息是:&#39;.mysqli_connect_error();
    exit();
  }
  //设置一下编码
  $_mysqli->set_charset(&#39;utf8&#39;);
  //创建一句SQL,获取数据库的表的数据
  $_sql = "SELECT * FROM tg_user";
  //创建一个结果集
  $_result = $_mysqli->query($_sql);
  //移动数据指针
  $_result->data_seek(9);
  $_row = $_result->fetch_row();
  echo $_row[3];
  //移动字段指针
  $_result->field_seek(3);
  $_field = $_result->fetch_field();
  echo $_field->name;
  $_mysqli->close();
?>
Salin selepas log masuk

Demo14.php

<?php
  header ( &#39;Content-Type:text/html; charset=utf-8;&#39; );
  $_mysqli = new mysqli(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;testguest&#39;);
  //数据库连接时发生的错误
  if (mysqli_connect_errno()) {
    echo &#39;数据库连接出现了错误.错误的信息是:&#39;.mysqli_connect_error();
    exit();
  }
  //设置一下编码
  $_mysqli->set_charset(&#39;utf8&#39;);
  //创建三个修改的SQL语句
  $_sql .= "UPDATE tg_article SET tg_username=&#39;喀喀喀&#39; WHERE tg_id=1;";
  $_sql .= "UPDATE tg_flower SET tg_fromuser=&#39;喀喀喀&#39; WHERE tg_id=1;";
  $_sql .= "UPDATE tg_friend SET tg_fromuser=&#39;喀喀喀&#39; WHERE tg_id=1";
  //使用通知执行的方法
  $_mysqli->multi_query($_sql);
  //普通只能执行sql的方法是:$_mysqli->query($_sql);
  $_mysqli->close();
?>
Salin selepas log masuk

Demo15.php

<?php
  header ( &#39;Content-Type:text/html; charset=utf-8;&#39; );
  $_mysqli = new mysqli(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;testguest&#39;);
  //数据库连接时发生的错误
  if (mysqli_connect_errno()) {
    echo &#39;数据库连接出现了错误.错误的信息是:&#39;.mysqli_connect_error();
    exit();
  }
  //设置一下编码
  $_mysqli->set_charset(&#39;utf8&#39;);
  //创建三条选择语句
  $_sql .= "SELECT * FROM tg_photo;";
  $_sql .= "SELECT * FROM tg_user;";
  $_sql .= "SELECT * FROM tg_friend";
  if ($_mysqli->multi_query($_sql)) {
    //获取当前的结果集
    $_result = $_mysqli->store_result();
    print_r($_result->fetch_row());
    echo &#39;<br />&#39;;
    //将结果集的指针移到下一条
    $_mysqli->next_result();
    $_result = $_mysqli->store_result();
    if (!$_result) {
      echo &#39;第二条SQL语句有五!&#39;;
      exit();
    }
    print_r($_result->fetch_row());
    echo &#39;<br />&#39;;
    $_mysqli->next_result();
    $_result = $_mysqli->store_result();
    if (!$_result) {
      echo &#39;第三条SQL语句有五!&#39;;
      exit();
    }
    print_r($_result->fetch_row());
  } else {
    echo &#39;第一条SQL语句有误&#39;;
    exit();
  }
  $_mysqli->close();
?>
Salin selepas log masuk

Demo16.php

<?php
  header ( &#39;Content-Type:text/html; charset=utf-8;&#39; );
  $_mysqli = new mysqli(&#39;localhost&#39;,&#39;root&#39;,&#39;123456&#39;,&#39;testguest&#39;);
  //数据库连接时发生的错误
  if (mysqli_connect_errno()) {
    echo &#39;数据库连接出现了错误.错误的信息是:&#39;.mysqli_connect_error();
    exit();
  }
  //设置一下编码
  $_mysqli->set_charset(&#39;utf8&#39;);
  //设置关闭自动提交(手工提交)
  $_mysqli->autocommit(false);
  //创建两个SQL语句
  $_sql .= "UPDATE tg_flower SET tg_flower=tg_flower-50 WHERE tg_id=1;";
  $_sql .= "UPDATE tg_friend SET tg_state=tg_state+50 WHERE tg_id=1";
  //执行多条SQL语句
  //只要这两条SQL语句都成功了,就手工提交给数据库
  //否则,就回滚,撤销之前的有效操作。
  if ($_mysqli->multi_query($_sql)) {
    //通过影响的行数,来判定SQL语句是否成功执行
    //如果$_success是false说明sql语句有吴,那么就执行回滚,否则就手工提交
    $_success = $_mysqli->affected_rows == 1 ? true : false;
    //下移指针
    $_mysqli->next_result();
    $_success2 = $_mysqli->affected_rows == 1 ? true : false;
    //如果两条都成功的话
    if ($_success && $_success2) {
      //执行手工提交
      $_mysqli->commit();
      echo &#39;完美提交&#39;;
    } else {
      //执行回滚,撤销之前的所有操作
      $_mysqli->rollback();
      echo &#39;所有操作归零!&#39;;
    }
  } else {
    echo &#39;第一条SQL语句有错误!&#39;;
  }
  //再开启自动提交
  $_mysqli->autocommit(true);
  $_mysqli->close();
?>
Salin selepas log masuk

   

希望本文所述对大家PHP程序设计有所帮助。

更多PHP入门教程之使用Mysqli操作数据库的方法(连接,查询,事务回滚等)相关文章请关注PHP中文网!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Pembalakan PHP: Amalan Terbaik untuk Analisis Log PHP Pembalakan PHP: Amalan Terbaik untuk Analisis Log PHP Mar 10, 2025 pm 02:32 PM

Pembalakan PHP adalah penting untuk memantau dan menyahpepijat aplikasi web, serta menangkap peristiwa kritikal, kesilapan, dan tingkah laku runtime. Ia memberikan pandangan yang berharga dalam prestasi sistem, membantu mengenal pasti isu -isu, dan menyokong penyelesaian masalah yang lebih cepat

Bekerja dengan Data Sesi Flash di Laravel Bekerja dengan Data Sesi Flash di Laravel Mar 12, 2025 pm 05:08 PM

Laravel memudahkan mengendalikan data sesi sementara menggunakan kaedah flash intuitifnya. Ini sesuai untuk memaparkan mesej ringkas, makluman, atau pemberitahuan dalam permohonan anda. Data hanya berterusan untuk permintaan seterusnya secara lalai: $ permintaan-

Curl dalam PHP: Cara Menggunakan Pelanjutan PHP Curl dalam API REST Curl dalam PHP: Cara Menggunakan Pelanjutan PHP Curl dalam API REST Mar 14, 2025 am 11:42 AM

Pelanjutan URL Pelanggan PHP (CURL) adalah alat yang berkuasa untuk pemaju, membolehkan interaksi lancar dengan pelayan jauh dan API rehat. Dengan memanfaatkan libcurl, perpustakaan pemindahan fail multi-protokol yang dihormati, php curl memudahkan execu yang cekap

Respons HTTP yang dipermudahkan dalam ujian Laravel Respons HTTP yang dipermudahkan dalam ujian Laravel Mar 12, 2025 pm 05:09 PM

Laravel menyediakan sintaks simulasi respons HTTP ringkas, memudahkan ujian interaksi HTTP. Pendekatan ini dengan ketara mengurangkan redundansi kod semasa membuat simulasi ujian anda lebih intuitif. Pelaksanaan asas menyediakan pelbagai jenis pintasan jenis tindak balas: Gunakan Illuminate \ Support \ Facades \ http; Http :: palsu ([ 'Google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

12 skrip sembang php terbaik di codecanyon 12 skrip sembang php terbaik di codecanyon Mar 13, 2025 pm 12:08 PM

Adakah anda ingin memberikan penyelesaian segera, segera kepada masalah yang paling mendesak pelanggan anda? Sembang langsung membolehkan anda mempunyai perbualan masa nyata dengan pelanggan dan menyelesaikan masalah mereka dengan serta-merta. Ia membolehkan anda memberikan perkhidmatan yang lebih pantas kepada adat anda

Terangkan konsep pengikatan statik lewat dalam PHP. Terangkan konsep pengikatan statik lewat dalam PHP. Mar 21, 2025 pm 01:33 PM

Artikel membincangkan pengikatan statik lewat (LSB) dalam PHP, yang diperkenalkan dalam Php 5.3, yang membolehkan resolusi runtime kaedah statik memerlukan lebih banyak warisan yang fleksibel. Isu: LSB vs polimorfisme tradisional; Aplikasi Praktikal LSB dan Potensi Perfo

Menyesuaikan/Memperluas Rangka Kerja: Cara Menambah Fungsi Custom. Menyesuaikan/Memperluas Rangka Kerja: Cara Menambah Fungsi Custom. Mar 28, 2025 pm 05:12 PM

Artikel ini membincangkan menambah fungsi khusus kepada kerangka kerja, memberi tumpuan kepada pemahaman seni bina, mengenal pasti titik lanjutan, dan amalan terbaik untuk integrasi dan debugging.

See all articles