首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >新的mysqli vs mysqli_connect

新的mysqli vs mysqli_connect
EN

Stack Overflow用户
提问于 2013-03-30 00:51:22
回答 3查看 49.6K关注 0票数 40

新的mysqlimysqli_connect有什么不同?我知道执行查询是不同的;

例如:mysqli->query()mysqli_query()

为什么会有两种不同的类型,有什么不同的需要吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-03-30 00:52:27

一个是过程化风格的编程,另一个是OOP风格的编程。两者都有相同的用途;Open a new connection to the MySQL server

OOP风格用法

代码语言:javascript
复制
$mysqli = new mysqli('localhost', 'my_user', 'my_password', 'my_db');

Procedural样式用法

代码语言:javascript
复制
$link = mysqli_connect('localhost', 'my_user', 'my_password', 'my_db');

参考:PHP Manual

票数 54
EN

Stack Overflow用户

发布于 2013-03-30 00:57:06

在@Hanky Panky上。此外,我还添加了PHP文档:

http://www.php.net/manual/en/mysqli.construct.php

备注:

仅限OO语法:如果连接失败,仍会返回对象。要检查连接是否失败,请使用mysqli_connect_error()函数或mysqli->connect_error属性,如前面的示例所示。

所以错误处理只是一个区别。

票数 14
EN

Stack Overflow用户

发布于 2020-01-20 09:54:29

我刚刚发现了两者之间一个微妙但有趣的区别。

如果您遇到mysqli_connect (如$connection = mysqli_connect())的连接错误,则不会向$connection变量返回任何mysql信息。因此,您将无法使用myqli_errno($connection)识别错误。

但是,如果您在使用新的mysqli (如$connection = new mysqli())时遇到连接错误,则会返回mysql信息,您可以使用$connection->connect_errno检查错误。

知道了这一点,我会选择新的mysqli。

哦..。我刚看到Rick Buczynski的回复,在发帖后意识到我在重复他说的话,但他的回复更有信息量。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15707696

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档