Learn PHP in 7 Days
Learn PHP in 7 Days
PHP
In
7
Days
Abhilash Sahoo
Learn PHP in 7 Days2
Contents
Chapter 1. Introduction
1.1 What is PHP?...........................................................................................
1.2 What is a PHP File? .................................................................................
1.3 What is MySQL? ......................................................................................
1.4 PHP + MySQL...........................................................................................
1.5 Why PHP? ...............................................................................................
1.6 Where to Start? ......................................................................................
1.7 What do You Need? ................................................................................
1.8 Download PHP.........................................................................................
1.9 Download MySQL Database.....................................................................
1.10 Download Apache Server........................................................................
1.11 Basic PHP Syntax.....................................................................................
1.12 Comments in PHP....................................................................................
7.1 Looping…………………………………………………………………………………………………..
7.2 The while Statement…………………………………………………………………………………
7.3 The do...while Statement…………………………………………………………………………..
7.4 The for Statement……………………………………………………………………………………..
7.5 The foreach Statement……………………………………………………………………………….
Chapter 1. Introduction
PHP is a widely-used general-purpose scripting language that is especially suited for Web
development and can be embedded into HTML. PHP is free and efficient alternative to
competitors such as Microsoft's ASP
PHP is a powerful server-side scripting language for creating dynamic and interactive
websites.
The PHP syntax is very similar to Perl and C. PHP is often used together with Apache (web
server) on various operating systems. It also supports ISAPI and can be used with
Microsoft's IIS on Windows.
PHP combined with MySQL are cross-platform (means that you can develop in
Windows and serve on a Unix platform)
This book will not explain how to install PHP, MySQL, or Apache Server.
If your server supports PHP - you don't need to do anything! You do not need to compile
anything or install any extra tools - just create some .php files in your web directory - and
the server will parse them for you. Most web hosts offer PHP support.
However, if your server does not support PHP, you must install PHP. Below is a link to a
good tutorial from PHP.net on how to install PHP5:
http://www.php.net/manual/en/install.php
A PHP scripting block always starts with <?php and ends with ?>. A PHP scripting block can
be placed anywhere in the document.
On servers with shorthand support enabled you can start a scripting block with <? and end
with ?>.
However, for maximum compatibility, we recommend that you use the standard form (<?
php) rather than the shorthand form.
<?php
?>
A PHP file normally contains HTML tags, just like an HTML file, and some PHP scripting code.
Below, we have an example of a simple PHP script which sends the text "Hello World" to the
browser:
<html>
<body>
<?php
echo "Hello World";
?>
</body>
</html>
Each code line in PHP must end with a semicolon. The semicolon is a separator and is used
to distinguish one set of instructions from another.
There are two basic statements to output text with PHP: echo and print. In the example
above we have used the echo statement to output the text "Hello World".
Learn PHP in 7 Days7
<html>
<body>
<?php
//This is a comment
/*
This is
a comment
block
*/
?>
</body>
</html>
Learn PHP in 7 Days8
Variables are used for storing values, like text strings, numbers or arrays.
When a variable is set it can be used over and over again in your script
$var_name = value;
New PHP programmers often forget the $ sign at the beginning of the variable. In that case
it will not work.
Let's try creating a variable with a string, and a variable with a number:
<?php
$txt = "Hello World!";
$number = 16;
?>
In the example above, you see that you do not have to tell PHP which data type the variable
is.
PHP automatically converts the variable to the correct data type, depending on how they are
set.
In a strongly typed programming language, you have to declare (define) the type and name
of the variable before using it.
PHP Strings
A string variable is used to store and manipulate a piece of text.
String variables are used for values that contain character strings.
In this book we are going to look at some of the most common functions and operators
used to manipulate strings in PHP.
After we create a string we can manipulate it. A string can be used directly in a function or
it can be stored in a variable.
Below, the PHP script assigns the string "Hello World" to a string variable called $txt:
<?php
$txt="Hello World";
echo $txt;
?>
Hello World
Now, lets try to use some different functions and operators to manipulate our string.
The concatenation operator (.) is used to put two string values together.
<?php
$txt1="Hello World";
$txt2="1234";
echo $txt1 . " " . $txt2;
?>
If we look at the code above you see that we used the concatenation operator two times.
This is because we had to insert a third string.
Between the two string variables we added a string with a single character, an empty space,
to separate the two variables.
<?php
echo strlen("Hello world!");
?>
12
The length of a string is often used in loops or other functions, when it is important to know
when the string ends. (i.e. in a loop, we would want to stop the loop after the last character
in the string)
The strpos() function is used to search for a string or character within a string.
If a match is found in the string, this function will return the position of the first match. If no
match is found, it will return FALSE.
<?php
echo strpos("Hello world!","world");
?>
Learn PHP in 7 Days11
As you see the position of the string "world" in our string is position 6. The reason that it is
6, and not 7, is that the first position in the string is 0, and not 1.
Learn PHP in 7 Days12
Arithmetic Operators
Very often when you write code, you want to perform different actions for different
decisions.
if...else statement - use this statement if you want to execute a set of code when a
condition is true and another if the condition is not true
elseif statement - is used with the if...else statement to execute a set of code if
one of several condition are true
If you want to execute some code if a condition is true and another code if a condition is
false, use the if....else statement.
Syntax
if (condition)
code to be executed if condition is true;
else
code to be executed if condition is false;
Example
The following example will output "Have a nice weekend!" if the current day is Friday,
otherwise it will output "Have a nice day!":
<html>
<body>
<?php
$d=date("D");
if ($d=="Fri")
echo "Have a nice weekend!";
else
echo "Have a nice day!";
?>
</body>
</html>
If more than one line should be executed if a condition is true/false, the lines should be
enclosed within curly braces:
Learn PHP in 7 Days15
<html>
<body>
<?php
$d=date("D");
if ($d=="Fri")
{
echo "Hello!<br />";
echo "Have a nice weekend!";
echo "See you on Monday!";
}
?>
</body>
</html>
If you want to execute some code if one of several conditions are true use the elseif
statement
Syntax
if (condition)
code to be executed if condition is true;
elseif (condition)
code to be executed if condition is true;
else
code to be executed if condition is false;
Example
The following example will output "Have a nice weekend!" if the current day is Friday, and
"Have a nice Sunday!" if the current day is Sunday. Otherwise it will output "Have a nice
day!":
<html>
<body>
<?php
$d=date("D");
if ($d=="Fri")
echo "Have a nice weekend!";
elseif ($d=="Sun")
echo "Have a nice Sunday!";
else
echo "Have a nice day!";
?>
</body>
</html>
Learn PHP in 7 Days16
Switch Statements
The Switch statement in PHP is used to perform one of several different actions
based on one of several different conditions.
If you want to select one of many blocks of code to be executed, use the Switch statement.
Syntax
switch (expression)
{
case label1:
code to be executed if expression = label1;
break;
case label2:
code to be executed if expression = label2;
break;
default:
code to be executed
if expression is different
from both label1 and label2;
}
Example
<html>
<body>
<?php
switch ($x)
{
case 1:
echo "Number 1";
break;
case 2:
echo "Number 2";
break;
case 3:
Learn PHP in 7 Days17
In this book we will show you how to create your own functions.
Example
<html>
<body>
<?php
function writeMyName()
{
echo "Kai Jim Refsnes";
}
writeMyName();
?>
</body>
</html>
Learn PHP in 7 Days19
<html>
<body>
<?php
function writeMyName()
{
echo "Kai Jim Refsnes";
}
echo "Hello world!<br />";
echo "My name is ";
writeMyName();
echo ".<br />That's right, ";
writeMyName();
echo " is my name.";
?>
</body>
</html>
Hello world!
My name is Kai Jim Refsnes.
That's right, Kai Jim Refsnes is my name.
Our first function (writeMyName()) is a very simple function. It only writes a static string.
To add more functionality to a function, we can add parameters. A parameter is just like a
variable.
You may have noticed the parentheses after the function name, like: writeMyName(). The
parameters are specified inside the parentheses.
Example 1
The following example will write different first names, but the same last name:
<html>
<body>
<?php
function writeMyName($fname)
{
echo $fname . " Refsnes.<br />";
}
Learn PHP in 7 Days20
Example 2
<html>
<body>
<?php
function writeMyName($fname,$punctuation)
{
echo $fname . " Refsnes" . $punctuation . "<br />";
}
echo "My name is ";
writeMyName("Kai Jim",".");
echo "My name is ";
writeMyName("Hege","!");
echo "My name is ";
writeMyName("Ståle","...");
?>
</body>
</html>
Example
<html>
<body>
<?php
function add($x,$y)
{
$total = $x + $y;
return $total;
}
echo "1 + 16 = " . add(1,16);
?>
</body>
</html>
1 + 16 = 17
Learn PHP in 7 Days22
When working with PHP, sooner or later, you might want to create many similar variables.
Instead of having many similar variables, you can store the data as elements in an array.
Each element in the array has its own ID so that it can be easily accessed.
Example 1
$names = array("Peter","Quagmire","Joe");
Example 2
$names[0] = "Peter";
$names[1] = "Quagmire";
$names[2] = "Joe";
Learn PHP in 7 Days23
<?php
$names[0] = "Peter";
$names[1] = "Quagmire";
$names[2] = "Joe";
echo $names[1] . " and " . $names[2] .
" are ". $names[0] . "'s neighbors";
?>
When storing data about specific named values, a numerical array is not always the best
way to do it.
With associative arrays we can use the values as keys and assign values to them.
Example 1
Example 2
This example is the same as example 1, but shows a different way of creating the array:
$ages['Peter'] = "32";
$ages['Quagmire'] = "30";
$ages['Joe'] = "34";
<?php
$ages['Peter'] = "32";
$ages['Quagmire'] = "30";
$ages['Joe'] = "34";
echo "Peter is " . $ages['Peter'] . " years old.";
?>
Learn PHP in 7 Days24
In a multidimensional array, each element in the main array can also be an array. And each
element in the sub-array can be an array, and so on.
Example
$families = array
(
"Griffin"=>array
(
"Peter",
"Lois",
"Megan"
),
"Quagmire"=>array
(
"Glenn"
),
"Brown"=>array
(
"Cleveland",
"Loretta",
"Junior"
)
);
The array above would look like this if written to the output:
Array
(
[Griffin] => Array
(
[0] => Peter
[1] => Lois
[2] => Megan
)
[Quagmire] => Array
(
[0] => Glenn
)
[Brown] => Array
(
Learn PHP in 7 Days25
Example 2
7.1 Looping
Very often when you write code, you want the same block of code to run a number of times.
You can use looping statements in your code to perform this.
while - loops through a block of code if and as long as a specified condition is true
do...while - loops through a block of code once, and then repeats the loop as long
as a special condition is true
for - loops through a block of code a specified number of times
foreach - loops through a block of code for each element in an array
The while statement will execute a block of code if and as long as a condition is true.
Syntax
while (condition)
code to be executed;
Example
The following example demonstrates a loop that will continue to run as long as the variable i
is less than, or equal to 5. i will increase by 1 each time the loop runs:
<html>
<body>
<?php
$i=1;
while($i<=5)
{
echo "The number is " . $i . "<br />";
$i++;
}
?>
</body>
</html>
Learn PHP in 7 Days27
The do...while statement will execute a block of code at least once - it then will repeat the
loop as long as a condition is true.
Syntax
do
{
code to be executed;
}
while (condition);
Example
The following example will increment the value of i at least once, and it will continue
incrementing the variable i as long as it has a value of less than 5:
<html>
<body>
<?php
$i=0;
do
{
$i++;
echo "The number is " . $i . "<br />";
}
while ($i<5);
?>
</body>
</html>
The for statement is used when you know how many times you want to execute a
statement or a list of statements.
Syntax
for (initialization; condition; increment)
{
code to be executed;
}
Note: The for statement has three parameters. The first parameter initializes variables, the
second parameter holds the condition, and the third parameter contains the increments
required to implement the loop. If more than one variable is included in the initialization or
the increment parameter, they should be separated by commas. The condition must
evaluate to true or false.
Learn PHP in 7 Days28
Example
The following example prints the text "Hello World!" five times:
<html>
<body>
<?php
for ($i=1; $i<=5; $i++)
{
echo "Hello World!<br />";
}
?>
</body>
</html>
For every loop, the value of the current array element is assigned to $value (and the array
pointer is moved by one) - so on the next loop, you'll be looking at the next element.
Syntax
foreach (array as value)
{
code to be executed;
}
Example
The following example demonstrates a loop that will print the values of the given array:
<html>
<body>
<?php
$arr=array("one", "two", "three");
foreach ($arr as $value)
{
echo "Value: " . $value . "<br />";
}
?>
</body>
</html>
The PHP $_GET and $_POST variables are used to retrieve information from forms,
like user input.
The most important thing to notice when dealing with HTML forms and PHP is that any form
element in an HTML page will automatically be available to your PHP scripts.
Form example:
<html>
<body>
<form action="welcome.php" method="post">
Name: <input type="text" name="name" />
Age: <input type="text" name="age" />
<input type="submit" />
</form>
</body>
</html>
The example HTML page above contains two input fields and a submit button. When the
user fills in this form and click on the submit button, the form data is sent to the
"welcome.php" file.
<html>
<body>
Welcome <?php echo $_POST["name"]; ?>.<br />
You are <?php echo $_POST["age"]; ?> years old.
</body>
</html>
Welcome John.
You are 28 years old.
The PHP $_GET and $_POST variables will be explained in the next chapters.
User input should be validated whenever possible. Client side validation is faster, and will
reduce server load.
However, any site that gets enough traffic to worry about server resources, may also need
to worry about site security. You should always use server side validation if the form
accesses a database.
Learn PHP in 7 Days30
A good way to validate a form on the server is to post the form to itself, instead of jumping
to a different page. The user will then get the error messages on the same page as the
form. This makes it easier to discover the error.
PHP $_GET
The $_GET variable is used to collect values from a form with method="get".
The $_GET variable is an array of variable names and values sent by the HTTP GET method.
The $_GET variable is used to collect values from a form with method="get". Information
sent from a form with the GET method is visible to everyone (it will be displayed in the
browser's address bar) and it has limits on the amount of information to send (max. 100
characters).
Example
<form action="welcome.php" method="get">
Name: <input type="text" name="name" />
Age: <input type="text" name="age" />
<input type="submit" />
</form>
When the user clicks the "Submit" button, the URL sent could look something like this:
http://www.w3schools.com/welcome.php?name=Peter&age=37
The "welcome.php" file can now use the $_GET variable to catch the form data (notice that
the names of the form fields will automatically be the ID keys in the $_GET array):
Note: When using the $_GET variable all variable names and values are displayed in the
URL. So this method should not be used when sending passwords or other sensitive
information! However, because the variables are displayed in the URL, it is possible to
bookmark the page. This can be useful in some cases.
Note: The HTTP GET method is not suitable on large variable values; the value cannot
exceed 100 characters.
Learn PHP in 7 Days31
The PHP $_REQUEST variable contains the contents of both $_GET, $_POST, and
$_COOKIE.
The PHP $_REQUEST variable can be used to get the result from form data sent with both
the GET and POST methods.
Example
Welcome <?php echo $_REQUEST["name"]; ?>.<br />
You are <?php echo $_REQUEST["age"]; ?> years old!
PHP $_POST
The $_POST variable is used to collect values from a form with method="post".
The $_POST variable is an array of variable names and values sent by the HTTP POST
method.
The $_POST variable is used to collect values from a form with method="post". Information
sent from a form with the POST method is invisible to others and has no limits on the
amount of information to send.
Example
<form action="welcome.php" method="post">
Enter your name: <input type="text" name="name" />
Enter your age: <input type="text" name="age" />
<input type="submit" />
</form>
When the user clicks the "Submit" button, the URL will not contain any form data, and will
look something like this:
http://www.w3schools.com/welcome.php
The "welcome.php" file can now use the $_POST variable to catch the form data (notice that
the names of the form fields will automatically be the ID keys in the $_POST array):
Variables sent with HTTP POST are not shown in the URL
Learn PHP in 7 Days32
However, because the variables are not displayed in the URL, it is not possible to bookmark
the page.
The PHP $_REQUEST variable contains the contents of both $_GET, $_POST, and
$_COOKIE.
The PHP $_REQUEST variable can be used to get the result from form data sent with both
the GET and POST methods.
Example
Welcome <?php echo $_REQUEST["name"]; ?>.<br />
You are <?php echo $_REQUEST["age"]; ?> years old!
What is MySQL?
In a database, there are tables. Just like HTML tables, database tables contain rows,
columns, and cells.
Databases are useful when storing information categorically. A company may have a
database with the following tables: "Employees", "Products", "Customers" and "Orders".
Database Tables
A database most often contains one or more tables. Each table has a name (e.g.
"Customers" or "Orders"). Each table contains records (rows) with data.
The table above contains three records (one for each person) and four columns (LastName,
FirstName, Address, and City).
Queries
With MySQL, we can query a database for specific information and have a recordset
returned.
The query above selects all the data in the LastName column in the Persons table, and will
return a recordset like this:
LastName
Learn PHP in 7 Days34
Hansen
Svendson
Pettersen
If you don't have a PHP server with a MySQL Database, you can download MySQL for free
here: http://www.mysql.com/downloads/index.html
One great thing about MySQL is that it can be scaled down to support embedded database
applications. Perhaps it is because of this reputation that many people believe that MySQL
can only handle small to medium-sized systems.
The truth is that MySQL is the de-facto standard database for web sites that support huge
volumes of both data and end users (like Friendster, Yahoo, Google). Look at
http://www.mysql.com/customers/ for an overview of companies that use MySQL.
Before you can access and work with data in a database, you must create a connection to
the database.
Syntax
mysql_connect(servername,username,password);
Parameter Description
Learn PHP in 7 Days35
Example
In the following example we store the connection in a variable ($con) for later use in the
script. The "die" part will be executed if the connection fails:
<?php
$con = mysql_connect("localhost","peter","abc123");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
// some code
?>
Closing a Connection
The connection will be closed as soon as the script ends. To close the connection before, use
the mysql_close() function.
<?php
$con = mysql_connect("localhost","peter","abc123");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
// some code
mysql_close($con);
?>
Learn PHP in 7 Days36
Create a Database
Syntax
CREATE DATABASE database_name
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
<?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
Syntax
CREATE TABLE table_name
(
column_name1 data_type,
column_name2 data_type,
column_name3 data_type,
Learn PHP in 7 Days37
.......
)
We must add the CREATE TABLE statement to the mysql_query() function to execute the
command.
Example
The following example shows how you can create a table named "person", with three
columns. The column names will be "FirstName", "LastName" and "Age":
<?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 in my_db database
mysql_select_db("my_db", $con);
$sql = "CREATE TABLE person
(
FirstName varchar(15),
LastName varchar(15),
Age int
)";
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).
Below are the different MySQL data types that can be used:
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 primary key field is always indexed. There is no exception to this rule! You must index
the primary key field so the database engine can quickly locate rows based on the key's
value.
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
$sql = "CREATE TABLE person
(
personID int NOT NULL AUTO_INCREMENT,
PRIMARY KEY(personID),
FirstName varchar(15),
LastName varchar(15),
Age int
)";
mysql_query($sql,$con);
The INSERT INTO statement is used to add new records to a database table.
Syntax
INSERT INTO table_name
VALUES (value1, value2,....)
You can also specify the columns where you want to insert the data:
Note: SQL statements are not case sensitive. INSERT INTO is the same as insert into.
To get PHP to execute the statements above we must use the mysql_query() function. This
function is used to send a query or command to a MySQL connection.
Example
In the previous chapter we created a table named "Person", with three columns;
"Firstname", "Lastname" and "Age". We will use the same table in this example. The
following example adds two new records to the "Person" table:
<?php
$con = mysql_connect("localhost","peter","abc123");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("my_db", $con);
mysql_query("INSERT INTO person (FirstName, LastName, Age)
VALUES ('Peter', 'Griffin', '35')");
mysql_query("INSERT INTO person (FirstName, LastName, Age)
VALUES ('Glenn', 'Quagmire', '33')");
mysql_close($con);
?>
Now we will create an HTML form that can be used to add new records to the "Person"
table.
<html>
<body>
<form action="insert.php" method="post">
Learn PHP in 7 Days41
When a user clicks the submit button in the HTML form in the example above, the form data
is sent to "insert.php". The "insert.php" file connects to a database, and retrieves the values
from the form with the PHP $_POST variables. Then, the mysql_query() function executes
the INSERT INTO statement, and a new record will be added to the database table.
<?php
$con = mysql_connect("localhost","peter","abc123");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("my_db", $con);
$sql="INSERT INTO person (FirstName, LastName, Age)
VALUES
('$_POST[firstname]','$_POST[lastname]','$_POST[age]')";
if (!mysql_query($sql,$con))
{
die('Error: ' . mysql_error());
}
echo "1 record added";
mysql_close($con)
?>