热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

php中数据库连接方式pdo和mysqli对比分析,pdomysqli

php教程|php手册php,数据库连接方式,pdo,mysqli,pdophp教程-php手册php中数据库连接方式pdo和mysqli对比分析,pdomysqlijsonobj

php教程|php手册php中数据库连接方式pdo和mysqli对比分析,pdomysqli
php,数据库连接方式,pdo,mysqli,pdo
php教程-php手册
php中数据库连接方式pdo和mysqli对比分析,pdomysqli
jsonobject 源码下载,vscode 放大字体,ubuntu 获取键值,tomcat中设置jre,爬虫与采集,php 扩展 对象,seo网站优化方案报告答案,唯美聊天网站源码,贷款超市模板网lzw
1)总的比较
机关订餐管理系统源码,ubuntu是谁在开发,动物进口爬虫宠物,php配置文,saas建站seolzw
PDOMySQLi
数据库支持12种不同的数据库支持支持MySQL
APIOOPOOP + 过程
ConnectionEasyEasy
命名参数支持不支持
对象映射支持支持支持
预处理语句
(客户端)
支持不支持
性能
支持存储过程支持支持

2 连接方式

qq业务源码php,ubuntu .b 杀不掉,新浪爬虫软件下载,urlinfo php,网店seo引流lzw
先来看下两者连接数据库的方式:

代码如下:

// PDO
$pdo = new PDO(“mysql:host=localhost;dbname=database”, ‘username’, ‘password’);
// mysqli, 面向过程方式
$mysqli = mysqli_connect(‘localhost’,’username’,’password’,’database’);
// mysqli, 面向对象
$mysqli = new mysqli(‘localhost’,’username’,’password’,’database’);

3 数据库支持

PDO支持多种数据库,但MYSQLI只支持MYSQL

4 命名参数name parameter

PDO的方式:

代码如下:

$params = array(‘:username’ => ‘test’, ‘:email’ => $mail, ‘:last_login’ => time() – 3600);
$pdo->prepare(‘
SELECT * FROM users
WHERE username = :username
AND email = :email
AND last_login > :last_login’);

而MYSQLI则麻烦点,不支持这样,只能:

代码如下:

$query = $mysqli->prepare(‘
SELECT * FROM users
WHERE username = ?
AND email = ?
AND last_login > ?’);
$query->bind_param(‘sss’, ‘test’, $mail, time() – 3600);
$query->execute();

这样的话,一个个对问号的顺序,也比较麻烦,不大方便。

5 ORM映射的支持

比如有个类user,如下:

代码如下:

class User
{
public $id;
public $first_name;
public $last_name;
public function info()
{
return ‘#’ . $this->id . ‘: ‘ . $this->first_name . ‘ ‘ . $this->last_name;
}
}
$query = “SELECT id, first_name, last_name FROM users”;
// PDO
$result = $pdo->query($query);
$result->setFetchMode(PDO::FETCH_CLASS, ‘User’);
while ($user = $result->fetch())
{
echo $user->info() . “\n”;
}

MYSQLI用面向过程的方式:

代码如下:

if ($result = mysqli_query($mysqli, $query)) {
while ($user = mysqli_fetch_object($result, ‘User’)) {
echo $user->info().”\n”;
}
}

MYSQLI采用面向过程的方式:

代码如下:

// MySQLi, object oriented way
if ($result = $mysqli->query($query)) {
while ($user = $result->fetch_object(‘User’)) {
echo $user->info().”\n”;
}
}

6 防止SQL注入方面:

PDO 手工设置

代码如下:

$username = PDO::quote($_GET[‘username’]);
$pdo->query(“SELECT * FROM users WHERE username = $username”);

使用mysqli

代码如下:

$username = mysqli_real_escape_string($_GET[‘username’]);
$mysqli->query(“SELECT * FROM users WHERE username = ‘$username'”);

7 preparestament

PDO方式:

代码如下:

$pdo->prepare(‘SELECT * FROM users WHERE username = :username’);
$pdo->execute(array(‘:username’ => $_GET[‘username’]));

MYSQLI:

代码如下:

$query = $mysqli->prepare(‘SELECT * FROM users WHERE username = ?’);
$query->bind_param(‘s’, $_GET[‘username’]);
$query->execute();

小伙伴们是否通过本文对于PHP的2种链接方式PDO和mysqli有了新的认识了呢,希望本文能对大家有所帮助。


推荐阅读
  • MySQL中的Anemometer使用指南
    本文详细介绍了如何在MySQL环境中部署和使用Anemometer,以帮助开发者有效监控和优化慢查询性能。通过本文,您将了解从环境准备到具体配置的全过程。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 解决PHP与MySQL连接时出现500错误的方法
    本文详细探讨了当使用PHP连接MySQL数据库时遇到500内部服务器错误的多种解决方案,提供了详尽的操作步骤和专业建议。无论是初学者还是有经验的开发者,都能从中受益。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 当我在命令行登录MySQL后,无法访问任何依赖数据库连接的PHP应用。此问题每次都会出现。以下是复现问题的具体步骤及解决方案。 ... [详细]
  • 本文详细介绍了如何通过多种编程语言(如PHP、JSP)实现网站与MySQL数据库的连接,包括创建数据库、表的基本操作,以及数据的读取和写入方法。 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • 在Linux系统上构建Web服务器的详细步骤
    本文详细介绍了如何在Linux系统上搭建Web服务器的过程,包括安装Apache、PHP和MySQL等关键组件,以及遇到的一些常见问题及其解决方案。 ... [详细]
  • 本文将详细介绍如何在ThinkPHP6框架中实现多数据库的部署,包括读写分离的策略,以及如何通过负载均衡和MySQL同步技术优化数据库性能。 ... [详细]
  • 本文介绍如何在Windows Forms应用程序中使用C#实现DataGridView的多列排序功能,包括升序和降序排序。 ... [详细]
  • 作为一名Docker初学者,我已经成功创建了一个基于Alpine Linux 3.4的Docker镜像,该镜像安装了MySQL、Apache和PHP及其相关扩展。本文将探讨如何确保MySQL数据在Docker容器重启后仍能被保留。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • MySQL中枚举类型的所有可能值获取方法
    本文介绍了一种在MySQL数据库中查询枚举(ENUM)类型字段所有可能取值的方法,帮助开发者更好地理解和利用这一数据类型。 ... [详细]
author-avatar
mobiledu2502923487
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有