Home of Testers Forum Index Home of Testers
Nothing else, only testing!
Welcome to our Classroom!
 
 FAQFAQ   SearchSearch   MemberlistMemberlist   UsergroupsUsergroups   RegisterRegister 
 ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

Use PHP and MySQL to Create Database and Tables

 
Post new topic   Reply to topic    Home of Testers Forum Index -> Skills
View previous topic :: View next topic  
Author Message
BigPanda



Joined: 29 May 2008
Posts: 50

PostPosted: Tue Nov 25, 2008 6:32 am    Post subject: Use PHP and MySQL to Create Database and Tables Reply with quote

PHP MySQL Create Database and Tables

--------------------------------------------------------------------------------

A database holds one or multiple tables.


--------------------------------------------------------------------------------

Create a Database
The CREATE DATABASE statement is used to create a database in MySQL.

Syntax
Code:
CREATE DATABASE database_name


To learn more about SQL, please visit our SQL tutorial.
To get PHP to execute the statement above we must use the mysql_query() function. This function is used to send a query or command to a MySQL connection.

Example
The following example creates a database called "my_db":

Code:
<?php
$con = mysql_connect("localhost","peter","abc123");
if (!$con)
  {
  die('Could not connect: ' . mysql_error());
  }if (mysql_query("CREATE DATABASE my_db",$con))
  {
  echo "Database created";
  }
else
  {
  echo "Error creating database: " . mysql_error();
  }mysql_close($con);
?>


--------------------------------------------------------------------------------

Create a Table
The CREATE TABLE statement is used to create a table in MySQL.

Syntax
Code:
CREATE TABLE table_name
(
column_name1 data_type,
column_name2 data_type,
column_name3 data_type,
....
)


To learn more about SQL, please visit our SQL tutorial.

We must add the CREATE TABLE statement to the mysql_query() function to execute the command.

Example
The following example creates a table named "Persons", with three columns. The column names will be "FirstName", "LastName" and "Age":

Code:
<?php
$con = mysql_connect("localhost","peter","abc123");
if (!$con)
  {
  die('Could not connect: ' . mysql_error());
  }// Create database
if (mysql_query("CREATE DATABASE my_db",$con))
  {
  echo "Database created";
  }
else
  {
  echo "Error creating database: " . mysql_error();
  }// Create table
mysql_select_db("my_db", $con);
$sql = "CREATE TABLE Persons
(
FirstName varchar(15),
LastName varchar(15),
Age int
)";// Execute query
mysql_query($sql,$con);mysql_close($con);
?>


Important: A database must be selected before a table can be created. The database is selected with the mysql_select_db() function.

Note: When you create a database field of type varchar, you must specify the maximum length of the field, e.g. varchar(15).

The data type specifies what type of data the column can hold. For a complete reference of all the data types available in MySQL, go to our complete Data Types reference.



--------------------------------------------------------------------------------

Primary Keys and Auto Increment Fields
Each table should have a primary key field.

A primary key is used to uniquely identify the rows in a table. Each primary key value must be unique within the table. Furthermore, the primary key field cannot be null because the database engine requires a value to locate the record.

The following example sets the personID field as the primary key field. The primary key field is often an ID number, and is often used with the AUTO_INCREMENT setting. AUTO_INCREMENT automatically increases the value of the field by 1 each time a new record is added. To ensure that the primary key field cannot be null, we must add the NOT NULL setting to the field.

Example
Code:
$sql = "CREATE TABLE Persons
(
personID int NOT NULL AUTO_INCREMENT,
PRIMARY KEY(personID),
FirstName varchar(15),
LastName varchar(15),
Age int
)";
mysql_query($sql,$con);
Back to top
View user's profile Send private message
Display posts from previous:   
Post new topic   Reply to topic    Home of Testers Forum Index -> Skills All times are GMT
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group