TalkPHP
 
 
Account Login
Latest Articles
» The basic usage of PHPTAL, a XML/XHTML template library for PHP
» Vulnerable methods and the areas they are commonly trusted in.
» Simple way to protect a form from bot
» The Basics On: How Session Stealing Works
» How to keep your forms from double posting data
IRC Channel
IRC Speech Bubble Join the friendly bunch on IRC...
(#TalkPHP on Freenode)

...Also available via a web interface.

See this thread for information on the TalkPHP Free Hugs Initiative™. Subject to availability.
Associates
Associates
CSS Tutorials
Reply
 
LinkBack Thread Tools Search this Thread Display Modes
Old 09-19-2007, 08:11 PM   #1 (permalink)
The Frequenter
Prolific Welcomer Upcoming Programmer 
 
Join Date: Sep 2007
Posts: 360
Thanks: 24
Haris is on a distinguished road
Default How to check if a table exists?

How to check if a table exists in the database? I want to execute the function in my class which will create the table if only the table doesn't exists already.

EDIT:

As far as I know, I can accomplish it in this way:

PHP Code:
        /*
         * Summary:     Creats default database table for administration panel
         */
        
        
class Admins extends Database{
        
        public function 
__construct(){
            
$szSQL "SELECT * FROM admins";
            
$szResult $this->execute($szSQL);
            
$iNumRows mysql_num_rows($szResult);
            if(
$iNumRows == 0){
            
$szSQL 'CREATE TABLE `classes`.`admins` (
                        `id` INT( 11 ) NOT NULL AUTO_INCREMENT ,
                        `user` VARCHAR( 225 ) NOT NULL ,
                        `pass` VARCHAR( 225 ) NOT NULL ,
                        `rank` INT( 1 ) NOT NULL ,
                        UNIQUE (`id`)
                        ) ENGINE = InnoDB '
;
            @
$this->execute($szSQL);
            }
        } 
Mission failed or accomplished?
Haris is offline  
Reply With Quote
Old 09-19-2007, 08:32 PM   #2 (permalink)
La Vida es Sueño
Advanced Programmer Top Contributor 
 
Wildhoney's Avatar
 
Join Date: Sep 2007
Location: Oldham
Posts: 2,280
Thanks: 90
Wildhoney is on a distinguished road
Default

Code:
CREATE TABLE IF NOT EXISTS `classes`.`admins`
__________________
The man who comes back through the Door in the Wall will never be quite the same as the man who went out.
Send a message via AIM to Wildhoney Send a message via MSN to Wildhoney Send a message via Yahoo to Wildhoney
Wildhoney is offline  
Reply With Quote
Old 09-19-2007, 08:34 PM   #3 (permalink)
The Frequenter
Prolific Welcomer Upcoming Programmer 
 
Join Date: Sep 2007
Posts: 360
Thanks: 24
Haris is on a distinguished road
Default

Thanks, it saves 5 lines of code.
Haris is offline  
Reply With Quote
Old 09-19-2007, 08:42 PM   #4 (permalink)
The Frequenter
Prolific Welcomer Upcoming Programmer 
 
Join Date: Sep 2007
Posts: 360
Thanks: 24
Haris is on a distinguished road
Default

Quote:
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '\r\n `id` INT( 11 ) NOT NULL AUTO_INCREMENT ,\r\n `user` VARCHAR( 225 ' at line 1
Now what's wrong with syntax? :(
Haris is offline  
Reply With Quote
Old 09-19-2007, 08:43 PM   #5 (permalink)
The Prestige
Upcoming Programmer Inquisitive 
 
Tanax's Avatar
 
Join Date: Sep 2007
Location: Sweden, Stockholm
Posts: 1,080
Thanks: 115
Tanax is on a distinguished road
Default

PHP Code:
CREATE TABLE `classes`.`admins
What does that do? Creates 2 tables? :S
Sorry for noobie question..
Tanax is offline  
Reply With Quote
Old 09-19-2007, 08:45 PM   #6 (permalink)
La Vida es Sueño
Advanced Programmer Top Contributor 
 
Wildhoney's Avatar
 
Join Date: Sep 2007
Location: Oldham
Posts: 2,280
Thanks: 90
Wildhoney is on a distinguished road
Default

That works fine for me on localhost. Try doing just:

Code:
CREATE TABLE `classes` 	(
				`id` INT( 11 ) NOT NULL AUTO_INCREMENT ,
				`user` VARCHAR( 225 ) NOT NULL ,
				`pass` VARCHAR( 225 ) NOT NULL ,
				`rank` INT( 1 ) NOT NULL ,
				UNIQUE (`id`)
                        ) ENGINE = InnoDB
__________________
The man who comes back through the Door in the Wall will never be quite the same as the man who went out.
Send a message via AIM to Wildhoney Send a message via MSN to Wildhoney Send a message via Yahoo to Wildhoney
Wildhoney is offline  
Reply With Quote
Old 09-19-2007, 08:49 PM   #7 (permalink)
The Frequenter
Prolific Welcomer Upcoming Programmer 
 
Join Date: Sep 2007
Posts: 360
Thanks: 24
Haris is on a distinguished road
Default

It was due to my queries automatically escaping. How can I avoid this error? :S

I know I can remove the escaping and do it manually but that's not the safest option?

PHP Code:
        public function execute($szSQL){
            
$szSQL mysql_real_escape_string($szSQL);
            
$szResult mysql_query($szSQL) or die(mysql_error());
            return 
$szResult;
        } 
Haris is offline  
Reply With Quote
Old 09-19-2007, 08:58 PM   #8 (permalink)
La Vida es Sueño
Advanced Programmer Top Contributor 
 
Wildhoney's Avatar
 
Join Date: Sep 2007
Location: Oldham
Posts: 2,280
Thanks: 90
Wildhoney is on a distinguished road
Default

You don't want to escape your $szSQL variable. You ONLY escape user input.
__________________
The man who comes back through the Door in the Wall will never be quite the same as the man who went out.
Send a message via AIM to Wildhoney Send a message via MSN to Wildhoney Send a message via Yahoo to Wildhoney
Wildhoney is offline  
Reply With Quote
Old 09-19-2007, 09:04 PM   #9 (permalink)
Moderateur
RegEx Guru PHP Guru Top Contributor Advanced Programmer 
 
Salathe's Avatar
 
Join Date: Apr 2007
Posts: 1,393
Thanks: 5
Salathe is on a distinguished road
Default

To to clarify Wildhoney's post. You don't want to mysql_real_escape_string the entire SQL query all in one go. It is only intended to escape portions of user input (generally the values of columns).

PHP Code:
$szTitle = ...  (from $_POST$_GETetc?)
$szSafeSQL sprintf('SELECT * FROM myTable WHERE title = "%s"'
                     
mysql_real_escape_query($szTitle)); 
Salathe is offline  
Reply With Quote
Reply



Currently Active Users Viewing This Thread: 1 (0 members and 1 guests)
 
Thread Tools Search this Thread
Search this Thread:

Advanced Search
Display Modes

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

vB code is On
Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On


All times are GMT. The time now is 02:20 PM.

 
     

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2013, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.1.0
Inactive Reminders By Icora Web Design