Naez Posted March 3, 2008 Share Posted March 3, 2008 [code=php:0]class dbconn { // SNIP // just basic DB stuff } $db = new dbconn("localhost","lala","****","db"); // when the function is in comments, it works!" /*function getsomething() {*/ $query = "SELECT * FROM testtable"; $result = $db->query($query); // excute query with $result as a handle $numrows = $db->num_rows($result); // Get the number of rows returned or affected while($row = $db->fetch_array($result)) { echo $row['ID'] . ' - ' . $row['information'] . '<br>'; } // echo some data in a loop echo $numrows . 'rows Returned from ' . $query . '<br>'; echo $db->return_query_num() . " Queries"; /* } getsomething(); */ [/code] Basically I can't use the following as a function (or eventually a class). In my project I maintain an open database connection the entire time, and it works fine until I try to use the $db-> within a function or other class, then stuff gets screwed up and says this: Fatal error: Call to a member function query() on a non-object in / on line W/E Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/ Share on other sites More sharing options...
trq Posted March 3, 2008 Share Posted March 3, 2008 You need to pass the $db object into any function that uses it. Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/#findComment-482254 Share on other sites More sharing options...
Naez Posted March 3, 2008 Author Share Posted March 3, 2008 Could you show me a quick example of how to accomplish that? Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/#findComment-482258 Share on other sites More sharing options...
Daniel0 Posted March 3, 2008 Share Posted March 3, 2008 In PHP there are three scopes: global scope, class/object scope and function scope. The variable $db you define is in the global scope so you can only access it there, you can cheat and use the global keyword inside a function to bring it into the function scope, but you should not do that. Normally you cannot access things from a different scope that you are in (except for the class scope depending on the property's visibility (public, protected or private)). There are a few so-called superglobals which can be accessed from anywhere, an example could be $_GET and $_POST. To access things from the global scope within the function scope (and vice-versa) you'll have to find a way to bring the variable in there, that could be passing it as an argument. Also see: http://en.wikipedia.org/wiki/Scope_(programming) and http://php.net/variables.scope Could you show me a quick example of how to accomplish that? function getsomething($db) { /* ... */ } getsomething($db); Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/#findComment-482263 Share on other sites More sharing options...
Naez Posted March 3, 2008 Author Share Posted March 3, 2008 Thanks, that really helped alot. Do I have to call the database in the opening of every "function($db)" like that within the class that uses it? Or should I add $this->db = $db; to my constructor, and then later call functions like $this->db->query($query); ? Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/#findComment-482269 Share on other sites More sharing options...
Daniel0 Posted March 3, 2008 Share Posted March 3, 2008 If you're going to use the $db object a lot inside a class then it would perhaps be a good idea to store a reference in a property like you said. You could then pass it to the constructor and set it there. If you're just going to use it in one specific method then just pass it to that method. Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/#findComment-482296 Share on other sites More sharing options...
aschk Posted March 3, 2008 Share Posted March 3, 2008 Might be worth considering turning your "db" class into a singleton. Which can then be called from anywhere. function myfunc(){ $db = Database::instance(); // singleton initialisation. $db->query("blah blah blah"); ...// etc } Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/#findComment-482318 Share on other sites More sharing options...
Daniel0 Posted March 3, 2008 Share Posted March 3, 2008 Then what if he would like another connection? You should only use a singleton on things that should only be instantiated one time. Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/#findComment-482324 Share on other sites More sharing options...
Naez Posted March 4, 2008 Author Share Posted March 4, 2008 Hey I can also do function some_function($arg1, $argv) { global $db; $db->dostuff(); } that's what phpbb uses (which is what my project is centered around) Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/#findComment-482503 Share on other sites More sharing options...
Daniel0 Posted March 4, 2008 Share Posted March 4, 2008 That's a bad idea. You'll eventually run into problems are you are coupling your things too tight and making all the things dependent on each other. Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/#findComment-482634 Share on other sites More sharing options...
aschk Posted March 4, 2008 Share Posted March 4, 2008 Also bear in mind that you might choose to rename that variable in the future, from $db to $database, meaning ANY places where you have used $db would need to be changed. Also, because $db is being used globally there is the possibility that it can be overwritten with ANY variable type in the future, causing failure in other parts of your application. Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/#findComment-482652 Share on other sites More sharing options...
Daniel0 Posted March 4, 2008 Share Posted March 4, 2008 Furthermore, third party code might interfere with the global variables... Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/#findComment-482654 Share on other sites More sharing options...
aschk Posted March 4, 2008 Share Posted March 4, 2008 Seconded, good call Daniel, i didn't think of that. Beware the 3rd party code of DOOOOOM that users global variables! Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/#findComment-482658 Share on other sites More sharing options...
maexus Posted June 15, 2008 Share Posted June 15, 2008 That's a bad idea. You'll eventually run into problems are you are coupling your things too tight and making all the things dependent on each other. I was going to post a new topic about this but figured I would use this one to reduce the noise. If you reference your db object or create a db object inside of a class you are working on, doesn't that tie that class to your db class? That's the trouble I'm running into with the framework/library I'm writing. I want objects to be able to interact with the database but not directly or in a means that that the my db class is required for the object to work. I remember someone mentioning using a data mapping class but I can't find that thread. Can someone point me in the right direction? Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/#findComment-565965 Share on other sites More sharing options...
keeB Posted June 15, 2008 Share Posted June 15, 2008 No. In that case you use an interface. http://en.wikipedia.org/wiki/Interface_%28computer_science%29 <?php interface Database { function query($q); } public class MySQLDatabaseImpl implements Database { //must define $query; } class foo { public function doSomethingWithADatabase(Database $db) { //enforce usage of Database class return $db->query("select lol from mymom"); // you know $db will have a query method, and your object doesn't actually care what it does. } } ?> Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/#findComment-566042 Share on other sites More sharing options...
maexus Posted June 15, 2008 Share Posted June 15, 2008 Well, I was more thinking about how that foo class should be functional without relying on the db class. It's requesting and getting data from *insert data source* so if my friend wanted to drop foo into his app, he could use his db object as the data source without having to modify foo. So basically, foo is depenant on a data source but not a specific one. Is there a design pattern or a way of doing this? I want to keep objects seperate but have them work together. Like puzzle pieces. Quote Link to comment https://forums.phpfreaks.com/topic/94145-how-to-call-a-pre-existing-object-from-within-a-class/#findComment-566053 Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.