php workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من...

24
PHP Workshop 1 ك ع دا ب ا ق ل ط ا ك ع دا ب ا ق ل ط ا2 2 ووم ز ز ك ر م ن م مد ت ع م مدزسPHP Data Object (PDO)

Upload: valerie-nancy-walker

Post on 18-Jan-2016

227 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 1 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

PHP Data Object (PDO)

Page 2: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 2 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

What is PDO?

• PDO is a PHP extension to formalise PHP's database connections by creating a

uniform interface. This allows developers to create code which is portable across

many databases and platforms.

• PDO is not just another abstraction layer like PEAR DB or ADOdb.

Page 3: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 3 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Why use PDO?

• Portability

• Performance

• Power

• Easy

• Runtime Extensible

Page 4: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 4 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

What databases does it support?

• Microsoft SQL Server / Sybase

• Firebird / Interbase

• DB2 / INFORMIX (IBM)

• MySQL

• OCI (Oracle Call Interface)

• ODBC

• PostgreSQL

• SQLite

Page 5: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 5 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

DSNs

• In general

drivername:<driver-specific-stuff>

• mysql:host=name;dbname=dbname

• odbc:odbc_dsn

• oci:dbname=dbname;charset=charset

• sqlite:/path/to/db/file

• sqlite::memory:

Page 6: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 6 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Connect to MySQL

Page 7: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 7 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Connect to SQLite (file)

Page 8: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 8 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Connect to SQLite (memory)

Page 9: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 9 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Connect to Oracle

Page 10: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 10 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Connect to ODBC

Page 11: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 11 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Close a Database Connection

Page 12: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 12 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Persistent PDO Connection

• Connection stays alive between requests

$dbh = new PDO($dsn, $user, $pass,array(

PDO_ATTR_PERSISTENT => true)

);

Page 13: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 13 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

PDO Query (INSERT)

Page 14: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 14 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

PDO Query (UPDATE)

Page 15: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 15 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

PDO Query (SELECT)

Page 16: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 16 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Error Handling (1)

Page 17: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 17 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Error Handling (2)

Page 18: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 18 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Error Handling (3)

Page 19: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 19 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Error Handling (4)

Page 20: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 20 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Prepared statements

Page 21: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 21 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Transactions

Page 22: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 22 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Get Last Insert Id

Page 23: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 23 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

BenchmarkMySQL SELECT Benchmark Results, 1000 Requests

Library Concurrency Total Time Requests/Sec. Speedup

ADOdb 1 20.90/sec 47.84 -

PDO 1 0.73/sec 1358.62 +2840%

ADOdb 50 10.78/sec 99.23 -

PDO 50 0.54/sec 1850.90 +1865%

ADOdb 100 10.44/sec 95.78 -

PDO 100 0.53/sec 1869.33 +1952%

Page 24: PHP Workshop ‹#› أطلق إبداعك 2 أطلق إبداعك 2 مدرس معتمد من مركز زووم PHP Data Object (PDO)

PHP Workshop إبداعك 24 إبداعك أطلق 22أطلقمن مدرسمعتمد

زووم مركز

Questions