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

Registered : 107,995

HOME > PHP > PHP Forum > php oop การ return ค่าจาก function มายัง หน้า form



 

php oop การ return ค่าจาก function มายัง หน้า form

 



Topic : 072103

Guest




ดิฉันเพิ่งหัดเขียน php แบบ OOP ค่ะ
ตอนนี้พบปัญหาดังนี้ค่ะ คือสับสนว่าเราควร นำ sql string พวก select , update, insert ไว้ใน class หรือ เอาไว้ที่หน้า form ดีคะ

--- itemList.php-----
include("DBConnect.php");
require("class_itemmaster.php");
$objItemList = new ItemList;
$conn = new DBConnect;
echo $objItemList->itemLoad(); // หรือ นำ code ใน class itemlist,function itemLoad มาไว้ที่นี่ดีคะ ???

----DBConnect.php-------

ob_start();
Class DBConnect
{
private $_host = "localhost";
private $_user = "root";
private $_pass = "1234";
private $_db = "test_db";


private function openDB()
{
$charset = "set names utf8";
$link = mysql_pconnect($this->_host, $this->_user, $this->_pass);
if (!$link) {
die('Could not connect to the server: ' . odbc_error());
}

$db_selected = mysql_select_db($this->_db, $link);
if (!$db_selected) {
die ('Could not connect to the database"' . $this->_db ." get error: " . mysql_error());
}

mysql_query($charset) or die('Invalid query: ' . mysql_error());

}

private function closeDB()
{
mysql_close($link);
}

public function return_sql($sql)
{
self::openDB();
$result = mysql_query($sql) or trigger_error("SQL", E_USER_ERROR);

if ($result){
$arrData = array();
while ($rows = mysql_fetch_array($result)) {
$arrData[] = $rows;
}



}else{
$message = 'This command of : ' . mysql_error() . " incorrect<BR />";

$message = mysql_error();
die($message);
}

return $arrData;

self::closeDB();
}

public function exe($sql)
{
self::openDB();
$result = mysql_query($sql);
if (!$result) {
$message = 'This command of : ' . mysql_error() . "incorrect<BR />";
die($message);
}
}

}

?><?php ob_end_flush();?>

--------class_itemmaster.php-----

class ItemList {

public $itemcode;
public $itemname;
public $unittype;
public $status;
public $remark;
public $createby;
public $sql;

public function DuplicateItem ($fitemcode,$fitemname,$funittype,$fstatus,$fremark,$fcreateby) {

$this->itemcode=$fitemcode;
$this->itemname=$fitemname;
$this->unittype=$funittype;
$this->status=$fstatus;
$this->remark=$fremark;
$this->createby=$fcreateby;

$conn = new DBConnect;
$sSql = "select * from itemmaster where itemcode ='$this->itemcode'";

$arrData = $conn->return_sql($sSql);

if ( $arrData=true) {
return "<script>alert('Duplicate Data !');</script>";
}
else {

AddNewItem($this->itemcode,$this->itemname,$this->unittype,$this->status,$this->remark,$this->createby);
}

}

public function AddNewItem ($fitemcode,$fitemname,$funittype,$fstatus,$fremark,$fcreateby) {
$this->itemcode=$fitemcode;
$this->itemname=$fitemname;
$this->unittype=$funittype;
$this->status=$fstatus;
$this->remark=$fremark;
$this->createby=$fcreateby;
$conn = new DBConnect;
$sSql = "Insert into itemmaster (ItemCode,ItemName,Unit,Status,Remark,Createby) VALUES ('$this->itemcode','$this->itemname','$this->unittype','$this->status','$this->remark','$this->createby')";
$arrData = $conn->exe($sSql);
return "<meta http-equiv='refresh'Content =0;URL='ItemList.php'>";


}

public function itemLoad () {
$conn = new DBConnect;
$sSql = "SELECT * FROM itemmaster";
$arrData = $conn->return_sql($sSql);
return $arrData; // จากตรงนี้จะ return ค่าเป็น ไปยัง form ยังงัยดีคะ หรือว่า ต้องสร้าง html แทรกไว้ใน class ที่นี่ดีคะ ??

// ถ้าสร้างที่นี่ /*
echo "<table width=200 border=1>";
echo " <tr><td cellpadding= 0 cellspacing=3 bgcolor=#99CCFF align=center class=style274>ItemCode</td>
<td cellpadding= 0 cellspacing=3 bgcolor=#99CCFF align=center class=style274>ItemName</td>
<td cellpadding= 0 cellspacing=3 bgcolor=#99CCFF align=center class=style274>Unit</td></tr>";
$j=0;
foreach($arrData as $row){ {
echo "<tr><td cellpadding= 0 cellspacing=1 bgcolor=#99CCFF>"; echo $row['ItemCode']; echo"</td>";
echo "<td cellpadding= 0 width=100 cellspacing=1 bgcolor=#99CCFF >"; echo $row['ItemName']; echo"</td>";
echo "<td cellpadding= 0 width=250 cellspacing=1 bgcolor=#99CCFF >"; echo $row['Unit']; echo"</tr></td>";
echo "<br\n>";
}echo "</table>";*/

}

public function itemCodeSearch ($fitemcode) {
$this->itemcode=$fitemcode;
$conn = new connectDB;
$sSql = "SELECT * FROM itemmaster WHERE ItemCode ='$this->itemcode' ";
$arrData = $conn->return_sql($sSql);
return "<meta http-equiv='refresh'Content =0;URL='ItemList.php'>";
}



}
?>
รบกวนผู้รู้ทั้งหลายช่วยเข้ามาตอบด้วยค่ะ ตอนนี้มึนกับ OOP มั่กๆๆ หรือว่าจากลับไปเขียนแบบไม่ OOP ดีมั้ย???



Tag : PHP







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2012-01-17 10:19:25 By : เนย View : 1125 Reply : 5
 

 

No. 1

Guest


ดิฉันเพิ่งหัดเขียน php แบบ OOP ค่ะ
ตอนนี้พบปัญหาดังนี้ค่ะ คือสับสนว่าเราควร นำ sql string พวก select , update, insert ไว้ใน class หรือ เอาไว้ที่หน้า form ดีคะ

Code (PHP)
--- itemList.php-----
include("DBConnect.php");
require("class_itemmaster.php");
$objItemList = new ItemList; 
$conn = new DBConnect; 
echo $objItemList->itemLoad();	// หรือ นำ code ใน class itemlist,function itemLoad มาไว้ที่นี่ดีคะ ???

----DBConnect.php-------

ob_start(); 
Class DBConnect
{
private $_host = "localhost"; 
private $_user = "root"; 
private $_pass = "1234"; 
private $_db = "test_db"; 


private function openDB()
{
$charset = "set names utf8";
$link = mysql_pconnect($this->_host, $this->_user, $this->_pass);
if (!$link) {
die('Could not connect to the server: ' . odbc_error());
}

$db_selected = mysql_select_db($this->_db, $link);
if (!$db_selected) {
die ('Could not connect to the database"' . $this->_db ." get error: " . mysql_error());
}

mysql_query($charset) or die('Invalid query: ' . mysql_error());

}

private function closeDB()
{
mysql_close($link);
}

public function return_sql($sql)
{
self::openDB();
$result = mysql_query($sql) or trigger_error("SQL", E_USER_ERROR);

if ($result){
$arrData = array();
while ($rows = mysql_fetch_array($result)) {
$arrData[] = $rows;
}



}else{ 
$message = 'This command of : ' . mysql_error() . " incorrect<BR />";

$message = mysql_error();
die($message);
} 

return $arrData;

self::closeDB();
}

public function exe($sql)
{
self::openDB();
$result = mysql_query($sql);
if (!$result) {
$message = 'This command of : ' . mysql_error() . "incorrect<BR />";
die($message);
}
}

}

?><?php ob_end_flush();?>

--------class_itemmaster.php-----

class ItemList {

public $itemcode;
public $itemname;
public $unittype;
public $status;
public $remark;
public $createby;
public $sql;

public function DuplicateItem ($fitemcode,$fitemname,$funittype,$fstatus,$fremark,$fcreateby) {

$this->itemcode=$fitemcode;
$this->itemname=$fitemname;
$this->unittype=$funittype;
$this->status=$fstatus;
$this->remark=$fremark;
$this->createby=$fcreateby;

$conn = new DBConnect; 
$sSql = "select * from itemmaster where itemcode ='$this->itemcode'";

$arrData = $conn->return_sql($sSql);

if ( $arrData=true)	{
return "<script>alert('Duplicate Data !');</script>"; 
} 
else { 

AddNewItem($this->itemcode,$this->itemname,$this->unittype,$this->status,$this->remark,$this->createby);
}

}

public function AddNewItem ($fitemcode,$fitemname,$funittype,$fstatus,$fremark,$fcreateby) {
$this->itemcode=$fitemcode;
$this->itemname=$fitemname;
$this->unittype=$funittype;
$this->status=$fstatus;
$this->remark=$fremark;
$this->createby=$fcreateby; 
$conn = new DBConnect; 
$sSql = "Insert into itemmaster (ItemCode,ItemName,Unit,Status,Remark,Createby) VALUES ('$this->itemcode','$this->itemname','$this->unittype','$this->status','$this->remark','$this->createby')";	
$arrData = $conn->exe($sSql);
return "<meta http-equiv='refresh'Content =0;URL='ItemList.php'>";


}

public function itemLoad () {
$conn = new DBConnect; 
$sSql = "SELECT * FROM itemmaster";
$arrData = $conn->return_sql($sSql);
return $arrData; // จากตรงนี้จะ return ค่าเป็น ไปยัง form ยังงัยดีคะ หรือว่า ต้องสร้าง html แทรกไว้ใน class ที่นี่ดีคะ ??

// ถ้าสร้างที่นี่ /*
echo "<table width=200 border=1>";
echo " <tr><td cellpadding= 0 cellspacing=3 bgcolor=#99CCFF align=center class=style274>ItemCode</td>
<td cellpadding= 0 cellspacing=3 bgcolor=#99CCFF align=center class=style274>ItemName</td>
<td cellpadding= 0 cellspacing=3 bgcolor=#99CCFF align=center class=style274>Unit</td></tr>";
$j=0;
foreach($arrData as $row){ {
echo "<tr><td cellpadding= 0 cellspacing=1 bgcolor=#99CCFF>"; echo $row['ItemCode']; echo"</td>";
echo "<td cellpadding= 0 width=100 cellspacing=1 bgcolor=#99CCFF >"; echo $row['ItemName']; echo"</td>";
echo "<td cellpadding= 0 width=250 cellspacing=1 bgcolor=#99CCFF >"; echo $row['Unit']; echo"</tr></td>";
echo "<br\n>";
}echo "</table>";*/

}

public function itemCodeSearch ($fitemcode) {
$this->itemcode=$fitemcode;
$conn = new connectDB;
$sSql = "SELECT * FROM itemmaster WHERE ItemCode ='$this->itemcode' ";
$arrData = $conn->return_sql($sSql);
return "<meta http-equiv='refresh'Content =0;URL='ItemList.php'>";
}



}
?>



รบกวนผู้รู้ทั้งหลายช่วยเข้ามาตอบด้วยค่ะ ตอนนี้มึนกับ OOP มั่กๆๆ หรือว่าจากลับไปเขียนแบบไม่ OOP ดีมั้ย???






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-17 15:37:09 By : เนย
 


 

No. 2



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



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


แล้วแต่จะออกแบบกระบวนการ มันทำได้ทั้งนั้นแหละครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-17 15:56:37 By : mr.v
 

 

No. 3



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



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

ตอบความคิดเห็นที่ : 2 เขียนโดย : mr.v เมื่อวันที่ 2012-01-17 15:56:37
รายละเอียดของการตอบ ::
ถูกต้องเลยครับ :)

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-17 16:00:29 By : evanesscaz
 


 

No. 4

Guest


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

แล้วที่งง อีกอย่างก็คือ ถ้าเราเอา query string ไปไว้ในหน้า form (จริงๆต้องไว้ใน class?) แระมันจะเป็น OOP ตรงไหนค่ะ
หรือว่า php เขียน oop เฉพาะตอนติดต่อ database เท่าันั้นเหรอคะ

รบกวนช่วยเข้ามาตอบกันอีกครั้งนะคะ ยังสับสนอยู่ค่ะ ขอบคุณค่ะ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-17 16:17:50 By : เนย
 


 

No. 5

Guest


ยังงัยรบกวน ช่วยยกตัวอย่างให้ดูได้มั้ยคะ
เื่ผื่อจะเข้าใจมากขึ้น
ขอบคุณค่ะ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-17 16:21:45 By : เนย
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : php oop การ return ค่าจาก function มายัง หน้า form
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ 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: Voake, Comcube, รับทำเว็บไซต์ รับเขียนโปรแกรม

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