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 Lib กันดีกว่า 3



 
Clound SSD Virtual Server

เริ่มต้นสร้าง PHP Lib กันดีกว่า 3

เกริ่นนำ
ผมมีปัญหาเรื่องการเขียน sql ให้ถูกต้องตามรูปแบบของคำสั่งอยู่บ่อยๆ และต้องการหาวิธีที่ทำให้จัดการเรื่องจุกจิกให้เร็วขึ้นอีกหน่อย (เขียนเยอะอีกหน่อยแต่แม่นชัวร์ ทำให้ผมไม่ต้องตรวจอะไรมากมายนัก ใช้แล้วก็ง่ายมากขึ้นจริงๆ)

SQLCommand Class

Code
SQLCommand.php
<?php
if (! defined ( "S_CHARACTOR" ))
	define ( "S_CHARACTOR", 1001 );
if (! defined ( "S_NUMERIC" ))
	define ( "S_NUMERIC", 1002 );
if (! defined ( "S_BLOB" ))
	define ( "S_BLOB", 1003 );
if (! defined ( "S_DATETIME" ))
	define ( "S_DATETIME", 1004 );

/** @package Databases */
class SQLCommand {
	/**
	 * array list variable parameter
	 *
	 * @var array
	 */
	private $a_assign_var;
	
	/**
	 * array list value for list parameter
	 *
	 * @var array
	 */
	private $a_assign_value;
	
	/**
	 * Source sql command before parsing sql command.
	 *
	 * @var string
	 */
	private $s_sql_source;
	
	/**
	 * Constructor
	 * $o_ new SQLCommand("select * from tbl1 where col1 = :c_1");
	 * $o_->setValue("c_1","name");
	 * print $o_->parseSQL();
	 *
	 * @param string $s_sql_source
	 */
	function __construct($s_sql_source = '') {
		$this->s_sql_source = $s_sql_source;
	}
	
	/**
	 * Assgin value on mark point from sql command.
	 *
	 * @param string $s_marker
	 * @param string $s_values
	 */
	public function setValue($s_marker, $s_values, $s_col_type = S_CHARACTOR) {
		
		$this->a_assign_var [] = "/:" . $s_marker . "/";
		if ($s_col_type === S_CHARACTOR) {
			$this->a_assign_value [] = "'" . $s_values . "'";
		} else if ($s_col_type === S_DATETIME) {
			$this->a_assign_value [] = "'" . $s_values . "'";
		} else {
			$this->a_assign_value [] = $s_values;
		}
	}
	/**
	 * Set source Sql command.
	 *
	 * @param string $s_sql
	 */
	public function setSql($s_sql = '') {
		$this->s_sql_source = $s_sql;
	}
	
	/**
	 * Get source Sql command.
	 *
	 * @return string
	 */
	public function getSql() {
		return $this->s_sql_source;
	}
	
	/**
	 * Return parsing sql command.
	 *
	 * @return string
	 */
	public function parseSQL() {
		return preg_replace ( $this->a_assign_var, $this->a_assign_value, $this->s_sql_source );
	}
}

?>[/code]

การใช้งาน
[code]UseSQLCommand.php
<?php
include_once "SQLCommand.php";

$s_sql = "INSERT INTO tbl_teacher ( title_name_id, name, middle_name, surname, email, faculty, created_at, updated_at) VALUES( :title_name_id, :name, :middle_name, :surname, :email, :faculty, :created_at, :updated_at);";
print "ก่อน กำหนดค่า<br>";
print $s_sql."<br>";
        $o_sql_cmd = new SQLCommand ( $s_sql );
        $o_sql_cmd->setValue ( 'title_name_id', 1, S_NUMERIC );
        $o_sql_cmd->setValue ( 'name',  "ชื่อ" , S_CHARACTOR  );
        $o_sql_cmd->setValue ( 'middle_name', "ชื่อกลาง", S_CHARACTOR   );
        $o_sql_cmd->setValue ( 'surname',"สกุล", S_CHARACTOR  );
        $o_sql_cmd->setValue ( 'faculty',"วิทยาศาสตร์" , S_CHARACTOR  );
        $o_sql_cmd->setValue ( 'email',  "[email protected]" , S_CHARACTOR  );
        $o_sql_cmd->setValue ( 'created_at', date ( "Y-m-d H:i:s" ), S_DATETIME );
        $o_sql_cmd->setValue ( 'updated_at', date ( "Y-m-d H:i:s" ), S_DATETIME );
print "หลัง กำหนดค่า<br>";
print $o_sql_cmd->parseSQL () ; // จะคืนค่ากลับมาเป็น คำสั่ง Sql ที่สามารถนำไปส่งฐานข้อมูลประมวลผลได้เลย แต่สำหรับตรงนี้ผมให้มันแสดงออกทางหน้าเว็บ
?>


ผลลัพธ์
จะเห็นว่า Sql จะอยู่ในรูปที่กำหนดค่าให้เรียบร้อยตามประเภท Numeric Charactor Datetime

[url=https://www.thaicreate.com/upload/stock/20090503042701.jpg[คลิกเพื่อดูรูปภาพ[/url]







   
Share
Bookmark.   

  By : เอส
  Article : บทความเป็นการเขียนโดยสมาชิก หากมีปัญหาเรื่องลิขสิทธิ์ กรุณาแจ้งให้ทาง webmaster ทราบด้วยครับ
  Score Rating :
  Create Date : 2009-05-03
  Download : No files
Sponsored Links
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
สอน jQuery การเขียนโปรแกรม ภาษา jQuery
สอน .Net การเขียนโปรแกรม ภาษา .Net
Free Tutorial
สอน Google Maps Api
สอน Windows Service
สอน 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
VBScript Tutorial
VBScript Validation
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
ปรับแต่งเว็บให้โหลดเร็ว


Hit Link
   







Load balance : Server 03
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 อัตราราคา คลิกที่นี่