Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,037

HOME > PHP > PHP Forum > เปลี่ยนจาก procedural เป็น pdo หรือ mysqli กันเถอะ



 

เปลี่ยนจาก procedural เป็น pdo หรือ mysqli กันเถอะ

 



Topic : 110045



โพสกระทู้ ( 484 )
บทความ ( 3 )



สถานะออฟไลน์




เนื่องจาก PHP Version ที่สูงๆ ขึ้นจะตัดพวก procedural ออกไปแล้ว

ดังนั้นควรเปลี่ยนมาใช้ mysqli หรือ pdo กันดีกว่า

ข้อดีของ pdo รองรับ driver ได้หลายตัวเช่น


PDO Drivers
CUBRID (PDO) — CUBRID Functions (PDO_CUBRID)
MS SQL Server (PDO) — Microsoft SQL Server and Sybase Functions (PDO_DBLIB)
Firebird (PDO) — Firebird Functions (PDO_FIREBIRD)
IBM (PDO) — IBM Functions (PDO_IBM)
Informix (PDO) — Informix Functions (PDO_INFORMIX)
MySQL (PDO) — MySQL Functions (PDO_MYSQL)
MS SQL Server (PDO) — Microsoft SQL Server Functions (PDO_SQLSRV)
Oracle (PDO) — Oracle Functions (PDO_OCI)
ODBC and DB2 (PDO) — ODBC and DB2 Functions (PDO_ODBC)
PostgreSQL (PDO) — PostgreSQL Functions (PDO_PGSQL)
SQLite (PDO) — SQLite Functions (PDO_SQLITE)
4D (PDO) — 4D Functions (PDO_4D)


และ extension ก็มีมาพร้อมกับ php เลย

http://th1.php.net/manual/en/book.pdo.php

ตัวอย่าง code

Example #1 Prepare an SQL statement with named parameters

Code (PHP)
<?php
/* Execute a prepared statement by passing an array of values */
$sql = 'SELECT name, colour, calories
    FROM fruit
    WHERE calories < :calories AND colour = :colour';
$sth = $dbh->prepare($sql, array(PDO::ATTR_CURSOR => PDO::CURSOR_FWDONLY));
$sth->execute(array(':calories' => 150, ':colour' => 'red'));
$red = $sth->fetchAll();
$sth->execute(array(':calories' => 175, ':colour' => 'yellow'));
$yellow = $sth->fetchAll();
?>
Example #2 Prepare an SQL statement with question mark parameters

<?php
/* Execute a prepared statement by passing an array of values */
$sth = $dbh->prepare('SELECT name, colour, calories
    FROM fruit
    WHERE calories < ? AND colour = ?');
$sth->execute(array(150, 'red'));
$red = $sth->fetchAll();
$sth->execute(array(175, 'yellow'));
$yellow = $sth->fetchAll();
?>


หรือ ไม่ก็เปลี่ยนไปใช้ MVC เลยครับ 55+



Tag : PHP







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2014-07-19 09:36:41 By : fossil31 View : 5602 Reply : 10
 

 

No. 1



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook








แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-07-19 09:48:35 By : mr.win
 


 

No. 2



โพสกระทู้ ( 9,586 )
บทความ ( 2 )



สถานะออฟไลน์


สำหรับผมคงไม่เปลี่ยนล่ะครับ

จะเปลี่ยนก็จนกว่า Server ที่ผมดูแลอยู่เขาเปลี่ยน version PHP หรือ MySql แหล่ะครับ

แต่ส่วนใหญ่ ถ้า Admin ไม่ใช่เด็กใหม่ไฟแรง ก็ไม่ค่อยมีใครอยากเปลี่ยนหรอกครับ เมื่อมันยังใช้ได้
ส่วนใหญ่ก็จะปล่อยมันไป ใช้งานได้ก็พอแล้ว ถ้าต้องมาเปลี่ยน โครงสร้างการเขียนใหม่
มันน่าปวดหัวนะครับ 55555

ที่พูดนี้ไม่ใช่ไม่ยอมเปลี่ยนนะครับ แต่ก็คงอีกนานแหล่ะกว่าของเก่ามันจะตาย
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-07-19 22:56:00 By : Chaidhanan
 

 

No. 3



โพสกระทู้ ( 10 )
บทความ ( 0 )



สถานะออฟไลน์


ตอบความคิดเห็นที่ : 2 เขียนโดย : Chaidhanan เมื่อวันที่ 2014-07-19 22:56:00
รายละเอียดของการตอบ ::
ผมเคยชื่นชมคุณลุงนะคับ

แต่คุณลุงตอบแบบนี้มันทำให้ผมเปลี่ยนใจแล้ว

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-07-20 00:07:42 By : mr.e
 


 

No. 4



โพสกระทู้ ( 5,149 )
บทความ ( 26 )

สมาชิกที่ใส่เสื้อไทยครีเอท Hall of Fame 2012

สถานะออฟไลน์


ไม่รู้สิครับ มันแล้วแต่งานครับ

บางงาน ที่ทำให้ลูกค้า ที่เขาต้องใช้กับ ฐานข้อมูลที่บางทีก็ใช้ ms sql , mysql หรือตั้งแต่ 2 ขึ้นไป ผมถึงใช้ pdo

ส่วนงานอื่น ๆ ผมก็ยังใช้ PHP PURE เหมือนเดิมครับ.

ป.ลิง .. ระบบงานหลักที่ใช้ในออฟฟิศผม ก็ CODE PURE คือกันครับ.
หากมาเขียนให่ม่ คงเรื่องใหญ่ครับ.

มันขึ้นอยู่กับลักษณะงานมากกว่าครับ ตามความเห็นส่วนตัว ผมคนเดียวนะครับ.
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-07-20 07:58:21 By : deawx
 


 

No. 5



โพสกระทู้ ( 9,586 )
บทความ ( 2 )



สถานะออฟไลน์


ตอบความคิดเห็นที่ : 3 เขียนโดย : mr.e เมื่อวันที่ 2014-07-20 00:07:42
รายละเอียดของการตอบ ::
แล้วคุณจะให้ผมเปลี่ยนได้ยังไงครับ ในเมื่อเจ้าของ Server เขาไม่ยอมเปลี่ยน
สำหรับผมแล้ว เปลี่ยนตามลูกค้าครับ ถ้า Server ของลูกค้าเป็นของใหม่
แล้วอยากใช้ของใหม่ทุกอย่าง ผมก็ใช้ของใหม่ทำให้ครับ แต่ราคาก็จะเปลี่ยนไปตาม knowhow ครับ
เมื่อเป็นของใหม่ ค่าประสบการณ์ในการเรียนรู้มันก็ตามมาครับ แต่ถ้าใช้ของเก่าที่มีต้นทุนเดิมอยู่แล้ว
ราคาก็ถูกลงหน่อยครับ และสิ่งสำคัญผมไม่ค่อยเจอลูกค้าที่อยากเปลี่ยนของใหม่เพื่อเพิ่มค่าใช้จ่ายนะครับ

แต่ถ้าเป็นการศึกษาหาความรู้ ศึกษาของใหม่ไว้ไม่เสียหลายครับ PDO MySqliผมก็เคยลองศึกษามาก่อนแล้วครับ
ก็แค่เปลี่ยนวิธีการเรียกใช้จาก ฟังก์ชั่นไปเป็นการเรียกใช้แบบ class ก็เท่านั้นครับ ส่วน วิธีการเชื่อมต่อกับ server
ก็ยังใช้ protocol ตัวเดิม ไม่ได้ทำให้ความเร็วในการทำงานเร็วขึ้น

ถ้าจะพูดถึงการเขียนที่เร็วขึ้น ครับมันทำให้เขียนง่ายขึ้น แต่มันเหมาะกับคนที่ยังไม่เคยเรียนมาก่อน
ถ้าจะมาศึกษาก็ควรศึกษาตัวใหม่เลยครับ เพราะโลกมันต้องพัฒนาขึ้น จะมาเรียนของเก่าที่มีฟังก์ชั่นทำงานอย่างจำกัดทำไม
ในเมื่อของใหม่มี ฟังก์ชั่นให้ใช้งานมากกว่า ไม่ต้องมานั้งสร้างฟังก์ชั่นใหม่ขึ้นเอง แต่สำหรับผมประสบการณ์ในการเขียน
ทำให้ผมสามารถ modify งานทุกอย่าง จากโค๊ดพื้นๆ ให้ทำงานได้รวดเร็วตามต้องการของลูกค้า นั้นก็เพี่ยงพอสำหรับผมแล้วครับ
เพราะทุกฟังก์ชั่นใหม่ที่เขียนขึ้น มันก็ไม่ได้หนีไปจากคำสั่งภาษาเครื่อง หรือ API ที่เหมือนกัน หรอกครับ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-07-20 08:34:22 By : Chaidhanan
 


 

No. 6



โพสกระทู้ ( 484 )
บทความ ( 3 )



สถานะออฟไลน์


ในแง่ความปลอดภัย เช่น sql injection ไม่ต้องใช้ function เพิ่มเติม มากมาย
และเขียนได้ลื่นกว่า และลด code
ตรงนี้น่าจะเป็นจุดที่หลายๆ ท่านชอบ เหมือนผมครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-07-20 21:36:04 By : fossil31
 


 

No. 7



โพสกระทู้ ( 86 )
บทความ ( 0 )



สถานะออฟไลน์
Facebook

ตอนนี้ Host ส่วนใหญ่ก็ซัพพอร์ท Mysqli นะครับ ผมว่าเปลี่ยนแต่เนิ่น ๆ ดีกว่าครับ โปรเจคผมจะสร้างส่วนของคอนเนทชั่นและคิวรี่ต่าง ๆ ไว้ต่างหากเลย ซึ่งนั่นทำให้ง่ายต่อการเปลี่ยนรูปแบบการเชื่อมต่อหรือประเภทฐานข้อมูล ครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-07-21 08:47:36 By : soghband
 


 

No. 8



โพสกระทู้ ( 484 )
บทความ ( 3 )



สถานะออฟไลน์


Doctrine2 ORM+Active Record ก็ใช้ Driver pdo แล้ว

http://www.doctrine-project.org/projects/orm.html

*** Active Record ของ CI ยังเป็น procedural อยู่เลย

Doctrine2 Plugin เข้าไปใช้เจ๋วกว่าครับ

<?php

$u = Doctrine::getTable('User');

print_r($u);

//=========================================

user_id = 1;

$u = Doctrine::getTable('User')->find($user_id);

$u->delete();
?>

เขียนลื่นดีครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-07-21 09:27:16 By : fossil31
 


 

No. 9



โพสกระทู้ ( 86 )
บทความ ( 0 )



สถานะออฟไลน์
Facebook

PDO นี่น่าสนใจมากเดี๋ยวปรับระบบให้เป็น PDO น่าจะเวิร์คขึ้นเยอะ เวลา นำไปใช้กับญฐานข้อมูลรูปแบบอื่นแค่เปลี่ยนนิดหน่อยเอง แต่มีคำถามว่า Process ของ PDO กับ mysqli ใช้ทรัพยกรมากน้อยกว่ากันขนาดใหน และ มีข้อดีข้อเสียต่างกันอย่างไร


ประวัติการแก้ไข
2014-07-21 10:11:05
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-07-21 09:57:23 By : soghband
 


 

No. 10



โพสกระทู้ ( 484 )
บทความ ( 3 )



สถานะออฟไลน์


ยังไม่ได้เลย Test Performance ครับ
ว่างๆ จะลองเปรียบเทียบ mktime การ CRUD มาดูครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-07-21 10:02:50 By : fossil31
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : เปลี่ยนจาก procedural เป็น pdo หรือ mysqli กันเถอะ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 04
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2024 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่