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

Registered : 102,641


HOME > บทความจากสมาชิก > มาใช้ OOP ในการจัดการกับ Database PHP กับ MySQL กันเถอะ

มาใช้ OOP ในการจัดการกับ Database PHP กับ MySQL กันเถอะ

 
 
       
Bookmark.   
Share
       
มาใช้ OOP ในการจัดการกับ Database PHP กับ MySQL กันเถอะ ตอนนี้ผมกำลังทำ Project จบปี 4 อยู่ครับ เขียนโค้ดเชื่อมต่อกับ Database เยอะมาก เมื่อยมือหงิกเลย จึงนึกถึงวิชา JAVA+OOP ที่เคยเรียนมา ลองมา Adap ปรับใช้ดู ก็ได้ Class ที่จัดการเกี่ยวกับ Database มา 1 Class ทุกวันนี้ ขั้นตอนตั้งแต่ เชื่อมต่อ จนถึง ปิดการเชื่อมต่อ เสร็จสรรพภายใน 3-4 บรรทัดครับ แล้วบังเอิญได้ไปเห็น บทความของ คุณ nut_t02 >> http://www.thaicreate.com/php/forum/027334.html concept คล้ายๆกันจึงอยากจะเอา ความรู้ของผมมาแชร์ดูบ้างครับ ^^

การติดตั้ง
1. Copy Code function.php ด้านล่างไปครับ
2. เข้าไปตั้งค่า host, user, pass, ใน function.php ครับ


การใช้งาน
1. นำเข้าไฟล์เข้ามาก่อนครับ โดยใช้คำสั่งนี้ครับ
include("function.php"); //คำสั่งในการนำเข้าไฟล์ครับ 

2. สร้างตัวแปร Object ของ Class database ก่อนครับ โดยใช้คำสั่งนี้ครับ
$db = new database;

3. เชื่อมต่อฐานข้อมูล โดยใช้คำสั่งนี้ครับ
$db->con_db();

4. ทำการ Query ข้อมูล โดยใช้คำสั่งนี้ครับ
$sql1 = "คำสั่ง sql command ...";
$rs = $db->sql_cmd_select($sql1);
     //ใช้เฉพาะกับ SELECT ครับโดยคำสั่ง 
     //syntax : $db->sql_cmd_select("...sql command SELECT only..");
     //return : ค่าที่ SELECT มาเป็นชนิด Array
     //หลักจาก return แล้วก็ลงในตัวแปร $rs ครับ

$sql2 = "คำสั่ง sql command ...";
$rs = $db->sql_cmd($sql2); 
     //ใช้เฉพาะ INSERT, UPDATE, DELETE, ALTER ,ฯลฯ ครับ
     //syntax : $db->sql_cmd("...sql command อื่นๆ นอกจาก SELECT..");
     //return : ผลของการ Query เป็นชนิด boolean(true, false) ครับ
     //หลักจาก return แล้วก็ลงในตัวแปร $rs ครับ

5. การนำค่าไปใช้และตรวจสอบ

5.1) กรณี sql_cmd_select()
$rs = $db->sql_cmd_select($sql1);
if($rs[0]!=""){
     echo"ข้อมูล field ที่ 1 : ".$rs[0];
     echo"ข้อมูล field ที่ 2 : ".$rs[1];
}

5.2) กรณี sql_cmd_select()
$rs = $db->sql_cmd($sql2);
if($rs){
     echo "คำสั่งผ่าน";
}
else{
     echo "คำสั่งไม่ผ่าน";
}

6. การปิดการเชื่อมต่อ โดยใช้คำสั่งนี้ครับ
$db->close_db();



ผมสร้าง Function เสริมให้อีก 2 ตัวครับ

1. get_count() ใช้ในการดึงข้อมูลจำนวน record ในตารางนั้นๆครับ
$count = $db->get_count("ชื่อ table ในฐานข้อมูล");
     //syntax : $db->get_count("ชื่อ table ในฐานข้อมูล");
     //return : ผลของการ Query เป็นชนิด int ครับ
     //หลักจาก return แล้วก็ลงในตัวแปร $count ครับ

2. get_pk() ใช้ในการสร้าง PK key ตัวใหม่ โดยใช้ควบคู่กับ get_count()
$new_pk = $db->get_pk($count+1,"M");
     //syntax : $db->get_pk(ค่าcount+1,"char");
     //return : ผลของการ Query เป็นชนิด int ครับ
     //หลักจาก return แล้วก็ลงในตัวแปร $count ครับ
     //อาจ งง ไว้ดูตัวอย่างดีกว่าครับ

เช่นในฐานข้อมูลมีข้อมูล 3 ตัว PK มีดังนี้

ตาราง : human_table
-------------------------------- -- code | name | gender -- -------------------------------- -- M001 | นายA | ชาย -- -- M002 | นางB | หญิง -- -- M003 | นายC | ชาย -- --------------------------------

$count = $db->get_count("human_table");
$new_pk = $db->get_pk($count+1,"M") ; 
echo $new_pk; //M004
// ถ้าในตารางมี 9 ตัว ก็จะได้ M010
// ถ้าในตารางมี 99 ตัว ก็จะได้ M100
// รองรับPKสูงสุด 1000 ตัวครับ (หมายเลข0-999)
// โดยมีข้อแม้ว่า PK ในฐานข้อมูลต้องอยู่ในรูปแบบ ตัวอักษร+ตัวเลข3หลัืก เช่น STU001, P078, h628 เป็นต้นครับ


function.php
<?php
	class database
	{ 
		var $host = "..."; //ของผมใช้ localhost ครับ
		var $user = "..."; //username phpmyadmin
		var $pass = "..."; //password phpmyadmin
		var $db = "..."; //ชื่อฐานข้อมูล
		var $con;
		
		function con_db()
		{
			$this->con = mysql_connect($this->host,$this->user,$this->pass)or die("Error : ไม่สามารถเชื่อมต่อฐานข้อมูลได้");
			mysql_select_db($this->db,$this->con)or die("Error : ไม่สามารถเลือกฐานข้อมูลได้");
		}
	
		function sql_cmd($sqlCmd)
		{
			mysql_query("set character_set_results='utf8'");
			mysql_query("set character_set_client='utf8'");
			mysql_query("set character_set_connection='utf8'");
			return $result = mysql_query($sqlCmd,$this->con) or die("Error : เกิดข้อผิดพลาด");
		}	
		
		function sql_cmd_select($sqlCmd)
		{
			mysql_query("set character_set_results='utf8'");
			mysql_query("set character_set_client='utf8'");
			mysql_query("set character_set_connection='utf8'");
			$result = mysql_query($sqlCmd,$this->con) or die("Error : เกิดข้อผิดพลาด ไม่เจอข้อมูลที่ต้องการ");
			$rs = mysql_fetch_array($result);
			return $rs;
		}	
		
		function close_db()
		{
			mysql_close($this->con);
		}
		
		function get_count($table)
		{
			$this->con_db();
			$count = $this->sql_cmd_select("select count(*) from ".$table);
			return $count[0];
			$this->close_db();
		}
		
		function get_pk($count,$key)
		{
			if($count<=9)
			{	
				return $key."00".$count;
			}
			else if($count<=99)
			{
				return $key."0".$count;
			}
			else
			{
				return $key.$count;
			}	
		}
	}
?>


ถ้าใครสร้าง Function ใหม่ๆน่าใช้ ก็เอามาแบ่งกันด้วยนะครับ ผมไปทำ Project ต่อแล้วครับ ... ขอบคุณทุกท่านครับ


Reference : http://www.facebook.com/fluke.farlook
   
Share

  By : Fluke
  Article : บทความเป็นการเขียนโดยสมาชิก หากมีปัญหาเรื่องลิขสิทธิ์ กรุณาแจ้งให้ทาง webmaster ทราบด้วยครับ
  Score Rating :
  Create Date : 2012-11-11
  Download : No files
Sponsored Links
 

Sponsored Links
ตัวอย่างการสร้าง Webboard ด้วย PHP + MySQLi และ Bootstrap
ตัวอย่างการสร้าง Webboard ด้วย PHP + MySQLi และ Bootstrap
บทความนี้จะให้แนวทางในการสร้าง Webboard ด้วย PHP + MySQLi และ Bootstrap โดยเน้นการให้แนวทางที่มีประสิทธิภาพและปลอดภัย เพื่อให้มีพื้นฐานการเขียนโปรแกรมด้วย PHP ที่ถูกต้องและทันสมัย
Rating : Update : 2014-12-17 17:56:15
C# การสสร้างฐานข้อมูลลูกค้าด้วย DataGridView  แบบ บ้านๆ
C# การสสร้างฐานข้อมูลลูกค้าด้วย DataGridView แบบ บ้านๆ
C# การสสร้างฐานข้อมูลลูกค้าด้วย datagridview แบบ บ้านๆ
Rating : Update : 2016-06-06 09:21:24
ตอนที่ 6 : SQL Azure รู้จักกับ Connection String สิทธิ์การใช้งาน SQL Database
ตอนที่ 6 : SQL Azure รู้จักกับ Connection String สิทธิ์การใช้งาน SQL Database
หลังจากที่เราได้ทำการสร้าง SQL Azure หรือ SQL Database บน Windows Azure เรียบร้อยแล้ว เราจะมาเรียนรู้กฏและเงื่อนไขการใช้งาน SQL Database ว่าจะมีรูปแบบการเรียกใช้งานจาก Application อื่น ๆ ได้อย่างไร
Rating : Update : 2013-07-23 13:24:27
แปลง session ข้อมูลที่เป็น tis-620 ให้เป็น utf-8  หรือกลับกันก็ได้ครับ  กรณีแต่ล่ะ Page ทำหนด collection ไม่เหมือนกัน
แปลง session ข้อมูลที่เป็น tis-620 ให้เป็น utf-8 หรือกลับกันก็ได้ครับ กรณีแต่ล่ะ Page ทำหนด collection ไม่เหมือนกัน
พอผมต้องเอา session จากเว็บนึงซึ่งเป็นรูปแบบ tis-620 มาใช้อีกเว็บนึงซึ่งเป็น utf-8 ก็เลยเอาวิธีการแปลงภาษาจากการใช้งานของ PDF มาประยุกต์ใช้ครับ ซึ่งได้ผล รูปแบบ iconv( 'tis-620','utf-8','ตัวแปร'); ตัวอย่างนี้ คือ tis-620 คืือ ตัวแปลที่ส่งมาเป็นรูปแบบ ภาไทย tis-620 และแปลให้เป็น utf-8 ครับ เช่นเดียวกันครับเมื่อต้องการแปลงกลับก็แค่สลับตำแหน่งกัน แค่นี้เราก็สามารถแก้ปัญหา session ที่มาจากอีกเว็บนึง เพื่อนำมาใช้ในเว็บเราได้อย่างที่เราต้องการแล้วครับ
Rating : Update : 2012-04-16 16:23:53
สร้าง Create Theme บน jQuery Mobile เป็นของตนเองแบบง่าย ๆ ด้วย Theme Roller
สร้าง Create Theme บน jQuery Mobile เป็นของตนเองแบบง่าย ๆ ด้วย Theme Roller
Theme roller เป็นเครื่องมือสำหรับออกแบบและสร้าง themes ด้วยตนเอง ผ่านเครื่องมือ wizard ที่ทาง jquery mobile ได้ออกแบบไว้ ใช้งานง่ายและสะดวกมาก
Rating : Update : 2012-06-30 22:41:05
ตอนที่ 17 : Show Case 4 : Delete Data (Android and Mobile Services)
ตอนที่ 17 : Show Case 4 : Delete Data (Android and Mobile Services)
ตัวอย่าง Show Case การเขียน Android กับ Mobile Services เพื่อที่จะทำการลบ Delete ข้อมูลในที่อยู่ในตาราง Table ด้วยการแสดงรายการทั้งหมดบน ListView จากนั้นผู้ใช้สามารที่จะเลือกรายการที่ต้องการลบ
Rating : Update : 2013-10-14 10:05:57


ThaiCreate.Com Forum
Comunity Forum Free Web Script
Jobs Freelance Free Uploads
Free Web Hosting Free Tools

สอน PHP ผ่าน Youtube ฟรี
สอน Android การเขียนโปรแกรม Android
สอน Windows Phone การเขียนโปรแกรม Windows Phone 7 และ 8
สอน iOS การเขียนโปรแกรม iPhone, iPad
สอน Java การเขียนโปรแกรม ภาษา Java
สอน Java GUI การเขียนโปรแกรม ภาษา Java GUI
สอน JSP การเขียนโปรแกรม ภาษา Java
สอน Struts การเขียนโปรแกรม Java Struts Framework
สอน jQuery การเขียนโปรแกรม ภาษา jQuery
สอน Yii  Framework การเขียนโปรแกรม ภาษา PHP กับ Yii
สอน .Net การเขียนโปรแกรม ภาษา .Net
Free Tutorial
สอน Entity Framework
สอน Android
สอน Java เขียน Java
Java GUI Swing
สอน JSP (Web App)
iOS (iPhone,iPad)
Windows Phone
Windows Azure
Windows Store
Laravel Framework
Yii PHP Framework
สอน jQuery
สอน jQuery กับ Ajax
สอน PHP OOP (Vdo)
Ajax Tutorials
SQL Tutorials
สอน SQL (Part 2)
JavaScript Tutorial
Javascript Tips
Microsoft Access
MySQL Tutorials
-- Stored Procedure
MariaDB Database
SQL Server Tutorial
SQL Server 2005
SQL Server 2008
SQL Server 2012
-- Stored Procedure
Oracle Database
-- Stored Procedure
SVN (Subversion)
แนวทางการทำ SEO
ปรับแต่งเว็บให้โหลดเร็ว

สุดยอด Source Code V2.0
 

แจ้งชำระเงิน/โอนเงิน
 

Hit Link
   




Acc : thaicreate@hotmail.com






Load balance : Server 02
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2015 All Rights Reserved.
for Contact Us : [Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 , 084-715-5121 อัตราราคา คลิกที่นี่

Back to Top