Connecting to the database_PHP tutorial
4. Database connection
Through PHP you can easily connect to the database, request data and display it in your web site, and even modify the data in the database. MySQL is a very popular database, and there are many tutorials on PHP and MySQL on the Internet. MySQL is free, which may attract many people. Due to its wide application, I don't want to go into details about the use of MySQL here. Oracle is widely used in enterprise applications, so we will use Oracle to introduce the connection between PHP and database. We will certainly not mention the design principles of the Oracle database, as this is beyond the scope of our discussion.
PHP provides two sets of functions to connect to Oracle, namely ORA_ and OCI functions. The ORA_ function is slightly outdated. The OCI function update is said to be better. The usage syntax of the two is almost the same. As mentioned before, your PHP installation options should support the use of both.
For more knowledge about installing an Apache server supporting PHP3 on Microsoft Windows platform and more knowledge about Oracle database, please consult the following URL: www.csoft.net/~vsbabu/articles/oraphp.html.
4.1 Connection
if ($conn=Ora_Logon("user@TNSNAME","password"))
{
echo "n";
}
else
{
echo "Failed :-( Could not connect to databasen";
}
Ora_Logoff($conn);
phpinfo();
?>
The above code uses the Oracle database name and user name defined by TNSNAME (specified in your tnsnames.ora file) and password to connect to the database. Based on a successful connection, the ora_logon function returns a non-zero connection ID and stores it in the variable $conn.
4.2 Query
Assume that the connection to the database is ready. Next we will come to the actual application of querying the database.The following code demonstrates a typical example of connecting and querying:
/*
* Connect to the database and execute the query
*/
function printoraerr($in_cur)
{
// Check whether Oracle has an error
// If there is an error, display it
// When the pointer is activated, call this function after each request for Oracle
if(ora_errorcode($in_cur))
echo "Oracle code - ".ora_error($in_cur)."n";
return;
}
/**main program*/
if (!($conn=ora_logon ("user@TNSNAME","password")))
{
echo "Connection to database failedn";
exit;
}
echo "Connected as connection - $conn
n";
echo "Opening cursor ...
n";
$cursor=ora_open($conn); printoraerr($cursor);
echo "Opened cursor - $cursor
n";
$qry="select user,sysdate from dual";
echo "Parsing the query $qry ...
n";
ora_parse($cursor,$qry,0); printoraerr($cursor);
echo "Query parsed
n";
echo "Executing cursor ...
n";
ora_exec($cursor); printoraerr($cursor);
echo "Executing cursor
n";
echo " Fetching cursor ...
n";
while(ora_fetch($cursor))
{
$user=ora_getcolumn($cursor,0); printoraerr($cursor);
$sysdate=ora_getcolumn($cursor,1); printoraerr($cursor);
echo " row = $user, $sysdate
n";
}
echo "Fetched all records
n";
echo "Closing cursor ...
n";
ora_close($cursor);
echo "Closed cursor
n ";
echo "Logging off from oracle...
n";
ora_logoff($conn);
echo "Logged off from oracle
n";
? >
(Translator’s Note: The above code segment lacks comments, please refer to the Oracle database function section of the PHP Manual)
4.3 Display results
The following code demonstrates how to query the database and Output the result:
function printoraerr($in_cur, $conn)
{
// Check if Oracle has an error
// If there is an error, display it
// This function is called after each Oracle request when the pointer is activated
// If it encounters an error, we exit immediately
if(ora_errorcode($in_cur))
{
echo "Oracle code - ".ora_error($in_cur)."
n";
ora_logoff($conn);
exit;
}
return;
}
function exequery($w_qry,$conn)
{
$cursor=ora_open($conn); printoraerr($cursor,$conn);
ora_parse($cursor,$w_qry,0); printoraerr($ cursor,$conn);
ora_exec($cursor); printoraerr($cursor,$conn);
$numrows=0;
$w_numcols=ora_numcols($cursor);
// display Head
echo "
n";n"; n ";
for ($i=0;$i<$w_numcols;$i++)
{
$align=(ora_columntype($cursor,$i)=="NUMBER")?"RIGHT":"LEFT";
echo "t".ora_columnname($cursor,$i)." n";
}
echo "
while(ora_fetch($cursor))
{
echo "n"; n";
for ($i=0;$i<$w_numcols;$i++)
{
$align=(ora_columntype($cursor,$i)=="NUMBER")?"RIGHT":"LEFT";
if(ora_columntype($cursor,$i)=="LONG" )
echo " n";".<br>ora_getcolumn($cursor,$i)."
else
echo "".ora_getcolumn($cursor,$i)." n";
printoraerr($cursor,$conn) ;
}
$numrows++;
echo "
}
if ($numrows==0)
echo "< TD COLSPAN="$w_numcols">Query returned no records n";
else
{
echo "n"; n";
echo "Count n";
echo "$numrows n";
echo "
}
echo "
ora_close($cursor );
return;
}
// Main program
if(!($conn=ora_logon("user@SID","password")))
{
echo "Error: Cannot connect to databasen";
exit;
}
$qry="SELECT
deptno "Dept"
,empno "Emp"
,empnm "Name"
,salary "Salary"
FROM
employee
ORDER BY 1,2";
exequery($qry);
ora_logoff($conn);
?>
(Translator's Note: The above code snippet lacks comments, please refer to the PHP Manual Oracle database function part)
4.4 Oracle login based on HTTP
Add the following code before the PHP page code to confirm Oracle login. Note that you must set $SID correctly.
if(!isset($PHP_AUTH_USER))
{
Header("WWW-authenticate: basic realm="$SID"");
Header("HTTP/ 1.0 401 Unauthorized");
$title="Login Instructions";
echo "
n";
You are not authorized to enter the site
exit;
}
else
{
if (!($conn=ora_logon("$PHP_AUTH_USER@$SID",$PHP_AUTH_PW)))
{
Header(" WWW-authenticate: basic realm="$SID"");
Header("HTTP/1.0 401 Unauthorized");
$title="Login Instructions";
echo "
n";
You are not authorized to enter the site
exit;
}
}
?>

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

PHP and Python each have their own advantages, and choose according to project requirements. 1.PHP is suitable for web development, especially for rapid development and maintenance of websites. 2. Python is suitable for data science, machine learning and artificial intelligence, with concise syntax and suitable for beginners.

MySQL is an open source relational database management system. 1) Create database and tables: Use the CREATEDATABASE and CREATETABLE commands. 2) Basic operations: INSERT, UPDATE, DELETE and SELECT. 3) Advanced operations: JOIN, subquery and transaction processing. 4) Debugging skills: Check syntax, data type and permissions. 5) Optimization suggestions: Use indexes, avoid SELECT* and use transactions.

PHP is a scripting language widely used on the server side, especially suitable for web development. 1.PHP can embed HTML, process HTTP requests and responses, and supports a variety of databases. 2.PHP is used to generate dynamic web content, process form data, access databases, etc., with strong community support and open source resources. 3. PHP is an interpreted language, and the execution process includes lexical analysis, grammatical analysis, compilation and execution. 4.PHP can be combined with MySQL for advanced applications such as user registration systems. 5. When debugging PHP, you can use functions such as error_reporting() and var_dump(). 6. Optimize PHP code to use caching mechanisms, optimize database queries and use built-in functions. 7

In PHP, you can effectively prevent CSRF attacks by using unpredictable tokens. Specific methods include: 1. Generate and embed CSRF tokens in the form; 2. Verify the validity of the token when processing the request.

PHP is widely used in e-commerce, content management systems and API development. 1) E-commerce: used for shopping cart function and payment processing. 2) Content management system: used for dynamic content generation and user management. 3) API development: used for RESTful API development and API security. Through performance optimization and best practices, the efficiency and maintainability of PHP applications are improved.

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHP is suitable for web development, with simple syntax and high execution efficiency. 2. Python is suitable for data science and machine learning, with concise syntax and rich libraries.

PHP is used to build dynamic websites, and its core functions include: 1. Generate dynamic content and generate web pages in real time by connecting with the database; 2. Process user interaction and form submissions, verify inputs and respond to operations; 3. Manage sessions and user authentication to provide a personalized experience; 4. Optimize performance and follow best practices to improve website efficiency and security.

The future of PHP will be achieved by adapting to new technology trends and introducing innovative features: 1) Adapting to cloud computing, containerization and microservice architectures, supporting Docker and Kubernetes; 2) introducing JIT compilers and enumeration types to improve performance and data processing efficiency; 3) Continuously optimize performance and promote best practices.
