+ All Categories
Home > Documents > + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example...

+ Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example...

Date post: 22-Dec-2015
Category:
Upload: jalyn-beson
View: 225 times
Download: 1 times
Share this document with a friend
Popular Tags:
63
+ Intro to PHP and SQL James Ohene-Djan
Transcript
Page 1: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+

Intro to PHP and SQL

James Ohene-Djan

Page 2: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+What We’ll Cover

Introduction to PHP

Explain example code

Introduction to Database

Using PHP/MySQL for database access

Page 3: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+

Intro to PHP

Page 4: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+What is PHP?

PHP == ‘Hypertext Preprocessor’

Open-source, server-side scripting language

Used to generate dynamic webpages

PHP scripts reside between reserved PHP tags This allows the programmer to embed PHP scripts within HTML

pages

Page 5: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+What is PHP (cont’d)

Interpreted language, scripts are parsed at run-time rather than compiled beforehand

Executed on the server-side

Source-code not visible by client ‘View Source’ in browsers does not display the PHP

code

Various built-in functions allow for fast development

Compatible with many popular databases

Page 6: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+What is PHP (cont’d)

Conceived in 1994, now used on +10 million web sites.

Outputs not only HTML but can output XML, images (JPG & PNG), PDF files and even Flash movies all generated on the fly. Can write these files to the file system.

Supports a wide-range of databases

PHP also has support for talking to other services using protocols such as LDAP, IMAP, SNMP, NNTP, POP3, HTTP.

Page 7: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+ What does PHP code look like?

Structurally similar to C/C++ but more like JSPs

Supports procedural and object-oriented paradigm (to some degree)

All PHP statements end with a semi-colon

Each PHP script must be enclosed in the reserved PHP tag

<?php …?>

Page 8: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+ Comments in PHP

Standard C, C++, and shell comment symbols

// C++ and Java-style comment

# Shell-style comments

/* C-style comments These can span multiple lines */

Page 9: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Variables in PHP

PHP variables must begin with a “$” sign

Case-sensitive ($Foo != $foo != $fOo)

Global and locally-scoped variables Global variables can be used anywhere Local variables restricted to a function or class

Certain variable names reserved by PHP Form variables ($_POST, $_GET) Server variables ($_SERVER) Etc.

Page 10: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Variable usage

<?php$foo = 25; // Numerical variable$bar = “Hello”; // String variable

$foo = ($foo * 7); // Multiplies foo by 7$bar = ($bar * 7); // Invalid expression ?>

Page 11: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+ Echo

The PHP command ‘echo’ is used to output the parameters passed to itThe typical usage for this is to send data to the

client’s web-browser

Syntaxvoid echo (string arg1 [, string argn...]) In practice, arguments are not passed in

parentheses since echo is a language construct rather than an actual function

Page 12: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Echo example

Notice how echo ‘5x5=$foo’ outputs $foo rather than replacing it with 25

Strings in single quotes (‘ ’) are not interpreted or evaluated by PHP

This is true for both variables and character escape-sequences (such as “\n” or “\\”)

<?php$foo = 25; // Numerical variable$bar = “Hello”; // String variable

echo $bar; // Outputs Helloecho $foo,$bar; // Outputs 25Helloecho “5x5=”,$foo; // Outputs 5x5=25echo “5x5=$foo”; // Outputs 5x5=25echo ‘5x5=$foo’; // Outputs 5x5=$foo?>

Page 13: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Run hello.php

<html><head><title>Test PHP</title></head><body bgcolor=87cefa><?php echo"Hello There <p>"; ?></body></html>

Page 14: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Arithmetic Operations

$a - $b // subtraction

$a * $b // multiplication

$a / $b// division

$a += 5 // $a = $a+5 Also works for *= and /=

<?php$a=15;$b=30;$total=$a+$b;Print $total;Print “<p><h1>$total</h1>”;// total is 45

?>

Page 15: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Concatenation

Use a period to join strings into one.

<?php$string1=“Hello”;$string2=“PHP”;$string3=$string1 . “ ” . $string2;Print $string3;?>

Hello PHP

Page 16: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Escaping the Character

If the string has a set of double quotation marks that must remain visible, use the \ [backslash] before the quotation marks to ignore and display them.

<?php$heading=“\”Computer Science\””;Print $heading;?>

“Computer Science”

Page 17: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+icecream.php

Page 18: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+ices.php

Page 19: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+ PHP Control Structures Control Structures: Are the structures within a language

that allow us to control the flow of execution through a program or script.

Grouped into conditional (branching) structures (e.g. if/else) and repetition structures (e.g. while loops).

Example if/else if/else statement:

<?php

$foo =4;

if ($foo == 0) {

echo 'The variable foo is equal to 0';

}

else if (($foo > 0) && ($foo <= 5)) {

echo 'The variable foo is between 1 and 5';

}

else {

echo 'The variable foo is equal to '.$foo;

}

?>

Page 20: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+If ... Else...

If (condition)

{

Statements;

}

Else

{

Statement;

}

<?php$user = “John”

If($user==“John”){

Print “Hello John.”;}Else{

Print “You are not John.”;}?>

No THEN in PHP

Page 21: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+While Loops

While (condition)

{

Statements;

}

<?php$count=0;While($count<3){

Print “hello PHP. ”;$count += 1;// $count = $count + 1;// or// $count++;

?>

hello PHP. hello PHP. hello PHP.

Page 22: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Date Display

$datedisplay=date(“yyyy/m/d”);

Print $datedisplay;

# If the date is April 1st, 2009

# It would display as 2009/4/1

<?php$datedisplay=date(“yyyy/m/d");Print $datedisplay;?>

$datedisplay=date(“l, F m, Y”);

Print $datedisplay;

# If the date is April 1st, 2009

# Wednesday, April 1, 2009

<?php$datedisplay=date("I/F m/ Y");Print $datedisplay;?>

Page 23: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

Month, Day & Date Format Symbols

M Jan

F January

m 01

n 1

Day of Month d 01

Day of Month J 1

Day of Week l Monday

Day of Week D Mon

Page 24: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Run Today.php

<html>

<head><title>Test Form PHP</title></head>

<body bgcolor=87cefa>

<p>Today's date (according to this Web server) is

<?php

date_default_timezone_set('UTC');

echo date("l, F dS Y.");?>

</body>

</html>

Page 25: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+ Functions

Functions MUST be defined before then can be called

Function headers are of the format

Note that no return type is specified

Unlike variables, function names are not case sensitive (foo(…) == Foo(…) == FoO(…))

function functionName($arg_1, $arg_2, …, $arg_n)

Page 26: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+ Functions example

<?php // This is a function

function foo($arg_1, $arg_2) { $arg_2 = $arg_1 * $arg_2;   return $arg_2;}

$result_1 = foo(12, 3); // Store the function echo $result_1; // Outputs 36echo foo(12, 3); // Outputs 36?>

Page 27: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Include FilesInclude “opendb.php”;

Include “closedb.php”;

This inserts files; the code in files will be inserted into current code. This will provide useful and protective means once you connect to a database, as well as for other repeated functions.

Include (“footer.php”);

The file footer.php might look like:

<hr SIZE=11 NOSHADE WIDTH=“100%”>

<i>Copyright © 2008-2010 KSU </i></font><br>

<i>ALL RIGHTS RESERVED</i></font><br>

<i>URL: http://www.kent.edu</i></font><br>

Page 28: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+ PHP - Forms• Access to the HTTP POST and GET data is simple in

PHP• The global variables $_POST[] and $_GET[] contain the

request data <?php

if ($_POST["submit"]) echo "<h2>You clicked Submit!</h2>"; else if ($_POST["cancel"]) echo "<h2>You clicked Cancel!</h2>";?><form action="form.php" method="post"> <input type="submit" name="submit" value="Submit"> <input type="submit" name="cancel" value="Cancel"></form>

Page 29: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+ WHY PHP – Sessions ?Whenever you want to create a website that allows you to store and display information about a user, determine which user groups a person belongs to, utilize permissions on your website or you just want to do something cool on your site, PHP's Sessions are vital to each of these features.

Cookies are about 30% unreliable right now and it's getting worse every day. More and more web browsers are starting to come with security and privacy settings and people browsing the net these days are starting to frown upon Cookies because they store information on their local computer that they do not want stored there.

PHP has a great set of functions that can achieve the same results of Cookies and more without storing information on the user's computer. PHP Sessions store the information on the web server in a location that you chose in special files. These files are connected to the user's web browser via the server and a special ID called a "Session ID". This is nearly 99% flawless in operation and it is virtually invisible to the user.

Page 30: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+ PHP - Sessions• Sessions store their identifier in a cookie in the client’s browser• Every page that uses session data must be proceeded by the

session_start() function• Session variables are then set and retrieved by accessing the

global $_SESSION[]

• Save it as session.php <?php

session_start(); if (!$_SESSION["count"]) $_SESSION["count"] = 0; if ($_GET["count"] == "yes") $_SESSION["count"] = $_SESSION["count"] + 1; echo "<h1>".$_SESSION["count"]."</h1>";?><a href="session.php?count=yes">Click here to count</a>

Page 31: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Avoid Error PHP - Sessions

PHP Example: <?php echo "Look at this nasty error below:<br />"; session_start(); ?> Error!

PHP Example: <?php session_start(); echo "Look at this nasty error below:"; ?> Correct

Warning: Cannot send session cookie - headers already sent by (output started at session_header_error/session_error.php:2) in session_header_error/session_error.php on line 3

Warning: Cannot send session cache limiter - headers already sent (output started at session_header_error/session_error.php:2) in session_header_error/session_error.php on line 3

Page 32: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+ Destroy PHP - SessionsWhy it is necessary to destroy a session when the session will get destroyed when the user closes their browser. Imagine that you had a session registered called "access_granted" and you were using that to determine if the user was logged into your site based upon a username and password. Anytime you have a login feature, to make the users feel better, you should have a logout feature as well. That's where this cool function called session_destroy() comes in handy. session_destroy() will completely demolish your session (no, the computer won't blow up or self destruct) but it just deletes the session files and clears any trace of that session.

Here's how we use session_destroy():

Page 33: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+ Destroy PHP - Sessions<?php // start the session session_start(); header("Cache-control: private"); //IE 6 Fix $_SESSION = array(); session_destroy(); echo "<strong>Step 5 - Destroy This Session </strong><br />"; if($_SESSION['name']){     echo "The session is still active"; } else {     echo "Ok, the session is no longer active! <br />";     echo "<a href=\"page1.php\"><< Go Back Step 1</a>"; } ?>

Page 34: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+First PHP script

Save as sample.php:<!– sample.php -->

<html><body>

<strong>Hello World!</strong><br /> <?php

echo “<h2>Hello, World</h2>”; ?>

<?php$myvar = "Hello World";

echo $myvar;

?>

</body></html>

Page 35: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+ PHP References http://www.php.net <-- php home page http://www.phpbuilder.com/ http://www.devshed.com/ http://www.phpmyadmin.net/ http://www.hotscripts.com/PHP/ http://geocities.com/stuprojects/ChatroomDescription.htm http://www.academic.marist.edu/~kbhkj/chatroom/

chatroom.htm http://www.aus-etrade.com/Scripts/php.php http://www.codeproject.com/asp/CDIChatSubmit.asp http://www.php.net/downloads <-- php download page http://www.php.net/manual/en/install.windows.php <--

php installation manual http://php.resourceindex.com/ <-- PHP resources like

sample programs, text book references, etc. http://www.daniweb.com/techtalkforums/forum17.html

php forums

Page 36: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+

SQL Intro

Page 37: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Relational Databases

There are many different versions of Relational Database management systems available • Oracle• MySQL• SQLite• DB2• many others

We’ll be using MySQL. The syntax of the Structured Query Language (SQL) is fairly standard.

Page 38: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Databases _ creation

CREATE TABLE tableName (name VARCHAR(55),sex CHAR(1),age INT(3),birthdate DATE,salary DECIMAL(10,2),primary key(name)

);Types of attributes: char, varchar, int, smallint, decimal, date, float, etc.*varchar is a string with varying # of characters. In our example, 55 is the characters longest possible string allowed.*decimal(10,2) indicated 2 places after the decimal point and 10 total digits (including the decimal numbers)

Page 39: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Databases _ creation 2CREATE TABLE tableName (

name VARCHAR(55),sex CHAR(1) NOT NULL,age INT(3),birthdate DATE,salary DECIMAL(10,2) DEFAULT ‘0.00’,primary key(name)

);Primary key: primary key is a UNIQUE value. For every entry in your database this must be unique and not null and every DB must have one.NOT NULL: column must have a valueDEFAULT: you can set a default value if no other value is inputted for that column.

Page 40: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Databases _ indexed primary keysInstead of specifying a column as a primary key you can have the database create a column of numbers that will automatically increment with each entry inserted into the DB. Example:CREATE TABLE tableName (

id INT AUTO_INCREMENT,name VARCHAR(55),sex CHAR(1),age INT(3),birthdate DATE,salary DECIMAL(10,2),primary key(id)

);Entry 1 will have 1 as a key. Entry 2 will have 2 and so forth.

Page 41: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Databases _ deletion

DROP TABLE tableName;

Page 42: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Databases _ insertion

Inserting data in the database:INSERT INTO tableName(name,sex,age)VALUES(‘Mr. Freeze’,’M’,42);

Also valid:INSERT INTO tableName(sex,name,age)VALUES(‘M’,’Mr. Freeze’,42);

Order doesn’t matter.

Page 43: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Databases _ querying data

Always in the form of:SELECT ….FROM ….WHERE ….

So select a column from your database.From a databaseWhere x meets y condition.

Page 44: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Databases _ updating

Suppose we want to change Mr. Freeze’s age to 52.

UPDATE tableNameSET age = ’52’WHERE name LIKE ‘Mr. Freeze’

And so forth.

Page 45: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Databases _ aggregates

This is the actual meat of using SQL. These are where you set your conditions, narrow down your table into a usable set. Here are the usable functions

Group byCountSumAvgMin/MaxOrder by

Page 46: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Databases _ group by

Group by lumps all the common attributes into one row.

SELECT employee_id, MAX(salary)FROM Works_InGROUP BY dept_id;

* MAX selects the maximum value in its () likewise for MIN

Page 47: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Databases _ count

Count counts the number of columns with the specified attribute.

SELECT term, COUNT(course_id)FROM teachesGROUP BY term;

We counted the number of courses taught during x term. AVG & SUM function pretty much the same way.

Page 48: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Using a Database with PHP

Page 49: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Functions Covered mysql_connect()

mysql_select_db()

include()

mysql_query()

mysql_num_rows()

mysql_fetch_array()

mysql_close()

Page 50: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+PHP _ connecting to the db

This is the basic connect script for accessing your db:

<?phpmysql_connect(“localhost”,”username”,”password”) or die(mysql_error()); ?>

Localhost indicates the current machine. So you’re asking the machine to connect to itself. The die(mysql_error) part says if there’s an error halt everything and display this error. If it errors on this part, it means either your host, username, or password are wrong.

Page 51: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+PHP _ error checking w/ echo

Consider the connection script again with this modification:

<?phpmysql_connect(“localhost”,”username”,”password”) or die(mysql_error());echo “Connected to MySQL.”?>

Later on you may be unable to differentiate where the error occurred. So while developing your code throw in some echo statements, they just print stuff to the screen. When PHP is done connecting to our database it tell us.

Page 52: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+PHP _ select the database.

<?phpmysql_connect(“localhost”,”username”,”password”) or die(mysql_error());echo “Connected MySQL!”;

mysql_select_db(“ljlayou_comp353” or die(mysql_error());echo “Connected to database 353”;?>

Page 53: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+PHP _ create/drop table

<?phpmysql_connect(“localhost”,”username”,”pw”) or die(mysql_error());mysql_select_db(“ljlayou_comp353” or die(mysql_error());

mysql_query(“CREATE TABLE Works_In(…)“) or die(mysql_error());?>

We’re querying PHP to tell MySQL to do something, in this case create the table. The same applies for dropping a table. As you can see our code is being reused over and over. It gets pretty repetitive like this. Again we tell php to stop everything if an error occurs.

Page 54: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+PHP _ insertion

<?phpmysql_connect(“localhost”,”username”,”pw”) or die(mysql_error());mysql_select_db(“ljlayou_comp353” or die(mysql_error());

mysql_query(“INSERT INTO Works_In(company,position) VALUES(‘McDonalds’,’fry cook’)”);?>

We’re querying PHP to tell MySQL to do something, in this case insert a row into the table. As you can see our code is being reused over and over. It gets pretty repetitive like this.

Page 55: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+PHP _ selecting a tableIn order to manipulate, fetch, etc data from your database you must have PHP remember the result. So we store it in an array to preserve “columns”. PHP variables unlike Java do not need a type declaration

<?php […]$result = mysql_query(“SELECT * FROM Works_In”) or die(mysql_error());$row = mysql_fetch_array($result);

echo “company: “ .$row[‘company’];echo “position:” .$row[‘position’];?>

From these lines we see that each cell in the area is labeled under the column name. Using this method we can output or even compare data.

Page 56: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+PHP _ selecting a table

<?php […]$result = mysql_query(“SELECT * FROM Works_In”) or die(mysql_error());$row = mysql_fetch_array($result);

echo “company: “ .$row[‘company’];echo “position:” .$row[‘position’];?>

The ‘*’ symbol in the SELECT statement just means that we select all the columns in the table. The above statement however results in the first row only being shown.

Page 57: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+PHP _ selecting a table 2

To solve this problem, we loop continuously until there are no more rows to choose from.

<?php […]

while ($row = mysql_fetch_array($result)) {echo “company: “ .$row[‘company’]. “ | “position:” .$row[‘position’];echo “<br/>”;}?>

If you have noticed the ‘.’ symbol signifies a concatenation.

Page 58: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+PHP _ the formulaWe looked over it all. Here’s the general formula:

<?php mysql_connect(“localhost”,”username”,”pw”) or die(mysql_error());mysql_select_db(“databaseName” or die(mysql_error());

$result = mysql_query(yourQuery) or die(mysql_error());$row = mysql_fetch_array($result);

while ($row = mysql_fetch_array($result)) { … };?>

Page 59: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+Example – show data in the tables

Function: list all tables in your database. Users can select one of tables, and show all contents in this table.

second.php

showtable.php

Page 60: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+selecttable.php

<html><head><title>MySQL Table Viewer</title></head><body><?php// change the value of $dbuser and $dbpass to your username and password$dbhost = 'hercules.cs.kent.edu:3306';$dbuser = 'nruan';$dbpass = ‘*****************’;$dbname = $dbuser;$table = 'account';$conn = mysql_connect($dbhost, $dbuser, $dbpass);if (!$conn) { die('Could not connect: ' . mysql_error());}if (!mysql_select_db($dbname)) die("Can't select database");

Page 61: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+selecttable.php (cont.)$result = mysql_query("SHOW TABLES");if (!$result) { die("Query to show fields from table failed");}$num_row = mysql_num_rows($result);echo "<h1>Choose one table:<h1>"; echo "<form action=\"showtable.php\" method=\"POST\">";echo "<select name=\"table\" size=\"1\" Font size=\"+2\">";for($i=0; $i<$num_row; $i++) {

$tablename=mysql_fetch_row($result);echo "<option value=\"{$tablename[0]}\" >{$tablename[0]}</option>";

}echo "</select>";echo "<div><input type=\"submit\" value=\"submit\"></div>";echo "</form>";

mysql_free_result($result);mysql_close($conn);?></body></html>

Page 62: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+showtable.php<html><head><title>MySQL Table Viewer</title></head><body><?php$dbhost = 'hercules.cs.kent.edu:3306';$dbuser = 'nruan';$dbpass = ‘**********’;$dbname = 'nruan';$table = $_POST[“table”];$conn = mysql_connect($dbhost, $dbuser, $dbpass);if (!$conn)

die('Could not connect: ' . mysql_error());if (!mysql_select_db($dbname))

die("Can't select database");$result = mysql_query("SELECT * FROM {$table}");if (!$result) die("Query to show fields from table failed!" . mysql_error());

Page 63: + Intro to PHP and SQL James Ohene-Djan. + What We’ll Cover Introduction to PHP Explain example code Introduction to Database Using PHP/MySQL for database.

+showtable.php (cont.)$fields_num = mysql_num_fields($result);echo "<h1>Table: {$table}</h1>";echo "<table border='1'><tr>";// printing table headersfor($i=0; $i<$fields_num; $i++) {

$field = mysql_fetch_field($result);echo "<td><b>{$field->name}</b></td>";

}echo "</tr>\n";while($row = mysql_fetch_row($result)) {

echo "<tr>";// $row is array... foreach( .. ) puts every element// of $row to $cell variableforeach($row as $cell)

echo "<td>$cell</td>";echo "</tr>\n";

}mysql_free_result($result);mysql_close($conn);?></body></html>


Recommended