Heim > Backend-Entwicklung > PHP-Tutorial > PHP-MySQL-Betriebsdatenbank

PHP-MySQL-Betriebsdatenbank

藏色散人
Freigeben: 2023-04-07 18:40:02
nach vorne
2014 Leute haben es durchsucht

Erste Schritte

Da die MySQL-Verbindungsmethode abgeschafft wurde, müssen Sie zusätzliche Komponenten herunterladen, um mysql_connect() in PHP7 verwenden zu können.

Es gibt zwei Möglichkeiten, MySQL zu verwenden: prozessorientiert und objektorientiert.

mysqli bietet drei Klassen:

● mysqli-verbindungsbezogen

● mysqli_result-Verarbeitungsergebnissatz

● mysqli_stmt-Vorverarbeitungsklasse

Datenbankverbindung

<?php
$db_host = &#39;localhost&#39;;
$db_name = &#39;test&#39;;
$db_user = &#39;root&#39;;
$db_pwd = &#39;&#39;;
//面向对象方式
$mysqli = new mysqli($db_host, $db_user, $db_pwd, $db_name);
//面向对象的昂视屏蔽了连接产生的错误,需要通过函数来判断
if(mysqli_connect_error()){
    echo mysqli_connect_error();
}
//设置编码
$mysqli->set_charset("utf8");//或者 $mysqli->query("set names &#39;utf8&#39;")
//关闭连接
$mysqli->close();
//面向过程方式的连接方式
$mysqli = mysqli_connect($db_host, $db_user, $db_pwd, $db_name);
//判断是否连接成功
if(!$mysqli ){
    echo mysqli_connect_error();
}
//关闭连接
mysqli_close($mysqli);
?>
Nach dem Login kopieren

Datenbankabfrage

Allgemein: query(sql) kann zum Ausführen von SQL-Anweisungen verwendet werden Wenn dies fehlschlägt, wird „false“ zurückgegeben. Wenn die Auswahl erfolgreich ist, wird das Ergebnissatzobjekt zurückgegeben. Andernfalls wird „true“ zurückgegeben. Dies bedeutet, dass die SQL-Anweisung erfolgreich ausgeführt wurde.

<?php
//无结果集示例
$sql = "insert into table_name (`name`, `address`) values (&#39;xiaoming&#39;, &#39;adddddrrreess&#39;)";
$result = $mysqli->query($sql);
//或者
$sql = "delete from table_name where name=&#39;xiaoming&#39;";
$result = $mysqli->query($sql);
if($result === false){
    echo $mysqli->error;
    echo $mysqli->errno;
}
//影响条数
echo $mysqli->num_rows;
//插入的id
echo $mysqli->insert_id;
$mysqli->close();
Nach dem Login kopieren

Mit Ergebnissatz

<?php
$sql = "select * from table_name";
$result = $mysqli->query($sql);
if($result === false){//执行失败
    echo $mysqli->error;
    echo $mysqli->errno;
}
//行数
echo $result->num_rows;
//列数 字段数
echo $result->field_count;
//获取字段信息
$field_info_arr = $result->fetch_fields();
//移动记录指针
//$result->data_seek(1);//0 为重置指针到起始
//获取数据
while($row = $result->fetch_assoc()){
    echo $row[&#39;name&#39;];
    echo $row[&#39;address&#39;];
}
//也可一次性获取所有数据
//$result->data_seek(0);//如果前面有移动指针则需重置
$data = $result->fetch_all(MYSQLI_ASSOC);
$mysqli->close();
Nach dem Login kopieren

Vorverarbeitungsbeispiel

Vorverarbeitung kann das Auftreten von SQL-Injection wirksam verhindern, mysqli_stmt Es ist eine Vorverarbeitungsklasse

<?php
$sql = "insert inro table_name (&#39;name&#39;,&#39;address&#39;) values (?,?)";
//获得预处理对象
$stmt = $mysqli->prepare($sql);
//绑定参数 第一个参数为绑定的数据类型
/*
i:integer 整型
d:double 浮点型
s:string 字符串
b:a blob packets blob数据包
*/
$name = "xiaoming";
$address = "adddressss";
$stmt->bind_param("ss", $name, $address);//绑定时使用变量绑定
//执行预处理
$stmt->execute();
/*
//可重新绑定 多次执行
$stmt->bind_param("ss", $name, $address);
$stmt->execute();
*/
//插入的id 多次插入为最后id
echo $stmt->insert_id;
//影响行数 也是最后一次执行的
echo $stmt->affected_rows;
//错误号
echo $stmt->errno;
//错误信息
echo $stmt->error;
//关闭
$stmt->close();
$mysqli->close();
下面示例select的预处理
//注释部分省略
$sql = "select * from table_name where id<?";
$stmt = $mysqli->prepare($sql);
$id = 30;
$stmt->bind_param("i", $id);
$stmt->execute();
//获取结果集
$result = $stmt->get_result();//结果集取后的操作就和之前一样了
//获取所有数据
$data = $result->fetch_all(MYSQLI_ASSOC);
$result->close();
$mysqli->close();
Nach dem Login kopieren

, die mehrere SQL-Anweisungen gleichzeitig ausführt (nicht empfohlen). Das Ausführungsergebnis ist keine betroffene_Zeilen ist die Anzahl der zuletzt betroffenen Elemente >Weitere PHP-bezogene Kenntnisse finden Sie auf der

PHP-Chinese-Website

!

Das obige ist der detaillierte Inhalt vonPHP-MySQL-Betriebsdatenbank. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
php
Quelle:segmentfault.com
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage