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 相关文章推荐
使用MaxMind 根据IP地址对访问者定位
Oct 09 PHP
PHP 之Section与Cookie使用总结
Sep 14 PHP
PHP数组循环操作详细介绍 附实例代码
Feb 03 PHP
php实现邮件发送并带有附件
Jan 24 PHP
PHP PDO fetch 模式各种参数的输出结果一览
Jan 07 PHP
PHP+shell实现多线程的方法
Jul 01 PHP
JavaScript实现删除电脑的关机键
Jul 26 PHP
YII2框架中使用yii.js实现的post请求
Apr 09 PHP
使用PHP连接数据库_实现用户数据的增删改查的整体操作示例
Sep 01 PHP
PHP创建XML接口示例
Jul 04 PHP
Yii Framework框架使用PHPExcel组件的方法示例
Jul 24 PHP
php多进程并发编程防止出现僵尸进程的方法分析
Feb 28 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
安健A254立体声随身听的分析与打磨
2021/03/02 无线电
PHP 5.0对象模型深度探索之属性和方法
2008/03/27 PHP
PHP+ajax 无刷新删除数据
2010/02/20 PHP
PHP中json_encode、json_decode与serialize、unserialize的性能测试分析
2010/06/09 PHP
PHP多进程编程之僵尸进程问题的理解
2017/10/15 PHP
详解php curl带有csrf-token验证模拟提交方法
2018/04/18 PHP
在IE下:float属性会影响offsetTop的取值
2006/12/22 Javascript
js鼠标滑过弹出层的定位IE6bug解决办法
2012/12/26 Javascript
获取内联和链接中的样式(js代码)
2013/04/11 Javascript
jQuery验证元素是否为空的两种常用方法
2015/03/17 Javascript
解决微信浏览器Javascript无法使用window.location.reload()刷新页面
2016/06/21 Javascript
Vue.js每天必学之指令系统与自定义指令
2016/09/07 Javascript
微信 java 实现js-sdk 图片上传下载完整流程
2016/10/21 Javascript
微信小程序--onShareAppMessage分享参数用处(页面分享)
2017/04/18 Javascript
Angualrjs 表单验证的两种方式(失去焦点验证和点击提交验证)
2017/05/09 Javascript
微信小程序实现顶部普通选项卡效果(非swiper)
2020/06/19 Javascript
Vue中使用matomo进行访问流量统计的实现
2019/11/05 Javascript
vue input标签通用指令校验的实现
2019/11/05 Javascript
js实现菜单跳转效果
2020/12/11 Javascript
Python类方法__init__和__del__构造、析构过程分析
2015/03/06 Python
Python HTTP客户端自定义Cookie实现实例
2017/04/28 Python
在Python程序员面试中被问的最多的10道题
2017/12/05 Python
Python图像处理之gif动态图的解析与合成操作详解
2018/12/30 Python
对Python3之进程池与回调函数的实例详解
2019/01/22 Python
详解python 模拟豆瓣登录(豆瓣6.0)
2019/04/18 Python
Python使用random模块生成随机数操作实例详解
2019/09/17 Python
Pycharm Git 设置方法
2020/09/15 Python
selenium如何定位span元素的实现
2021/01/13 Python
赫里福德的一家乡村零售商店:Philip Morris & Son
2017/06/25 全球购物
女士时装鞋:Chinese Laundry
2018/08/29 全球购物
简短证婚人证婚词
2014/01/09 职场文书
品牌转让协议书
2014/08/20 职场文书
颐和园英文导游词
2015/01/30 职场文书
小学生优秀作文范文(六篇)
2019/07/10 职场文书
nginx实现动静分离的方法示例
2021/11/07 Servers
详解在SQLPlus中实现上下键翻查历史命令的功能
2022/03/18 SQL Server