PHP使用MySqli扩展库去操作MySql数据库

时间:2022-12-11 15:24:11

PHP使用MySqli扩展库去操作MySql数据库

MySqli数据库是MySql数据库的增强版

Mysqli和MySql的区别

1.MySqli的效率和安全性更高。

2.MySqli支持面向对象编程,还支持面向过程编程。

修改PHP配置文件php.ini中的     ;extension=php_mysqli.dll

去掉前面的分号即可    extension=php_mysqli.dll

简单案例

1.使用MySqli面向对象风格完成案例。

2.配置php.ini文件,让PHP支持MySqli库。

3.mysqli面向对象案例的php代码如下

<?php
header("Content-type: text/html; charset=utf-8");
//MySqli操作MySql数据库(面向对象风格)

//1.创建MySQLi对象new MySQLi("主机","用户名","密码","数据库名");
$mysqli = new MySQLi("localhost","root","root","test");
if($mysqli->connect_error)
{
die("连接失败:".$mysqli->connect_error);
}
else
{
echo "连接成功<br/>";
}

//2.操作数据库
$sql="select * from user1";
$res = $mysqli->query($sql);

//3.处理结果
while($row=$res->fetch_row())
{
//循环打印每行数据
print_r($row);
echo "<br/>";
}

//4.释放资源,关闭连接
$res->free();
$mysqli->close();
?>

4.面向过程的案例PHP代码如下

<?php
header("Content-type: text/html; charset=utf-8");
//MySqli操作MySql数据库(面向过程风格)

//1.连接数据库
$mysqli = mysqli_connect("localhost","root","root","test");
if(!$mysqli)
{
die("连接失败:".mysqli_connect_error($mysqli));
}
else
{
echo "连接成功<br/>";
}

//2.操作数据库
$sql="select * from user1";
$res = mysqli_query($mysqli,$sql);

//3.处理结果
while($row=mysqli_fetch_row($res))
{
//循环打印每行数据
print_r($row);
echo "<br/>";
}

//4.释放资源,关闭连接
mysqli_free_result($res);
mysqli_close($mysqli);
?>

5.操作MySql的PHP代码如下

<?php
//使用MySql数据库

echo 'MySql扩展库和MySql数据库是两个不同的概念<br/>';



//1.获取连接
$conn=mysql_connect("localhost","root","root");
if(!$conn)
{
echo "连接数据库失败".mysql_error();
}
else
{
echo "连接数据库成功<br/>";
}

//2.选择数据库
mysql_select_db("test");

//3.设置操作编码
mysql_query(" set names utf8");

//4.发送指令sql (ddl 数据定义语句, dml(数据库操作语言), dql(数据查询语言), dtl(数据事务语句))

$sql="select name,age from user1";
$res=mysql_query($sql,$conn);

//5.接收数据
while($row=mysql_fetch_row($res))
{
echo "<br/>";
print_r($row);
}

//mysql_fetch_row,返回索引数组
//mysql_fetch_assoc,返回关联数组
//mysql_fetch_array,返回索引数组和关联数组
//mysql_fetch_object,返回对象

//6.释放资源,关闭连接
mysql_free_result($res);
mysql_close($conn)
?>

6.MySqli执行批量处理代码如下

<?php
header("Content-type: text/html; charset=utf-8");
//MySqli操作MySql数据库(面向对象风格)操作事务

//1.创建MySQLi对象new MySQLi("主机","用户名","密码","数据库名");
$mysqli = new MySQLi("localhost","root","root","test");
if($mysqli->connect_error)
{
die("连接失败:".$mysqli->connect_error);
}
else
{
echo "连接成功<br/>";
}

//2.操作数据库,增,删,改
$sql="insert into user1(name,pwd,email,age) values('guif1',md5('123'),'guif1@yeah.net',21);";
$sql.="insert into user1(name,pwd,email,age) values('guif2',md5('123'),'guif2@yeah.net',22);";
$sql.="insert into user1(name,pwd,email,age) values('guif3',md5('123'),'guif3@yeah.net',23);";
$res = $mysqli->multi_query($sql);//执行批量处理

//3.处理结果
if(!$res)
{
echo "操作失败:".$mysqli->error;
}
else
{
//看看影响记录行数
if($mysqli->affected_rows>0)
{
echo "执行OK,数据行数:".$mysqli->affected_rows;
}
else
{
echo "没有影响函数";
}
}

//4.关闭连接
$mysqli->close();
?>


7.msqli处理事务

<?php
header("Content-type: text/html; charset=utf-8");
//MySqli操作MySql数据库(面向对象风格)操作事务

//1.创建MySQLi对象new MySQLi("主机","用户名","密码","数据库名");
$mysqli = new MySQLi("localhost","root","root","test");
if($mysqli->connect_error)
{
die("连接失败:".$mysqli->connect_error);
}
else
{
echo "连接成功<br/>";
}

//关闭自动提交
$mysqli->autocommit(false);

//2.操作数据库,增,删,改
$sql="insert into user1(name,pwd,email,age) values('guif_1',md5('123'),'guif1@yeah.net',21);";
$sql1="insert into user1(name,pwd,email,age) values('guif_2',md5('123'),'guif2@yeah.net',22);";
$sql2="insert into user1(name,pwd,email,age) values('guif_3',md5('123'),'guif3@yeah.net',23);";
$res = $mysqli->query($sql);
$res1 = $mysqli->query($sql1);
$res2 = $mysqli->query($sql2);

//3.处理结果
if(!$res||!$res1||!$res2)
{
//回滚事务
$mysqli->rollback();
echo "出现错误,事务回滚";
}
else
{
//提交事务
$mysqli->commit();
echo "事务提交成功";
}

//4.关闭连接
$mysqli->close();
?>