PHP5 操作MySQL数据库基础代码
1. 建立数据库连接
复制代码 代码如下:
$mysqli = new mysqli("localhost","root","","mydb");
?>
建立一个数据库连接需要四个参数,分别为数据库地址、数据库访问用户名、数据库访问密码、数据库名称。除了使用上面的mysqli对象的构造方法建立数据库连接外,还可以调用其connect方法建立数据库的连接。
复制代码 代码如下:
$mysqli = new mysqli();
$mysqli->connect("localhost","root","","mydb");
?>
还可以通过mysqli对象的构造方法建立数据连接,通过select_db方法指定要访问的数据库。
复制代码 代码如下:
$mysqli = new mysqli("localhost","root","");
$mysqli->select_db("mydb");
?>
通过mysqli对象的errno属性获取当前连接的错误号,如果当前连接没有任何错误,错误号返回为0。
复制代码 代码如下:
$mysqli = new mysqli("localhost","root","");
$mysqli->select_db("mydb");
if($mysqli->errno == 0) //判断当前连接是否成功
{
}
else
{
echo "The Connection is Error!";
exit();
}
?>
当然可以通过mysqli对象的error属性获取当前连接的错误信息,如果没有错误,返回“”。
复制代码 代码如下:
$mysqli = new mysqli("localhost","rootsss","");
$mysqli->select_db("mydb");
if($mysqli->errno == 0) //判断当前连接是否成功
{
}
else
{
echo $mysqli->error; //输出当前错误信息
exit();
}
?>
2.查询数据库
查询数据库可以使用mysqli对象的query方法,该方法返回查询数据库的结果集。
语法为:$mysqli->query(查询语句,查询模式);
查询模式有两种:
① MYSQLI_STORE_RESULT。将结果作为一个缓存集进行返回,这说明可以立即对整个结果集进行导航。该设置为默认设置。结果集查询出来后就放入内存中,这就代表如果结果集内数据量很大则会占用较多的内存。但是利用这种方式我们可以很容易知道一个查询返回了多少行记录或希望立即跳到结果集的某一行。
② MYSQLI_USE_RESULT。将结果集作为一个非缓存集返回。这就代表会根据需要从数据库服务器获取结果集,对于较大的结果集数据这样做可以提高性能。但是会导致很多对结果集的操作受到限制,比如获取查询行数等。
复制代码 代码如下:
$mysqli = new mysqli("localhost","root","");
$mysqli->select_db("mydb");
if($mysqli->errno == 0) //判断当前连接是否成功
{
$sql = "SELECT * FROM student";
$result = $mysqli->query($sql);
echo "Result row nums:".$result->num_rows."
"; //显示结果集数量
//迭代结果集
while(list($id,$name,$age,$address) = $result->fetch_row())
{
echo "$id : $name : $age : $address"."
";
}
}
else
{
echo $mysqli->error; //输出当前错误信息
exit();
}
?>
使用结果集对象的fetch_row方法获取结果集中每一行数据,每一行数据为一个关联数组,并使用list方法将其中的每个数据进行输出。还可以使用输出对象的方式将结果集中的每一行进行输出。
复制代码 代码如下:
$mysqli = new mysqli("localhost","root","");
$mysqli->select_db("mydb");
if($mysqli->errno == 0) //判断当前连接是否成功
{
$sql = "SELECT * FROM student";
$result = $mysqli->query($sql);
echo "Result row nums:".$result->num_rows."
"; //显示结果集数量
//迭代结果集
while($rowObject = $result->fetch_object())
{
echo "$rowObject->id : $rowObject->name : $rowObject->age : $rowObject->address"."
";
}
}
else
{
echo $mysqli->error; //输出当前错误信息
exit();
}
?>
其中使用fetch_object方法将每一行中的数据封装为一个对象,在上面的例子中该对象为$rowObject,数据库中每一列成为该对象的属性,通过该对象调用其属性名称就可以获取对应的字段值。比如获取学生姓名$rowObject->name。
还可以使用fetch_array方法将每一行数据返回为一个关联数组或是一个索引数组,或者同时返回关联数组和索引数组。fetch_array方法的模式参数来指定当前返回数组的模式:
① MYSQLI_ASSOC。返回关联数组,key为字段名,value为字段值。
② MYSQLI_NUM。返回索引数组,返回顺序和查询字段顺序相同。
③ MYSQLI_BOTH。同时返回关联数组和索引数组。默认设置。
复制代码 代码如下:
while($row = $result->fetch_array(MYSQLI_ASSOC)) //返回关联数组
{
echo $row['id']. $row['name'].$row['age'].$row['address']."
";
}
?>
或
复制代码 代码如下:
while($row = $result->fetch_array(MYSQLI_NUM)) //返回索引数组
{
echo $row[0]. $row[1].$row[2].$row[3]."
";
}
?>
3.释放内存
如果结果集中数据量巨大并且已经使用完毕后,结果集对象的free方法用于释放结果集占用的内存。一旦调用了free方法,结果集将不再可用。
复制代码 代码如下:
...
$result->free(); //释放内存
?>
4.添加、修改和删除操作
使用mysqli对象的query方法依然可以进行对数据库的添加、修改和删除操作,只不过是SQL语句的不同而已。我们以添加数据为例:
复制代码 代码如下:
$mysqli = new mysqli("localhost","root","");
$mysqli->select_db("mydb");
if($mysqli->errno == 0) //判断当前连接是否成功
{
$sql = "INSERT INTO student(id,name,age,address) VALUES('8','kay','23','xian')";
$result = $mysqli->query($sql);
echo $mysqli->affected_rows; //输出影响的行数
}
else
{
echo $mysqli->error; //输出当前错误信息
exit();
}
?>
调用mysqli对象的affected_rows属性可以获取影响的行数。
5.关闭数据库连接
当一个数据库连接使用完毕后调用mysqli对象的close方法将其关闭。
复制代码 代码如下:
...
$mysqli->close();
?>
6.使用绑定参数
在PHP中的绑定参数和Java中的预处理SQL是相同的原理,当反复执行一个SQL时,SQL的参数不定时可以使用绑定参数方式可以提升SQL的执行速度.
复制代码 代码如下:
$mysqli = new mysqli("localhost","root","");
$mysqli->select_db("mydb");
if($mysqli->errno == 0) //判断当前连接是否成功
{
$sql = "INSERT INTO student(id,name,age,address) VALUES(?,?,?,?)";
$stmt = $mysqli->stmt_init(); //创建预处理对象
$stmt->prepare($sql); //对SQL进行预处理
$stmt->bind_param("isis",$id,$name,$age,$address); //设置绑定的变量 第一个参数为变量的数据类型
for($i = 12;$i{
$id = $i + 1;
$name = "樊凯";
$age = 23;
$address = "xian";
$stmt->execute(); //执行SQL语句
}
echo $mysqli->affected_rows; //输出影响的行数
$stmt->close(); //释放预处理对象占用的内存
$mysqli->close(); //关闭数据库连接
}
else
{
echo $mysqli->error; //输出当前错误信息
exit();
}
?>
需要注意的是bind_param方法的第一个参数,该参数指定了后面的变量的数据类型,这些数据类型如下所示:
① i : 所有的Integer类型。
② d : 所有的double和float类型。
③ b : Blob类型。
④ s : 其他数据类型包括字符串。
7.结果绑定
结果绑定用于将查询结果和一些变量进行绑定。
复制代码 代码如下:
$mysqli = new mysqli("localhost","root","");
$mysqli->select_db("mydb");
if($mysqli->errno == 0) //判断当前连接是否成功
{
$sql = "SELECT * FROM student";
$stmt = $mysqli->stmt_init(); //创建预处理对象
$stmt->prepare($sql); //对SQL进行预处理
$stmt->bind_result($id,$name,$age,$address); //将查询结果字段绑定到变量中
$stmt->execute(); //执行SQL语句
while($stmt->fetch()) //fetch方法用于获取结果集中的每一行,并将相应字段值赋给变量
{
echo "$id : $name : $age : $address"."
";
}
$stmt->close(); //释放预处理对象占用的内存
$mysqli->close(); //关闭数据库连接
}
else
{
echo $mysqli->error; //输出当前错误信息
exit();
}
?>

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

PHP用于构建动态网站,其核心功能包括:1.生成动态内容,通过与数据库对接实时生成网页;2.处理用户交互和表单提交,验证输入并响应操作;3.管理会话和用户认证,提供个性化体验;4.优化性能和遵循最佳实践,提升网站效率和安全性。

PHP在电子商务、内容管理系统和API开发中广泛应用。1)电子商务:用于购物车功能和支付处理。2)内容管理系统:用于动态内容生成和用户管理。3)API开发:用于RESTfulAPI开发和API安全性。通过性能优化和最佳实践,PHP应用的效率和可维护性得以提升。

PHP主要是过程式编程,但也支持面向对象编程(OOP);Python支持多种范式,包括OOP、函数式和过程式编程。PHP适合web开发,Python适用于多种应用,如数据分析和机器学习。

PHP和Python各有优劣,选择取决于项目需求和个人偏好。1.PHP适合快速开发和维护大型Web应用。2.Python在数据科学和机器学习领域占据主导地位。

PHP在数据库操作和服务器端逻辑处理中使用MySQLi和PDO扩展进行数据库交互,并通过会话管理等功能处理服务器端逻辑。1)使用MySQLi或PDO连接数据库,执行SQL查询。2)通过会话管理等功能处理HTTP请求和用户状态。3)使用事务确保数据库操作的原子性。4)防止SQL注入,使用异常处理和关闭连接来调试。5)通过索引和缓存优化性能,编写可读性高的代码并进行错误处理。

在 Docker 中启动 MySQL 的过程包含以下步骤:拉取 MySQL 镜像创建并启动容器,设置根用户密码并映射端口验证连接创建数据库和用户授予对数据库的所有权限

MySQL在Web应用中的主要作用是存储和管理数据。1.MySQL高效处理用户信息、产品目录和交易记录等数据。2.通过SQL查询,开发者能从数据库提取信息生成动态内容。3.MySQL基于客户端-服务器模型工作,确保查询速度可接受。

PHP的核心优势包括易于学习、强大的web开发支持、丰富的库和框架、高性能和可扩展性、跨平台兼容性以及成本效益高。1)易于学习和使用,适合初学者;2)与web服务器集成好,支持多种数据库;3)拥有如Laravel等强大框架;4)通过优化可实现高性能;5)支持多种操作系统;6)开源,降低开发成本。
