PHP5 操作MySQL数据库基础代码


Posted in PHP onSeptember 29, 2009

1. 建立数据库连接

<?php 
$mysqli = new mysqli("localhost","root","","mydb"); 
?>

建立一个数据库连接需要四个参数,分别为数据库地址、数据库访问用户名、数据库访问密码、数据库名称。除了使用上面的mysqli对象的构造方法建立数据库连接外,还可以调用其connect方法建立数据库的连接。
<?php 
$mysqli = new mysqli(); 
$mysqli->connect("localhost","root","","mydb"); 
?>

还可以通过mysqli对象的构造方法建立数据连接,通过select_db方法指定要访问的数据库。
<?php 
$mysqli = new mysqli("localhost","root",""); 
$mysqli->select_db("mydb"); 
?>

通过mysqli对象的errno属性获取当前连接的错误号,如果当前连接没有任何错误,错误号返回为0。
<?php 
$mysqli = new mysqli("localhost","root",""); 
$mysqli->select_db("mydb"); 
if($mysqli->errno == 0) //判断当前连接是否成功 
{ 
} 
else 
{ 
echo "The Connection is Error!"; 
exit(); 
} 
?>

当然可以通过mysqli对象的error属性获取当前连接的错误信息,如果没有错误,返回“”。
<?php 
$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。将结果集作为一个非缓存集返回。这就代表会根据需要从数据库服务器获取结果集,对于较大的结果集数据这样做可以提高性能。但是会导致很多对结果集的操作受到限制,比如获取查询行数等。
<?php 
$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."<br>"; //显示结果集数量 
//迭代结果集 
while(list($id,$name,$age,$address) = $result->fetch_row()) 
{ 
echo "$id : $name : $age : $address"."<br>"; 
} 
} 
else 
{ 
echo $mysqli->error; //输出当前错误信息 
exit(); 
} 
?>

使用结果集对象的fetch_row方法获取结果集中每一行数据,每一行数据为一个关联数组,并使用list方法将其中的每个数据进行输出。还可以使用输出对象的方式将结果集中的每一行进行输出。
<?php 
$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."<br>"; //显示结果集数量 
//迭代结果集 
while($rowObject = $result->fetch_object()) 
{ 
echo "$rowObject->id : $rowObject->name : $rowObject->age : $rowObject->address"."<br>"; 
} 
} 
else 
{ 
echo $mysqli->error; //输出当前错误信息 
exit(); 
} 
?>

其中使用fetch_object方法将每一行中的数据封装为一个对象,在上面的例子中该对象为$rowObject,数据库中每一列成为该对象的属性,通过该对象调用其属性名称就可以获取对应的字段值。比如获取学生姓名$rowObject->name。
还可以使用fetch_array方法将每一行数据返回为一个关联数组或是一个索引数组,或者同时返回关联数组和索引数组。fetch_array方法的模式参数来指定当前返回数组的模式:
① MYSQLI_ASSOC。返回关联数组,key为字段名,value为字段值。
② MYSQLI_NUM。返回索引数组,返回顺序和查询字段顺序相同。
③ MYSQLI_BOTH。同时返回关联数组和索引数组。默认设置。
<?php 
while($row = $result->fetch_array(MYSQLI_ASSOC)) //返回关联数组 
{ 
echo $row['id']. $row['name'].$row['age'].$row['address']."<br>"; 
} 
?>


<?php 
while($row = $result->fetch_array(MYSQLI_NUM)) //返回索引数组 
{ 
echo $row[0]. $row[1].$row[2].$row[3]."<br>"; 
} 
?>

3.释放内存
如果结果集中数据量巨大并且已经使用完毕后,结果集对象的free方法用于释放结果集占用的内存。一旦调用了free方法,结果集将不再可用。
<?php 
... 
$result->free(); //释放内存 
?>

4.添加、修改和删除操作
使用mysqli对象的query方法依然可以进行对数据库的添加、修改和删除操作,只不过是SQL语句的不同而已。我们以添加数据为例:
<?php 
$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方法将其关闭。
<?php 
... 
$mysqli->close(); 
?>

6.使用绑定参数
在PHP中的绑定参数和Java中的预处理SQL是相同的原理,当反复执行一个SQL时,SQL的参数不定时可以使用绑定参数方式可以提升SQL的执行速度.
<?php 
$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<100;$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.结果绑定
结果绑定用于将查询结果和一些变量进行绑定。
<?php 
$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"."<br>"; 
} 
$stmt->close(); //释放预处理对象占用的内存 
$mysqli->close(); //关闭数据库连接 
} 
else 
{ 
echo $mysqli->error; //输出当前错误信息 
exit(); 
} 
?>
PHP 相关文章推荐
一些使用频率比较高的php函数
Oct 03 PHP
超级简单的php+mysql留言本源码
Nov 11 PHP
PHP IPV6正则表达式验证代码
Feb 16 PHP
PHP学习之数组的定义和填充
Apr 17 PHP
PHP新手入门学习方法
May 08 PHP
php入门学习知识点三 PHP上传
Jul 14 PHP
php中将汉字转换成拼音的函数代码
Sep 08 PHP
php环境套包 dedeampz 伪静态设置示例
Mar 26 PHP
php获取mysql字段名称和其它信息的例子
Apr 14 PHP
php去掉URL网址中带有PHPSESSID的配置方法
Jul 08 PHP
php5.3后静态绑定用法详解
Nov 11 PHP
PHP date()格式MySQL中插入datetime方法
Jan 29 PHP
PHP 字符截取 解决中文的截取问题,不用mb系列
Sep 29 #PHP
php 生成饼图 三维饼图
Sep 28 #PHP
php 不同编码下的字符串长度区分
Sep 26 #PHP
php 应用程序安全防范技术研究
Sep 25 #PHP
从Web查询数据库之PHP与MySQL篇
Sep 25 #PHP
php 服务器调试 Zend Debugger 的安装教程
Sep 25 #PHP
php 代码优化的42条建议 推荐
Sep 25 #PHP
You might like
从Web查询数据库之PHP与MySQL篇
2009/09/25 PHP
PHP贪婪算法解决0-1背包问题实例分析
2015/03/23 PHP
php表单文件iframe异步上传实例讲解
2017/07/26 PHP
PHP实现给定一列字符,生成指定长度的所有可能组合示例
2019/06/22 PHP
php进程(线程)通信基础之System V共享内存简单实例分析
2019/11/09 PHP
javascript parseInt() 函数的进制转换注意细节
2013/01/08 Javascript
bootstrap table实例详解
2017/01/06 Javascript
JavaScript实现图像模糊化的方法实例
2017/01/15 Javascript
微信小程序实现给循环列表添加点击样式实例
2017/04/26 Javascript
iview中Select 选择器多选校验方法
2018/03/15 Javascript
bootstrap table.js动态填充单元格数据的多种方法
2019/07/18 Javascript
Vue2.X和Vue3.0数据响应原理变化的区别
2019/11/07 Javascript
js实现Element中input组件的部分功能并封装成组件(实例代码)
2021/03/02 Javascript
[03:37]2014DOTA2国际邀请赛 主赛事第一日胜者组TOPPLAY
2014/07/19 DOTA
Python读写unicode文件的方法
2015/07/10 Python
基于Django filter中用contains和icontains的区别(详解)
2017/12/12 Python
使用python进行文本预处理和提取特征的实例
2018/06/05 Python
Python设计模式之备忘录模式原理与用法详解
2019/01/15 Python
Python增强赋值和共享引用注意事项小结
2019/05/28 Python
使用python制作游戏下载进度条的代码(程序说明见注释)
2019/10/24 Python
Django Xadmin多对多字段过滤实例
2020/04/07 Python
Pycharm操作Git及GitHub的步骤详解
2020/10/27 Python
HTML5 Canvas图像模糊完美解决办法
2018/02/06 HTML / CSS
医学院四年学习生活的自我评价
2013/11/06 职场文书
酒店保洁主管岗位职责
2013/11/28 职场文书
技校毕业生个人学习的自我评价
2014/02/21 职场文书
公司年会策划方案
2014/05/17 职场文书
行政监察建议书
2014/05/19 职场文书
趵突泉导游词
2015/02/03 职场文书
旷工辞退通知书
2015/04/17 职场文书
2015年社区矫正工作总结
2015/04/21 职场文书
2016年村党支部公开承诺书
2016/03/24 职场文书
使用Python脚本对GiteePages进行一键部署的使用说明
2021/05/27 Python
python异步的ASGI与Fast Api实现
2021/07/16 Python
安装Windows Server 2012 R2企业版操作系统并设置好相关参数
2022/04/29 Servers
redis protocol通信协议及使用详解
2022/07/15 Redis