PHP连接MySQL数据库操作代码实例解析


Posted in PHP onJuly 11, 2020

方法一:普通方法(面向过程)

首先,先做出如下假设(也适用与方法二和方法三)

$username=your_name;
 $userpass=your_pass;
 $dbhost=localhost;
 $dbdatabase=your_database;

下面是关键步骤:

//生成一个连接
$db_connect=mysql_connect($dbhost,$username,$userpass) or die("Unable to connect to the MySQL!");

//选择一个需要操作的数据库
mysql_select_db($dbdatabase,$db_connect);

//执行MySQL语句
$result=mysql_query("SELECT id,name FROM user");

//提取数据
$row=mysql_fetch_row($result);

//关闭链接
mysql_close($db_connect);

代码注释已经说明了一切。不过这里还需要做一些补充。

①在mysql_connect()、mysql_select_db()等函数之前使用@(错误控制运算符),可以忽略掉系统产生的错误信息,然后我们用die()来自定义错误信息;

②提取数据的时候,除了上面的mysql_fetch_row,常见的还有mysql_fetch_assoc和mysql_fetch_array,具体差别请查阅我的另一篇随笔《PHP中mysql_fetch_row()、mysql_fetch_assoc()和mysql_fetch_array()的联系》;

③对于mysql_query()函数的返回值,如果执行的语句有返回值(如SELECT、SHOW、DESCRIBE等),则返回相应数据(成功时)或FALSE(失败时);如果执行的语句没有返回值(如DELETE、DROP、INSERT、UPDATE等),则返回TRUE(成功时)或FALSE(失败时)。

方法二:面向对象方法

其实这种方法和普通方法非常类似,只是把相应的函数换成了面向对象方法,直接看代码。

$db=new mysqli($dbhost,$username,$userpass,$dbdatabase);
if(mysqli_connect_error()){
  echo 'Could not connect to database.';
  exit;
}

$result=$db->query("SELECT id,name FROM user");
$row=$result->fetch_row();

这里用到的是mysqli,意思就是mysql的扩展,既可以通过面向过程的方式也可以通过面向对象的方式与数据库进行交互,唯一不同的是调用函数(对象方法)的方式不一样。

方法三:PDO方法

PDO其实是PHP Database Objects的缩写,中文即PHP数据库对象。它提供了一种统一的PHP与数据库交互的方法。

这是目前比较流行的一种连接数据库的方法。它的优势在于:只要正确提供数据源,余下对于数据库的基本操作都是一样的。也就是说,同一段代码既可以同MySQL交互,也可以和SQLite3交互,当然也可以和PostgreSQL进行交互,前提是你提供了正确的数据源。下面看一下连接MySQL的代码:

$dsn='mysql:host='.$dbhost.';dbname='.$dbdatabase.';'
$dbh=new PDO($dsn,$username,$userpass);

如果是SQLite3,直接使用下面的代码:

$dsn='sqlite3:"C:\sqlite\user.db"';
$dbh=new PDO($dsn);

如果是PostgreSQL,下面的代码能够对付:

$dsn='pgsql:host='.$dbhost.' port=5432 dbname='.$dbdatabase.' user='.$username.' password='.$userpass;
$dbh=new PDO($dsn);

跟数据库成功建立连接之后,下面就只需要从数据库获取数据或插入更新数据,实例代码如下:

$stmt=$dbh->query('SELECT id,name FROM user');
$row=$stmt->fetch();

至此,文章告一段落。当然,上面只是简单的介绍了一下PHP与数据库有关的最简单的操作,后面还有很多比如插入、排序、防止SQL注入等等一些方面的知识需要深入学习。希望有机会能够和大家一起探讨,共同进步。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
本地机apache配置基于域名的虚拟主机详解
Aug 10 PHP
ThinkPHP之import方法实例详解
Jun 20 PHP
PHP实现对站点内容外部链接的过滤方法
Sep 10 PHP
ThinkPHP结合AjaxFileUploader实现无刷新文件上传的方法
Oct 29 PHP
WordPress中Gravatar头像缓存到本地及相关优化的技巧
Dec 19 PHP
Symfony2使用第三方库Upload制作图片上传实例详解
Feb 04 PHP
PHP中常用的数组操作方法笔记整理
May 16 PHP
Yii中CGridView禁止列排序的设置方法
Jul 12 PHP
PHP环境搭建(php+Apache+mysql)
Nov 14 PHP
laravel5.4利用163邮箱发送邮件的步骤详解
Sep 22 PHP
php爬取天猫和淘宝商品数据
Feb 23 PHP
php实现登录页面的简单实例
Sep 29 PHP
PHP如何使用cURL实现Get和Post请求
Jul 11 #PHP
使用Rancher在K8S上部署高性能PHP应用程序的教程
Jul 10 #PHP
PHP实现简易用户登录系统
Jul 10 #PHP
PHP二维数组分页2种实现方法解析
Jul 09 #PHP
详解阿里云视频直播PHP-SDK接入教程
Jul 09 #PHP
PHP利用curl发送HTTP请求的实例代码
Jul 09 #PHP
PHP使用POP3读取邮箱接收邮件的示例代码
Jul 08 #PHP
You might like
php checkbox 取值详细说明
2010/08/19 PHP
Yii中CGridView关联表搜索排序方法实例详解
2014/12/03 PHP
php 判断字符串编码是utf-8 或gb2312实例
2016/11/01 PHP
Discuz不使用插件实现简单的打赏功能
2019/03/21 PHP
Javascript在IE和FireFox中的不同表现简析
2012/12/03 Javascript
使用DNode实现php和nodejs之间通信的简单实例
2015/07/06 NodeJs
基于jQuery的网页影音播放器jPlayer的基本使用教程
2016/03/08 Javascript
JavaScript中解决多浏览器兼容性23个问题的快速解决方法
2016/05/19 Javascript
jQuery树形控件zTree使用小结
2016/08/02 Javascript
vue2.0结合DataTable插件实现表格动态刷新的方法详解
2017/03/17 Javascript
ES6新特性之变量和字符串用法示例
2017/04/01 Javascript
JavaScript之Canvas_动力节点Java学院整理
2017/07/04 Javascript
VUE axios发送跨域请求需要注意的问题
2017/07/06 Javascript
vue2.0在没有dev-server.js下的本地数据配置方法
2018/02/23 Javascript
微信小程序实现天气预报功能
2018/07/18 Javascript
Vue resource三种请求格式和万能测试地址
2018/09/26 Javascript
带你使用webpack快速构建web项目的方法
2020/11/12 Javascript
js动态生成表格(节点操作)
2021/01/12 Javascript
[52:31]VP vs Serenity 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
在Python的Flask框架中实现单元测试的教程
2015/04/20 Python
Python入门教程之if语句的用法
2015/05/14 Python
Python实现简单的代理服务器
2015/07/25 Python
pycharm安装图文教程
2017/05/02 Python
python环境路径配置以及命令行运行脚本
2019/04/02 Python
Python HTTP下载文件并显示下载进度条功能的实现
2020/04/02 Python
大学生毕业求职简历的自我评价
2013/10/24 职场文书
自我鉴定范文
2013/11/10 职场文书
女方回门宴答谢词
2014/01/14 职场文书
致裁判员加油稿
2014/02/08 职场文书
团支部推优材料
2014/05/21 职场文书
上海世博会口号
2014/06/19 职场文书
2014年中学生检讨书大全
2014/10/09 职场文书
毕业生个人自荐书
2015/03/05 职场文书
2015年度内部审计工作总结
2015/05/20 职场文书
感动中国何玥观后感
2015/06/02 职场文书
七一晚会主持词
2015/06/29 职场文书