热门标签 | 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有了新的认识了呢,希望本文能对大家有所帮助。


推荐阅读
  • 深入分析十大PHP开发框架
    随着PHP技术的发展,各类开发框架层出不穷,成为了开发者们热议的话题。本文将详细介绍并对比十款主流的PHP开发框架,旨在帮助开发者根据自身需求选择最合适的工具。 ... [详细]
  • 本文将详细介绍如何在ThinkPHP6框架中实现多数据库的部署,包括读写分离的策略,以及如何通过负载均衡和MySQL同步技术优化数据库性能。 ... [详细]
  • 本文档详细介绍了Scrapy框架中的信号系统,包括如何利用信号来增强爬虫的功能性和灵活性,以及各个内置信号的具体用途和参数。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • Ralph的Kubernetes进阶之旅:集群架构与对象解析
    本文深入探讨了Kubernetes集群的架构和核心对象,详细介绍了Pod、Service、Volume等基本组件,以及更高层次的抽象如Deployment、StatefulSet等,帮助读者全面理解Kubernetes的工作原理。 ... [详细]
  • 作为一名 Ember.js 新手,了解如何在路由和模型中正确加载 JSON 数据是至关重要的。本文将探讨两者之间的差异,并提供实用的建议。 ... [详细]
  • Netflix利用Druid实现高效实时数据分析
    本文探讨了全球领先的在线娱乐公司Netflix如何通过采用Apache Druid,实现了高效的数据采集、处理和实时分析,从而显著提升了用户体验和业务决策的准确性。文章详细介绍了Netflix在系统架构、数据摄取、管理和查询方面的实践,并展示了Druid在大规模数据处理中的卓越性能。 ... [详细]
  • 深入理解Lucene搜索机制
    本文旨在帮助读者全面掌握Lucene搜索的编写步骤、核心API及其应用。通过详细解析Lucene的基本查询和查询解析器的使用方法,结合架构图和代码示例,带领读者深入了解Lucene搜索的工作流程。 ... [详细]
  • 在PHP后端开发中遇到一个难题:通过第三方类文件发送短信功能返回的JSON字符串无法解析。本文将探讨可能的原因并提供解决方案。 ... [详细]
  • 使用JS、HTML5和C3创建自定义弹出窗口
    本文介绍如何结合JavaScript、HTML5和C3.js来实现一个功能丰富的自定义弹出窗口。通过具体的代码示例,详细讲解了实现过程中的关键步骤和技术要点。 ... [详细]
  • MySQL Debug 模式的实现与应用
    本文详细介绍了如何启用和使用 MySQL 的调试模式,包括编译选项、环境变量配置以及调试信息的解析。通过实际案例展示了如何利用调试模式解决客户端无法连接服务器的问题。 ... [详细]
  • 本文探讨了如何在编程中正确处理包含空数组的 JSON 对象,提供了详细的代码示例和解决方案。 ... [详细]
  • 本文详细介绍了中央电视台电影频道的节目预告,并通过专业工具分析了其加载方式,确保用户能够获取最准确的电视节目信息。 ... [详细]
  • 在Linux系统上构建Web服务器的详细步骤
    本文详细介绍了如何在Linux系统上搭建Web服务器的过程,包括安装Apache、PHP和MySQL等关键组件,以及遇到的一些常见问题及其解决方案。 ... [详细]
  • Java EE CDI:解决依赖关系冲突的实例
    在本教程中,我们将探讨如何在Java EE的CDI(上下文和依赖注入)框架中有效解决依赖关系的冲突问题。通过学习如何使用限定符,您将能够为应用程序的不同客户端提供多种接口实现,并确保每个客户端都能正确调用其所需的实现。 ... [详细]
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社区 版权所有