SlideShare a Scribd company logo
PHP, PHP FRAMEWORKS AND DATABASE
Sayed Ahmed
Computer Engineering, BUET, Bangladesh
MSC, Computer Science, U of Manitoba, Canada
http://www.JustEtc.net
http://sayed.justetc.net
sayed@justetc.net
TOPICS
 Connection strategies
 Configuration for connection in different
frameworks
 PHP and DB2, MSSQL Server
 Common database oriented operations
 Reference to DB oriented functions/classes
CONNECTION
 mysql_connect
 mysqli_connect
 PDO
 PDO_ODBC
 Connection from Frameworks
 Code Igniter – configure for db connection
 CakePHP - configure for db connection
 Zend - configure for db connection
PDO VS MYSQLI
 Overall, PDO is a better choice than mysqli
 However, if performance is the only issue
that you care, and
 mysql will be the backend database all the
time,
 you can use mysqli
 Reference:
 http://net.tutsplus.com/tutorials/php/pdo-vs-
mysqli-which-should-you-use/
MYSQL_CONNECT
 mysql_connect
 Opens a connection to a MySQL Server
 Deprecated as of PHP 5.5.0, and will be removed in
the future.
 Instead use MySQLi or PDO_MySQL
 mysql_connect examples
MYSQL_CONNECT EXAMPLES USING PORTS
MYSQL_CONNECT USING PATH TO
SOCKET
MYSQLI_CONNECT — ALIAS OF MYSQLI::__CONSTRUCT()
MYSQLI_CONNECT
MYSQLI_CONNECT (OBJECT EXAMPLE)
OBJECT ORIENTED STYLE CONNECTION WITH MYSQLI
DATABASE CONNECTION WITH PDO
PDO CONNECTION WHEN PARAMETERS IN A FILE
PDO USING PHP.INI CONFIGURATIONS
CODE IGNITER DATABASE CONFIGURATION
 application/config/database.php
 $db['default']['hostname'] = "localhost";
$db['default']['username'] = "root";
$db['default']['password'] = "";
$db['default']['database'] = "database_name";
$db['default']['dbdriver'] = "mysql";
$db['default']['dbprefix'] = "";
$db['default']['pconnect'] = TRUE;
$db['default']['db_debug'] = FALSE;
$db['default']['cache_on'] = FALSE;
$db['default']['cachedir'] = "";
$db['default']['char_set'] = "utf8";
$db['default']['dbcollat'] = "utf8_general_ci";
$db['default']['swap_pre'] = "";
$db['default']['autoinit'] = TRUE;
$db['default']['stricton'] = FALSE;
 Reference:
 http://ellislab.com/codeigniter/user-guide/database/configuration.html
CAKEPHP AND MYSQL
 A copy of CakePHP’s database configuration
file is found in
 /app/Config/database.php.default
 Make a copy of this file in the same directory,
but name it
 database.php
 Change database.php as follows
CAKEPHP AND MYSQL
ZEND AND DATABASE CONFIGURATION
 Zend_Config_Ini enables developers to store
configuration data in a familiar INI format
PDO AND PREPARED STATEMENTS
PDO FETCH AND PREPARED STMT
PDO AND STORED PROCEDURE (OUT
PARAM)
PDO STRD PROC WITH IN/OUT PARAMS
MYSQLI AND STORED PROCEDURE
MYSQLI FETCHING RESULTS FROM STORED PROCEDURES
PHP FUNCTIONS FOR SQL SERVER
 The name of the functions may closely resemble the functionality.
 # mssql_ bind
# mssql_ close
# mssql_ connect
# mssql_ data_ seek
# mssql_ execute
# mssql_ fetch_ array
# mssql_ fetch_ assoc
# mssql_ fetch_ batch
# mssql_ fetch_ field
# mssql_ fetch_ object
# mssql_ fetch_ row
# mssql_ field_ length
# mssql_ field_ name
# mssql_ field_ seek
# mssql_ field_ type
# mssql_ free_ result
# mssql_ free_ statement
PHP FUNCTIONS FOR SQL SERVER
 # mssql_ get_ last_ message
# mssql_ guid_ string
# mssql_ init
# mssql_ min_ error_ severity
# mssql_ min_ message_ severity
# mssql_ next_ result
# mssql_ num_ fields
# mssql_ num_ rows
# mssql_ pconnect
# mssql_ query
# mssql_ result
# mssql_ rows_ affected
# mssql_ select_ db
PHP AND IBM DB2
 PHP has concepts like PDO and PDO_ODBC, and
generic odbc features that will allow you to connect to and
work with DB-2 databases. Generic odbc is the
general/procedural way to connect to. PDO and
PDO_ODBC are object oriented ways. PDO works with
native IBM drivers. PDO_ODBC uses odbc connections
to the DB2. For PHP you need to install drivers to support
DB2. I worked with PDO_ODBC to connect to DB-2
databases in IBM iSeries servers. You need to install
odbc db2 drivers for iseries servers. Then in
/etc/odbcinst.ini file you need to mention driver
specifications and in /etc/odbc.ini, you need to mention
the odbc dsn name, database name, and some other
parameters to connect to the database. Though, you may
also supply some parameters in the PDO_ODBC connect
method.
PHP AND SQL SERVER STORED PROCEDURE
PHP AND SQL SERVER STORED PROCEDURE
MYSQL RELATED FUNCTIONS
MYSQL RELATED FUNCTIONS
MYSQL RELATED FUNCTIONS
MYSQLI — THE MYSQLI CLASS
 mysqli::$affected_rows — Gets the number of affected
rows in a previous MySQL operation
 mysqli::autocommit — Turns on or off auto-committing
database modifications
 mysqli::begin_transaction — Starts a transaction
 mysqli::change_user — Changes the user of the specified
database connection
 mysqli::character_set_name — Returns the default
character set for the database connection
 mysqli::$client_info — Get MySQL client info
 mysqli::$client_version — Returns the MySQL client
version as a stringmysqli::close — Closes a previously
opened database connection
MYSQLI — THE MYSQLI CLASS
 mysqli::commit — Commits the current transaction
 mysqli::$connect_errno — Returns the error code from
last connect call
 mysqli::$connect_error — Returns a string description of
the last connect error
 mysqli::__construct — Open a new connection to the
MySQL server
 mysqli::debug — Performs debugging operations
 mysqli::dump_debug_info — Dump debugging
information into the log
 mysqli::$errno — Returns the error code for the most
recent function call
MYSQLI — THE MYSQLI CLASS
 mysqli::$error_list — Returns a list of errors from the last command executed
 mysqli::$error — Returns a string description of the last error
 mysqli::$field_count — Returns the number of columns for the most recent query
 mysqli::get_charset — Returns a character set objectmysqli::get_client_info —
Get MySQL client info
 mysqli_get_client_stats — Returns client per-process statistics
 mysqli_get_client_version — Returns the MySQL client version as an integer
 mysqli::get_connection_stats — Returns statistics about the client connection
 mysqli::$host_info — Returns a string representing the type of connection used
 mysqli::$protocol_version — Returns the version of the MySQL protocol used
 mysqli::$server_info — Returns the version of the MySQL server
 mysqli::$server_version — Returns the version of the MySQL server as an
integer
 mysqli::get_warnings — Get result of SHOW WARNINGS
MYSQLI — THE MYSQLI CLASS
 mysqli::$info — Retrieves information about the most recently
executed querymysqli::init — Initializes MySQLi and returns a
resource for use with mysqli_real_connect()mysqli::$insert_id —
Returns the auto generated id used in the last querymysqli::kill —
Asks the server to kill a MySQL threadmysqli::more_results —
Check if there are any more query results from a multi
querymysqli::multi_query — Performs a query on the
databasemysqli::next_result — Prepare next result from
multi_querymysqli::options — Set optionsmysqli::ping — Pings a
server connection, or tries to reconnect if the connection has
gone downmysqli::poll — Poll connectionsmysqli::prepare —
Prepare an SQL statement for executionmysqli::query —
Performs a query on the databasemysqli::real_connect — Opens
a connection to a mysql servermysqli::real_escape_string —
Escapes special characters in a string for use in an SQL
statement, taking into account the current charset of the
connectionmysqli::real_query — Execute an SQL query
MYSQLI_STMT — THE MYSQLI_STMT CLASS
 mysqli_stmt::$affected_rows — Returns the total number
of rows changed, deleted, or inserted by the last executed
statementmysqli_stmt::attr_get — Used to get the current
value of a statement attributemysqli_stmt::attr_set —
Used to modify the behavior of a prepared
statementmysqli_stmt::bind_param — Binds variables to
a prepared statement as
parametersmysqli_stmt::bind_result — Binds variables to
a prepared statement for result storagemysqli_stmt::close
— Closes a prepared statementmysqli_stmt::data_seek
— Seeks to an arbitrary row in statement result
setmysqli_stmt::$errno — Returns the error code for the
most recent statement callmysqli_stmt::$error_list —
Returns a list of errors from the last statement executed
MYSQLI_RESULT — THE MYSQLI_RESULT CLASS
 mysqli_result::$current_field — Get current field offset of a result
pointermysqli_result::data_seek — Adjusts the result pointer to an
arbitrary row in the resultmysqli_result::fetch_all — Fetches all
result rows as an associative array, a numeric array, or
bothmysqli_result::fetch_array — Fetch a result row as an
associative, a numeric array, or bothmysqli_result::fetch_assoc —
Fetch a result row as an associative
arraymysqli_result::fetch_field_direct — Fetch meta-data for a
single fieldmysqli_result::fetch_field — Returns the next field in
the result setmysqli_result::fetch_fields — Returns an array of
objects representing the fields in a result
setmysqli_result::fetch_object — Returns the current row of a
result set as an objectmysqli_result::fetch_row — Get a result row
as an enumerated array
MYSQLI_DRIVER, MYSQLI_WARNING
 mysqli_driver — The mysqli_driver
classmysqli_driver::embedded_server_end — Stop
embedded server
 mysqli_driver::embedded_server_start — Initialize
and start embedded server
 mysqli_driver::$report_mode — Enables or disables
internal report functions
 mysqli_warning — The mysqli_warning
classmysqli_warning::__construct — The __construct
purpose
 mysqli_warning::next — The next purpose
 mysqli_sql_exception — The mysqli_sql_exception
class
PDO — THE PDO CLASS
 PDO::beginTransaction — Initiates a
transactionPDO::commit — Commits a
transactionPDO::__construct — Creates a PDO
instance representing a connection to a
databasePDO::errorCode — Fetch the
SQLSTATE associated with the last operation
on the database handlePDO::errorInfo — Fetch
extended error information associated with the
last operation on the database
handlePDO::exec — Execute an SQL statement
and return the number of affected
rowsPDO::getAttribute — Retrieve a database
connection attribute
PDOSTATEMENT — THE PDOSTATEMENT CLASS
 PDOStatement::bindColumn — Bind a column to a PHP
variablePDOStatement::bindParam — Binds a parameter
to the specified variable namePDOStatement::bindValue
— Binds a value to a
parameterPDOStatement::closeCursor — Closes the
cursor, enabling the statement to be executed
again.PDOStatement::columnCount — Returns the
number of columns in the result
setPDOStatement::debugDumpParams — Dump an SQL
prepared commandPDOStatement::errorCode — Fetch
the SQLSTATE associated with the last operation on the
statement handlePDOStatement::errorInfo — Fetch
extended error information associated with the last
operation on the statement handle
PDOEXCEPTION, MISC
 PDOException — The PDOException class
 PDO DriversCUBRID (PDO) — CUBRID
Functions (PDO_CUBRID)
 MS SQL Server (PDO) — Microsoft SQL
Server and Sybase Functions (PDO_DBLIB)
 Firebird/Interbase (PDO) —
Firebird/Interbase Functions
(PDO_FIREBIRD)
 IBM (PDO) — IBM Functions (PDO_IBM)

More Related Content

What's hot (17)

Php mysql connectivity
Php mysql connectivity
abhikwb
 
PHP - Getting good with MySQL part II
PHP - Getting good with MySQL part II
Firdaus Adib
 
PHP with MySQL
PHP with MySQL
wahidullah mudaser
 
Database presentation
Database presentation
webhostingguy
 
Using php with my sql
Using php with my sql
salissal
 
Php Data Objects
Php Data Objects
hiren.joshi
 
MySQL
MySQL
Gouthaman V
 
Working with Databases and MySQL
Working with Databases and MySQL
Nicole Ryan
 
Mysql
Mysql
lotlot
 
lab56_db
lab56_db
tutorialsruby
 
Sqlite perl
Sqlite perl
Ashoka Vanjare
 
Learn PHP Lacture2
Learn PHP Lacture2
ADARSH BHATT
 
veracruz
veracruz
tutorialsruby
 
Mysql & Php
Mysql & Php
Inbal Geffen
 
9780538745840 ppt ch06
9780538745840 ppt ch06
Terry Yoast
 
Stored Procedure
Stored Procedure
NidiaRamirez07
 
9780538745840 ppt ch08
9780538745840 ppt ch08
Terry Yoast
 

Similar to Php and database functionality (20)

20141011 mastering mysqlnd
20141011 mastering mysqlnd
do_aki
 
Mysqlnd, an unknown powerful PHP extension
Mysqlnd, an unknown powerful PHP extension
julien pauli
 
Php and MySQL Web Development
Php and MySQL Web Development
w3ondemand
 
Php MySql For Beginners
Php MySql For Beginners
Priti Solanki
 
Intro to PECL/mysqlnd_ms (4/7/2011)
Intro to PECL/mysqlnd_ms (4/7/2011)
Chris Barber
 
PHP and Mysql
PHP and Mysql
Sankhadeep Roy
 
Mysql connection
Mysql connection
beben benzy
 
Lect_04b_PhpMysqlKEY PERFORMANCE INDICATOR FOR ICT-UNIT (new).ppt
Lect_04b_PhpMysqlKEY PERFORMANCE INDICATOR FOR ICT-UNIT (new).ppt
SenzotaSemakuwa
 
7. PHP and gaghhgashgfsgajhfkhshfasMySQL.pptx
7. PHP and gaghhgashgfsgajhfkhshfasMySQL.pptx
berihun18
 
Db function
Db function
JIGAR MAKHIJA
 
Php verses my sql
Php verses my sql
SEO Training in Chandigarh
 
PHP - PDO Objects
PHP - PDO Objects
AJINKYA N
 
Module 6WEB SERVER AND SERVER SIDE SCRPTING, PART-2Chapte.docx
Module 6WEB SERVER AND SERVER SIDE SCRPTING, PART-2Chapte.docx
moirarandell
 
Php verses MySQL
Php verses MySQL
CBitss Technologies
 
Php verses MySQL
Php verses MySQL
CBitss Technologies
 
Web app development_crud_13
Web app development_crud_13
Hassen Poreya
 
Python my sql database connection
Python my sql database connection
Learnbay Datascience
 
Collection of built in functions for manipulating MySQL databases.docx
Collection of built in functions for manipulating MySQL databases.docx
KingKhaliilHayat
 
Synapse india complain sharing info about php chaptr 26
Synapse india complain sharing info about php chaptr 26
SynapseindiaComplaints
 
Migrating from PHP 4 to PHP 5
Migrating from PHP 4 to PHP 5
John Coggeshall
 
20141011 mastering mysqlnd
20141011 mastering mysqlnd
do_aki
 
Mysqlnd, an unknown powerful PHP extension
Mysqlnd, an unknown powerful PHP extension
julien pauli
 
Php and MySQL Web Development
Php and MySQL Web Development
w3ondemand
 
Php MySql For Beginners
Php MySql For Beginners
Priti Solanki
 
Intro to PECL/mysqlnd_ms (4/7/2011)
Intro to PECL/mysqlnd_ms (4/7/2011)
Chris Barber
 
Mysql connection
Mysql connection
beben benzy
 
Lect_04b_PhpMysqlKEY PERFORMANCE INDICATOR FOR ICT-UNIT (new).ppt
Lect_04b_PhpMysqlKEY PERFORMANCE INDICATOR FOR ICT-UNIT (new).ppt
SenzotaSemakuwa
 
7. PHP and gaghhgashgfsgajhfkhshfasMySQL.pptx
7. PHP and gaghhgashgfsgajhfkhshfasMySQL.pptx
berihun18
 
PHP - PDO Objects
PHP - PDO Objects
AJINKYA N
 
Module 6WEB SERVER AND SERVER SIDE SCRPTING, PART-2Chapte.docx
Module 6WEB SERVER AND SERVER SIDE SCRPTING, PART-2Chapte.docx
moirarandell
 
Web app development_crud_13
Web app development_crud_13
Hassen Poreya
 
Collection of built in functions for manipulating MySQL databases.docx
Collection of built in functions for manipulating MySQL databases.docx
KingKhaliilHayat
 
Synapse india complain sharing info about php chaptr 26
Synapse india complain sharing info about php chaptr 26
SynapseindiaComplaints
 
Migrating from PHP 4 to PHP 5
Migrating from PHP 4 to PHP 5
John Coggeshall
 
Ad

More from Sayed Ahmed (20)

Workplace, Data Analytics, and Ethics
Workplace, Data Analytics, and Ethics
Sayed Ahmed
 
Python py charm anaconda jupyter installation and basic commands
Python py charm anaconda jupyter installation and basic commands
Sayed Ahmed
 
[not edited] Demo on mobile app development using ionic framework
[not edited] Demo on mobile app development using ionic framework
Sayed Ahmed
 
Sap hana-ide-overview-nodev
Sap hana-ide-overview-nodev
Sayed Ahmed
 
Invest wisely
Invest wisely
Sayed Ahmed
 
Will be an introduction to
Will be an introduction to
Sayed Ahmed
 
Whm and cpanel overview hosting control panel overview
Whm and cpanel overview hosting control panel overview
Sayed Ahmed
 
Web application development using zend framework
Web application development using zend framework
Sayed Ahmed
 
Web design and_html_part_3
Web design and_html_part_3
Sayed Ahmed
 
Web design and_html_part_2
Web design and_html_part_2
Sayed Ahmed
 
Web design and_html
Web design and_html
Sayed Ahmed
 
Visual studio ide shortcuts
Visual studio ide shortcuts
Sayed Ahmed
 
Virtualization
Virtualization
Sayed Ahmed
 
User interfaces
User interfaces
Sayed Ahmed
 
Unreal
Unreal
Sayed Ahmed
 
Unit tests in_symfony
Unit tests in_symfony
Sayed Ahmed
 
Telerik this is sayed
Telerik this is sayed
Sayed Ahmed
 
System analysis and_design
System analysis and_design
Sayed Ahmed
 
Symfony 2
Symfony 2
Sayed Ahmed
 
Story telling and_narrative
Story telling and_narrative
Sayed Ahmed
 
Workplace, Data Analytics, and Ethics
Workplace, Data Analytics, and Ethics
Sayed Ahmed
 
Python py charm anaconda jupyter installation and basic commands
Python py charm anaconda jupyter installation and basic commands
Sayed Ahmed
 
[not edited] Demo on mobile app development using ionic framework
[not edited] Demo on mobile app development using ionic framework
Sayed Ahmed
 
Sap hana-ide-overview-nodev
Sap hana-ide-overview-nodev
Sayed Ahmed
 
Will be an introduction to
Will be an introduction to
Sayed Ahmed
 
Whm and cpanel overview hosting control panel overview
Whm and cpanel overview hosting control panel overview
Sayed Ahmed
 
Web application development using zend framework
Web application development using zend framework
Sayed Ahmed
 
Web design and_html_part_3
Web design and_html_part_3
Sayed Ahmed
 
Web design and_html_part_2
Web design and_html_part_2
Sayed Ahmed
 
Web design and_html
Web design and_html
Sayed Ahmed
 
Visual studio ide shortcuts
Visual studio ide shortcuts
Sayed Ahmed
 
Unit tests in_symfony
Unit tests in_symfony
Sayed Ahmed
 
Telerik this is sayed
Telerik this is sayed
Sayed Ahmed
 
System analysis and_design
System analysis and_design
Sayed Ahmed
 
Story telling and_narrative
Story telling and_narrative
Sayed Ahmed
 
Ad

Recently uploaded (20)

Bridging the divide: A conversation on tariffs today in the book industry - T...
Bridging the divide: A conversation on tariffs today in the book industry - T...
BookNet Canada
 
ENERGY CONSUMPTION CALCULATION IN ENERGY-EFFICIENT AIR CONDITIONER.pdf
ENERGY CONSUMPTION CALCULATION IN ENERGY-EFFICIENT AIR CONDITIONER.pdf
Muhammad Rizwan Akram
 
Oracle Cloud Infrastructure Generative AI Professional
Oracle Cloud Infrastructure Generative AI Professional
VICTOR MAESTRE RAMIREZ
 
Crypto Super 500 - 14th Report - June2025.pdf
Crypto Super 500 - 14th Report - June2025.pdf
Stephen Perrenod
 
War_And_Cyber_3_Years_Of_Struggle_And_Lessons_For_Global_Security.pdf
War_And_Cyber_3_Years_Of_Struggle_And_Lessons_For_Global_Security.pdf
biswajitbanerjee38
 
Data Validation and System Interoperability
Data Validation and System Interoperability
Safe Software
 
Edge-banding-machines-edgeteq-s-200-en-.pdf
Edge-banding-machines-edgeteq-s-200-en-.pdf
AmirStern2
 
FME for Distribution & Transmission Integrity Management Program (DIMP & TIMP)
FME for Distribution & Transmission Integrity Management Program (DIMP & TIMP)
Safe Software
 
Agentic AI: Beyond the Buzz- LangGraph Studio V2
Agentic AI: Beyond the Buzz- LangGraph Studio V2
Shashikant Jagtap
 
Integration of Utility Data into 3D BIM Models Using a 3D Solids Modeling Wor...
Integration of Utility Data into 3D BIM Models Using a 3D Solids Modeling Wor...
Safe Software
 
The State of Web3 Industry- Industry Report
The State of Web3 Industry- Industry Report
Liveplex
 
cnc-drilling-dowel-inserting-machine-drillteq-d-510-english.pdf
cnc-drilling-dowel-inserting-machine-drillteq-d-510-english.pdf
AmirStern2
 
Murdledescargadarkweb.pdfvolumen1 100 elementary
Murdledescargadarkweb.pdfvolumen1 100 elementary
JorgeSemperteguiMont
 
“Addressing Evolving AI Model Challenges Through Memory and Storage,” a Prese...
“Addressing Evolving AI Model Challenges Through Memory and Storage,” a Prese...
Edge AI and Vision Alliance
 
FIDO Seminar: Perspectives on Passkeys & Consumer Adoption.pptx
FIDO Seminar: Perspectives on Passkeys & Consumer Adoption.pptx
FIDO Alliance
 
FIDO Seminar: Evolving Landscape of Post-Quantum Cryptography.pptx
FIDO Seminar: Evolving Landscape of Post-Quantum Cryptography.pptx
FIDO Alliance
 
Kubernetes Security Act Now Before It’s Too Late
Kubernetes Security Act Now Before It’s Too Late
Michael Furman
 
Oracle Cloud and AI Specialization Program
Oracle Cloud and AI Specialization Program
VICTOR MAESTRE RAMIREZ
 
FIDO Seminar: Targeting Trust: The Future of Identity in the Workforce.pptx
FIDO Seminar: Targeting Trust: The Future of Identity in the Workforce.pptx
FIDO Alliance
 
FIDO Seminar: New Data: Passkey Adoption in the Workforce.pptx
FIDO Seminar: New Data: Passkey Adoption in the Workforce.pptx
FIDO Alliance
 
Bridging the divide: A conversation on tariffs today in the book industry - T...
Bridging the divide: A conversation on tariffs today in the book industry - T...
BookNet Canada
 
ENERGY CONSUMPTION CALCULATION IN ENERGY-EFFICIENT AIR CONDITIONER.pdf
ENERGY CONSUMPTION CALCULATION IN ENERGY-EFFICIENT AIR CONDITIONER.pdf
Muhammad Rizwan Akram
 
Oracle Cloud Infrastructure Generative AI Professional
Oracle Cloud Infrastructure Generative AI Professional
VICTOR MAESTRE RAMIREZ
 
Crypto Super 500 - 14th Report - June2025.pdf
Crypto Super 500 - 14th Report - June2025.pdf
Stephen Perrenod
 
War_And_Cyber_3_Years_Of_Struggle_And_Lessons_For_Global_Security.pdf
War_And_Cyber_3_Years_Of_Struggle_And_Lessons_For_Global_Security.pdf
biswajitbanerjee38
 
Data Validation and System Interoperability
Data Validation and System Interoperability
Safe Software
 
Edge-banding-machines-edgeteq-s-200-en-.pdf
Edge-banding-machines-edgeteq-s-200-en-.pdf
AmirStern2
 
FME for Distribution & Transmission Integrity Management Program (DIMP & TIMP)
FME for Distribution & Transmission Integrity Management Program (DIMP & TIMP)
Safe Software
 
Agentic AI: Beyond the Buzz- LangGraph Studio V2
Agentic AI: Beyond the Buzz- LangGraph Studio V2
Shashikant Jagtap
 
Integration of Utility Data into 3D BIM Models Using a 3D Solids Modeling Wor...
Integration of Utility Data into 3D BIM Models Using a 3D Solids Modeling Wor...
Safe Software
 
The State of Web3 Industry- Industry Report
The State of Web3 Industry- Industry Report
Liveplex
 
cnc-drilling-dowel-inserting-machine-drillteq-d-510-english.pdf
cnc-drilling-dowel-inserting-machine-drillteq-d-510-english.pdf
AmirStern2
 
Murdledescargadarkweb.pdfvolumen1 100 elementary
Murdledescargadarkweb.pdfvolumen1 100 elementary
JorgeSemperteguiMont
 
“Addressing Evolving AI Model Challenges Through Memory and Storage,” a Prese...
“Addressing Evolving AI Model Challenges Through Memory and Storage,” a Prese...
Edge AI and Vision Alliance
 
FIDO Seminar: Perspectives on Passkeys & Consumer Adoption.pptx
FIDO Seminar: Perspectives on Passkeys & Consumer Adoption.pptx
FIDO Alliance
 
FIDO Seminar: Evolving Landscape of Post-Quantum Cryptography.pptx
FIDO Seminar: Evolving Landscape of Post-Quantum Cryptography.pptx
FIDO Alliance
 
Kubernetes Security Act Now Before It’s Too Late
Kubernetes Security Act Now Before It’s Too Late
Michael Furman
 
Oracle Cloud and AI Specialization Program
Oracle Cloud and AI Specialization Program
VICTOR MAESTRE RAMIREZ
 
FIDO Seminar: Targeting Trust: The Future of Identity in the Workforce.pptx
FIDO Seminar: Targeting Trust: The Future of Identity in the Workforce.pptx
FIDO Alliance
 
FIDO Seminar: New Data: Passkey Adoption in the Workforce.pptx
FIDO Seminar: New Data: Passkey Adoption in the Workforce.pptx
FIDO Alliance
 

Php and database functionality

  • 1. PHP, PHP FRAMEWORKS AND DATABASE Sayed Ahmed Computer Engineering, BUET, Bangladesh MSC, Computer Science, U of Manitoba, Canada http://www.JustEtc.net http://sayed.justetc.net [email protected]
  • 2. TOPICS  Connection strategies  Configuration for connection in different frameworks  PHP and DB2, MSSQL Server  Common database oriented operations  Reference to DB oriented functions/classes
  • 3. CONNECTION  mysql_connect  mysqli_connect  PDO  PDO_ODBC  Connection from Frameworks  Code Igniter – configure for db connection  CakePHP - configure for db connection  Zend - configure for db connection
  • 4. PDO VS MYSQLI  Overall, PDO is a better choice than mysqli  However, if performance is the only issue that you care, and  mysql will be the backend database all the time,  you can use mysqli  Reference:  http://net.tutsplus.com/tutorials/php/pdo-vs- mysqli-which-should-you-use/
  • 5. MYSQL_CONNECT  mysql_connect  Opens a connection to a MySQL Server  Deprecated as of PHP 5.5.0, and will be removed in the future.  Instead use MySQLi or PDO_MySQL  mysql_connect examples
  • 8. MYSQLI_CONNECT — ALIAS OF MYSQLI::__CONSTRUCT()
  • 11. OBJECT ORIENTED STYLE CONNECTION WITH MYSQLI
  • 13. PDO CONNECTION WHEN PARAMETERS IN A FILE
  • 14. PDO USING PHP.INI CONFIGURATIONS
  • 15. CODE IGNITER DATABASE CONFIGURATION  application/config/database.php  $db['default']['hostname'] = "localhost"; $db['default']['username'] = "root"; $db['default']['password'] = ""; $db['default']['database'] = "database_name"; $db['default']['dbdriver'] = "mysql"; $db['default']['dbprefix'] = ""; $db['default']['pconnect'] = TRUE; $db['default']['db_debug'] = FALSE; $db['default']['cache_on'] = FALSE; $db['default']['cachedir'] = ""; $db['default']['char_set'] = "utf8"; $db['default']['dbcollat'] = "utf8_general_ci"; $db['default']['swap_pre'] = ""; $db['default']['autoinit'] = TRUE; $db['default']['stricton'] = FALSE;  Reference:  http://ellislab.com/codeigniter/user-guide/database/configuration.html
  • 16. CAKEPHP AND MYSQL  A copy of CakePHP’s database configuration file is found in  /app/Config/database.php.default  Make a copy of this file in the same directory, but name it  database.php  Change database.php as follows
  • 18. ZEND AND DATABASE CONFIGURATION  Zend_Config_Ini enables developers to store configuration data in a familiar INI format
  • 19. PDO AND PREPARED STATEMENTS
  • 20. PDO FETCH AND PREPARED STMT
  • 21. PDO AND STORED PROCEDURE (OUT PARAM)
  • 22. PDO STRD PROC WITH IN/OUT PARAMS
  • 23. MYSQLI AND STORED PROCEDURE
  • 24. MYSQLI FETCHING RESULTS FROM STORED PROCEDURES
  • 25. PHP FUNCTIONS FOR SQL SERVER  The name of the functions may closely resemble the functionality.  # mssql_ bind # mssql_ close # mssql_ connect # mssql_ data_ seek # mssql_ execute # mssql_ fetch_ array # mssql_ fetch_ assoc # mssql_ fetch_ batch # mssql_ fetch_ field # mssql_ fetch_ object # mssql_ fetch_ row # mssql_ field_ length # mssql_ field_ name # mssql_ field_ seek # mssql_ field_ type # mssql_ free_ result # mssql_ free_ statement
  • 26. PHP FUNCTIONS FOR SQL SERVER  # mssql_ get_ last_ message # mssql_ guid_ string # mssql_ init # mssql_ min_ error_ severity # mssql_ min_ message_ severity # mssql_ next_ result # mssql_ num_ fields # mssql_ num_ rows # mssql_ pconnect # mssql_ query # mssql_ result # mssql_ rows_ affected # mssql_ select_ db
  • 27. PHP AND IBM DB2  PHP has concepts like PDO and PDO_ODBC, and generic odbc features that will allow you to connect to and work with DB-2 databases. Generic odbc is the general/procedural way to connect to. PDO and PDO_ODBC are object oriented ways. PDO works with native IBM drivers. PDO_ODBC uses odbc connections to the DB2. For PHP you need to install drivers to support DB2. I worked with PDO_ODBC to connect to DB-2 databases in IBM iSeries servers. You need to install odbc db2 drivers for iseries servers. Then in /etc/odbcinst.ini file you need to mention driver specifications and in /etc/odbc.ini, you need to mention the odbc dsn name, database name, and some other parameters to connect to the database. Though, you may also supply some parameters in the PDO_ODBC connect method.
  • 28. PHP AND SQL SERVER STORED PROCEDURE
  • 29. PHP AND SQL SERVER STORED PROCEDURE
  • 33. MYSQLI — THE MYSQLI CLASS  mysqli::$affected_rows — Gets the number of affected rows in a previous MySQL operation  mysqli::autocommit — Turns on or off auto-committing database modifications  mysqli::begin_transaction — Starts a transaction  mysqli::change_user — Changes the user of the specified database connection  mysqli::character_set_name — Returns the default character set for the database connection  mysqli::$client_info — Get MySQL client info  mysqli::$client_version — Returns the MySQL client version as a stringmysqli::close — Closes a previously opened database connection
  • 34. MYSQLI — THE MYSQLI CLASS  mysqli::commit — Commits the current transaction  mysqli::$connect_errno — Returns the error code from last connect call  mysqli::$connect_error — Returns a string description of the last connect error  mysqli::__construct — Open a new connection to the MySQL server  mysqli::debug — Performs debugging operations  mysqli::dump_debug_info — Dump debugging information into the log  mysqli::$errno — Returns the error code for the most recent function call
  • 35. MYSQLI — THE MYSQLI CLASS  mysqli::$error_list — Returns a list of errors from the last command executed  mysqli::$error — Returns a string description of the last error  mysqli::$field_count — Returns the number of columns for the most recent query  mysqli::get_charset — Returns a character set objectmysqli::get_client_info — Get MySQL client info  mysqli_get_client_stats — Returns client per-process statistics  mysqli_get_client_version — Returns the MySQL client version as an integer  mysqli::get_connection_stats — Returns statistics about the client connection  mysqli::$host_info — Returns a string representing the type of connection used  mysqli::$protocol_version — Returns the version of the MySQL protocol used  mysqli::$server_info — Returns the version of the MySQL server  mysqli::$server_version — Returns the version of the MySQL server as an integer  mysqli::get_warnings — Get result of SHOW WARNINGS
  • 36. MYSQLI — THE MYSQLI CLASS  mysqli::$info — Retrieves information about the most recently executed querymysqli::init — Initializes MySQLi and returns a resource for use with mysqli_real_connect()mysqli::$insert_id — Returns the auto generated id used in the last querymysqli::kill — Asks the server to kill a MySQL threadmysqli::more_results — Check if there are any more query results from a multi querymysqli::multi_query — Performs a query on the databasemysqli::next_result — Prepare next result from multi_querymysqli::options — Set optionsmysqli::ping — Pings a server connection, or tries to reconnect if the connection has gone downmysqli::poll — Poll connectionsmysqli::prepare — Prepare an SQL statement for executionmysqli::query — Performs a query on the databasemysqli::real_connect — Opens a connection to a mysql servermysqli::real_escape_string — Escapes special characters in a string for use in an SQL statement, taking into account the current charset of the connectionmysqli::real_query — Execute an SQL query
  • 37. MYSQLI_STMT — THE MYSQLI_STMT CLASS  mysqli_stmt::$affected_rows — Returns the total number of rows changed, deleted, or inserted by the last executed statementmysqli_stmt::attr_get — Used to get the current value of a statement attributemysqli_stmt::attr_set — Used to modify the behavior of a prepared statementmysqli_stmt::bind_param — Binds variables to a prepared statement as parametersmysqli_stmt::bind_result — Binds variables to a prepared statement for result storagemysqli_stmt::close — Closes a prepared statementmysqli_stmt::data_seek — Seeks to an arbitrary row in statement result setmysqli_stmt::$errno — Returns the error code for the most recent statement callmysqli_stmt::$error_list — Returns a list of errors from the last statement executed
  • 38. MYSQLI_RESULT — THE MYSQLI_RESULT CLASS  mysqli_result::$current_field — Get current field offset of a result pointermysqli_result::data_seek — Adjusts the result pointer to an arbitrary row in the resultmysqli_result::fetch_all — Fetches all result rows as an associative array, a numeric array, or bothmysqli_result::fetch_array — Fetch a result row as an associative, a numeric array, or bothmysqli_result::fetch_assoc — Fetch a result row as an associative arraymysqli_result::fetch_field_direct — Fetch meta-data for a single fieldmysqli_result::fetch_field — Returns the next field in the result setmysqli_result::fetch_fields — Returns an array of objects representing the fields in a result setmysqli_result::fetch_object — Returns the current row of a result set as an objectmysqli_result::fetch_row — Get a result row as an enumerated array
  • 39. MYSQLI_DRIVER, MYSQLI_WARNING  mysqli_driver — The mysqli_driver classmysqli_driver::embedded_server_end — Stop embedded server  mysqli_driver::embedded_server_start — Initialize and start embedded server  mysqli_driver::$report_mode — Enables or disables internal report functions  mysqli_warning — The mysqli_warning classmysqli_warning::__construct — The __construct purpose  mysqli_warning::next — The next purpose  mysqli_sql_exception — The mysqli_sql_exception class
  • 40. PDO — THE PDO CLASS  PDO::beginTransaction — Initiates a transactionPDO::commit — Commits a transactionPDO::__construct — Creates a PDO instance representing a connection to a databasePDO::errorCode — Fetch the SQLSTATE associated with the last operation on the database handlePDO::errorInfo — Fetch extended error information associated with the last operation on the database handlePDO::exec — Execute an SQL statement and return the number of affected rowsPDO::getAttribute — Retrieve a database connection attribute
  • 41. PDOSTATEMENT — THE PDOSTATEMENT CLASS  PDOStatement::bindColumn — Bind a column to a PHP variablePDOStatement::bindParam — Binds a parameter to the specified variable namePDOStatement::bindValue — Binds a value to a parameterPDOStatement::closeCursor — Closes the cursor, enabling the statement to be executed again.PDOStatement::columnCount — Returns the number of columns in the result setPDOStatement::debugDumpParams — Dump an SQL prepared commandPDOStatement::errorCode — Fetch the SQLSTATE associated with the last operation on the statement handlePDOStatement::errorInfo — Fetch extended error information associated with the last operation on the statement handle
  • 42. PDOEXCEPTION, MISC  PDOException — The PDOException class  PDO DriversCUBRID (PDO) — CUBRID Functions (PDO_CUBRID)  MS SQL Server (PDO) — Microsoft SQL Server and Sybase Functions (PDO_DBLIB)  Firebird/Interbase (PDO) — Firebird/Interbase Functions (PDO_FIREBIRD)  IBM (PDO) — IBM Functions (PDO_IBM)