Heim >Backend-Entwicklung >PHP-Tutorial >So verwenden Sie PHP zum Bearbeiten der MySQL-Datenbank

So verwenden Sie PHP zum Bearbeiten der MySQL-Datenbank

墨辰丷
墨辰丷Original
2018-06-01 11:09:401804Durchsuche

Dieser Artikel stellt hauptsächlich die Methode zur Manipulation der MySQLi-Datenbank in PHP vor. Ich hoffe, dass er für alle hilfreich ist.

Mysql(i)-Unterstützung wurde seit PHP5.0 hinzugefügt, und die neuen Funktionen werden in Form von Objekten hinzugefügt

i bedeutet verbesserte Funktionen, hohe Effizienz und Stabilität

Parameter für die Kompilierzeit:

./configure --with-mysql=/usr/bin/mysql_config \ #使用 Mysql ClientLibrary(libmysql)构建
--with-mysqli=mysqlnd \ #使用 Mysql Native Dirver 即mysqlnd
--with-pdo-mysql=mysqlnd #使用 Mysql Native Dirver 即mysqlnd

Aufgrund von Urheberrechtsproblemen verwendet PHP ab PHP 5.3 mysqlnd anstelle von libmysql.dll
mysqlnd ist ein von der Firma Zend entwickelter MySQL-Datenbanktreiber, der sich in allen Aspekten verbessert hat

# Verwenden Sie mysqlnd zum Kompilieren

./configure --with-mysql=mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd 加上你的参数

mysqli-Prozess, Objektmodus unterstützen alle die drei von

mysqli bereitgestellten Klassen:

1, mysqli und verbindungsbezogen
2 , MySQLi_Result-Verarbeitungsergebnissatz
3

Holen Sie sich das Datenbankobjekt


//创建mysqli对象方式 1
//屏蔽连接产生的错误
$mysqli = new mysqli('127.0.0.1', 'root', '', 'test');

//只能用函数来判断是否连接成功
if(mysqli_connect_errno())
{
  echo mysqli_connect_error();
}

//创建mysqli对象方式 2 可以设置一些参数
$mysqli = mysqli_init();
$mysqli->options(MYSQLI_OPT_CONNECT_TIMEOUT, 2);//设置超时时间
$mysqli->real_connect('127.0.0.1', 'root', '', 'test');

Abfrage: Gibt bei einem Fehler „false“ zurück, „select“ gibt das Ergebnismengenobjekt erfolgreich zurück und gibt „true“ zurück Wenn nicht falsch, bedeutet dies, dass die SQL-Ausführung erfolgreich ist

Kein Beispiel für eine Ergebnismenge

$mysqli = mysqli_init();
$mysqli->options(MYSQLI_OPT_CONNECT_TIMEOUT, 2);//设置超时时间
$mysqli->real_connect('127.0.0.1', 'root', '', 'test');

$sql = "insert into limove(`name`, `order`) values('aa', 11)";
$rst = $mysqli->query($sql);

$sql = "delete from limove where id = 221";
$rst = $mysqli->query($sql);

if($rst === false)
{
  ee($mysqli->errno);
  ee($mysqli->error);
}

#影响条数
ee($mysqli->affected_rows);
#插入的id
ee($mysqli->insert_id);

ee($mysqli);

Mit Ergebnissatz

$mysqli = mysqli_init();
$mysqli->options(MYSQLI_OPT_CONNECT_TIMEOUT, 2);//设置超时时间
$mysqli->real_connect('127.0.0.1', 'root', '', 'test');

$sql = "select * from limove as limove_as";

$result = $mysqli->query($sql);
if($result === false)
{
  ee($mysqli->errno);
  ee($mysqli->error);
}

#行数
ee($result->num_rows);

#列数
ee($result->field_count);

#字段个数
ee($result->field_count);

#获取所有字段的信息
$field_arr = $result->fetch_fields();

#移动字段的指针
// $result->field_seek(1);

#依次获取字段的信息
while($field = $result->fetch_field())
{
  ee($field);
}

#移动记录指针
$result->data_seek(1);

#一次获取所有数据
$data = $result->fetch_all(MYSQLI_ASSOC);

#关联数组方式获取结果集
$data = array();

$result->data_seek(0); #重置指针到起始
while($row = $result->fetch_assoc())
{
  $data[] = $row;
}

ee($data);


$result->free();
$mysqli->close();

Führen Sie mehrere Anweisungen mit mehreren Abfragen gleichzeitig aus (nicht empfohlen)

Kein Ergebnissatz, derzeit können betroffene_Zeilen Nur die Anzahl der letzten betroffenen Zeilen abrufen

$mysqli = mysqli_init();
$mysqli->options(MYSQLI_OPT_CONNECT_TIMEOUT, 2);//设置超时时间
$mysqli->real_connect('127.0.0.1', 'root', '', 'test');


$sql_arr = array(
  'insert into limove(id,`name`, `order`) values(null, 1, 2)',    
  'insert into limove(id,`name`, `order`) values(null, 1, 222)',    
  'delete from limove where `order` = 2',    
);

$sql = implode(';', $sql_arr);

$result = $mysqli->multi_query($sql);
if($result === false)
{
  ee($mysqli->errno);
  ee($mysqli->error);
}

$mysqli->close();

Mit Ergebnismenge

$mysqli = mysqli_init();
$mysqli->options(MYSQLI_OPT_CONNECT_TIMEOUT, 2);//设置超时时间
$mysqli->real_connect('127.0.0.1', 'root', '', 'test');

$sql_arr = array(
  'show tables',    
  'desc select * from limove',    
  'show create table limove',    
);

$sql = implode(';', $sql_arr);

$rst = $mysqli->multi_query($sql);

if($rst === false)
{
  ee($mysqli->errno);
  ee($mysqli->error);
}

do{
  $result = $mysqli->store_result();#获取当前光标所在的结果集
  
  $data = $result->fetch_all();
  
  ee($data);
  
}while($mysqli->next_result());#光标移动到下一个结果集

$mysqli->close();

Transaktionsverarbeitung:

$mysqli=new mysqli("localhost", "root", "123456", "xsphpdb");

  //事务处理
  $mysqli->autocommit(0);

  $error=true;

  $price=50;

  $sql="update zh set ye=ye-{$price} where name='zhangsan'";
  
  $result=$mysqli->query($sql);

  if(!$result){
    $error=false;
    echo "从张三转出失败
";
  }else{
    if($mysqli->affected_rows==0){
      $error=false;
      echo "张三的钱没有变化";  
    }else{
      echo "从张三账号中转出成功!
";
    }
  }

  $sql="update zh set ye=ye+{$price} where name='lisi1'";

  $result=$mysqli->query($sql);

  if(!$result){
    $error=false;
    echo "从李四转入失败
";
  }else{
    if($mysqli->affected_rows==0){
      $error=false;
      echo "李四的钱没有变化";  
    }else{
      echo "向李四账号中转入成功!
";
    }
  }

  if($error){
    echo "转账成功!";
    $mysqli->commit();
  }else{
    echo "转账失败!";
    $mysqli->rollback();
  }

  $mysqli->autocommit(1);
  $mysqli->close();

mysqli_stmt: MySQLi-Vorverarbeitungsklasse (empfohlen): Stellt eine vorbereitete Anweisung dar, den Server Kompiliert SQL nur einmal

Die gleiche Funktion kann mit mysqli und mysqli_result erreicht werden

Vorteile:

Hohe Effizienz, geeignet für Situationen, in denen die Anweisungen vorhanden sind das Gleiche, aber die Daten sind unterschiedlich und SQL kann blockiert werden. Injektion generiert

mysqli_stmt-Beispiel: Nicht-Select-Anweisung

require 'fns.php';

//创建mysqli对象方式 
$mysqli = @new mysqli('127.0.0.1', 'root', '', 'test');

//只能用函数来判断是否连接成功
if(mysqli_connect_errno())
{
  echo mysqli_connect_error();
  die;
}

$mysqli->set_charset('utf8');

$sql = "insert into limove values(?, ?, ?)"; //语句一样值不相同情况



//mysqli中有直接的方法可用
$stmt = $mysqli->prepare($sql);

//绑定参数
$stmt->bind_param('iss', $id, $name, $order);

for($i=0;$i<5;$i++){
  $id = 0;
  $name = &#39;name&#39;;
  $order = mt_rand(1, 1000);
  $stmt->execute();

}

//最后id
ee($stmt->insert_id);

//影响的行数 注:最后一条执行的
ee($stmt->affected_rows);

//错误号
ee($stmt->errno);

//错误信息
ee($stmt->error);

//stmt对象中可以看到更多的信息
ee($stmt);

eee($mysqli);

mysqli_stmt-Beispiel: Anweisung 1 auswählen

require &#39;fns.php&#39;;

//创建mysqli对象方式 
$mysqli = @new mysqli(&#39;127.0.0.1&#39;, &#39;root&#39;, &#39;&#39;, &#39;test&#39;);

//只能用函数来判断是否连接成功
if(mysqli_connect_errno())
{
  echo mysqli_connect_error();
  die;
}

$mysqli->set_charset(&#39;utf8&#39;);

$sql = "select * from limove where id

Zusammenfassung: Das Obige ist der gesamte Inhalt dieses Artikels, ich hoffe, dass dies möglich ist hilfreich für das Studium aller sein.

Verwandte Empfehlungen:

Verwenden Sie

php

, um innerhalb einer Woche einen automatischen Login-Speichermechanismus zu realisieren

PHP Einfache Verwendung von Benutzerüberprüfung und Tag-Empfehlung

Verwenden Sie

php, um mit dem Server und der Web-Front-End-Schnittstelle zu interagieren

Das obige ist der detaillierte Inhalt vonSo verwenden Sie PHP zum Bearbeiten der MySQL-Datenbank. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn