开发者

mysqli, OOP vs Procedural

开发者 https://www.devze.com 2023-03-10 01:40 出处:网络
I just saw this for the first time.I had no idea you can instantiate a mysqli class by doing something like

I just saw this for the first time. I had no idea you can instantiate a mysqli class by doing something like

new mysqli( $host, $username, $password, $db );

This is brand new to me...Every tutorial I have seen online or in books when connecting to database does something like this:

$conn = mysqli_connec开发者_运维知识库t( $host, $username, $password, $db );

if ( !$conn ) {
    die( 'Sorry, could not connect');
}

Is there a reason why most tutorials do it the procedural way? Even in tutorials I have seen on creating a separate database class, tell me to use the procedural style code...

What's the difference with mysqli procedural vs oop? Is there any? Do I have to install any extensions of some kind or can I just start using in my code? Total newb here, so not really sure.

Also, when is it a good idea to use PDO vs mysqli? Is PDO used most commonly by developers that work on large scale Enterprise applications? Or is simply a matter of preference.

Thanks for any help...

learning php has quickly become addictive...I just want to know more and more.


99% of PHP tutorials on the internet are outdated, advocate terrible code or are written by people that probably shouldn't teach PHP (and commonly all of the above). You should find the handful of good ones.

PDO is generally favoured over mysqli by developers, including me. For one, it can handle many more databases than just MySQL.


To answer your questions from the practical point of view

Is there a reason why most tutorials do it the procedural way?

Enough to say that reasons are not technology related.

What's the difference with mysqli procedural vs oop? Is there any?

No.

Do I have to install any extensions

No (save for mysqli itself, of course).

Also, when is it a good idea to use PDO?

Yes. As a matter of fact PDO would be the only sane choice.

You have to understand that set of mysqli functions is just a low level API, not intended to be used as is. One have to implement a wrapper upon mysqli, and then use this wrapper's methods. While PDO is such a wrapper already, offering help with performing many tasks. I wrote a guide on PDO, that emphasizes its benefits and discloses some superstitions, where, I hope, you will find answers for many questions you surely have.


Most mysqli_* functions are aliases of the object methods (PHP internally allows that easily with an C macro, so many extensions use that approach). But the availability is also for familiarity, so users of the old mysql functions have an easier time adopting to the new interface. Using the OOP or procedural interface is really just style/preference.

PDO is generally preferred nowadays, but it doesn't provide many mysql-specific features. So there might still be some use cases for the mysqli extension.

0

精彩评论

暂无评论...
验证码 换一张
取 消