Viewing file: clsResultRQTeach.php (5.51 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
//--Class ResultRQTeach--------------------------
//--PK of ResultRQTeach ::
// 1. reTeachid
class ResultRQTeach extends clsDB{
var $result;
var $reTeachid;
var $doTeachid;
var $sectionRQid;
var $RQid;
var $point;
var $xbar;
var $sd;
function ResultRQTeach(&$c){
$this->c=$c->c;
$this->DB=$c->db;
}
function Save(){
//--ข้อมูลในอ๊อบเจ๊กเป็นข้อมูลใหม่หรือข้อมูลเดิม --1:ข้อมูลใหม่ 2:ข้อมูลเดิม
if ($this->status==1){
//uncomment a line below if your table use ID as running number
$this->reTeachid=$this->GetNextCode();
$sql = "insert into ResultRQTeach values(
'$this->reTeachid',
'$this->doTeachid',
'$this->sectionRQid',
'$this->RQid',
'$this->point'
)";
}else {
$sql = "update ResultRQTeach set
doTeachid='$this->doTeachid',
sectionRQid='$this->sectionRQid',
RQid='$this->RQid',
Point='$this->point'
where reTeachid='$this->reTeachid'";
}
return $this->Dml($sql);
}
function Delete(){
//--ลบข้อมูลเดิมในอ๊อบเจ๊ก, เป็นการลบข้อมูลทีละ 1 เรคอร์ด
//--ต้องเรียกเมธอดตามลำดับดังนี้ SearchByKey()-->GetRecord()-->Delete()
return $this->Dml("delete from ResultRQTeach where reTeachid='$this->reTeachid'");
}
function GetNextCode(){
//--หาค่าสูงสุดของฟิลด์ที่ใช้เป็นคีย์ของตาราง ในลักษณะ auto increment
//--ต้องเป็นฟิลด์ชนิดตัวเลขจำนวนเต็มเท่านั้น และไม่ได้กำหนดรหัสเองทางจอภาพ
$this->SetQuery("select max(reTeachid) as num from ResultRQTeach");
if ($result=$this->GetResult()) {
return $result['num']+1;
}
}
function RSResultRQTeach(){
//--เมธอดที่ขึ้นต้นด้วย RS (ResultSet) มีความหมายว่าจะได้รับข้อมูลกลับมาจากการ select มากกว่า 1 เรคอร์ด
//--จะต้องเรียกเมธอด GetRecord() ด้วยเสมอ นำข้อมูลจาก ResultSet เข้าอ๊อบเจ๊ก
//--โดยสามารถเพิ่มเมธอดได้ตามต้องการ แต่ต้องขึ้นต้นด้วย RS
$this->SetQuery("select * from ResultRQTeach order by reTeachid");
}
function GetRecord(){
//--นำข้อมูลจาก ResultSet มากำหนดให้กับแอตทริบิวต์ของอ๊อบเจ็ก
//--เรียก GetRecord() หนึ่งครั้ง จะเลื่อนตัวชี้เรคอร์ดไปอีกหนึ่งเรคอร์ด
if ($this->result = $this->GetResult()) {
$this->reTeachid = $this->result['reTeachid'];
$this->doTeachid = $this->result['doTeachid'];
$this->sectionRQid = $this->result['sectionRQid'];
$this->RQid = $this->result['RQid'];
$this->point = $this->result['point'];
$this->xbar = $this->result['xbar'];
$this->sd = $this->result['sd'];
return 1;
}else {
return 0;
}
}
function SearchByKey($xKey){
//--ค้นหาข้อมูลตาม PK ต้องระบุพารามิเตอร์ด้วย และต้องตามด้วยเมธอด GetRecord() เสมอ
if ($this->SetQuery("select * from ResultRQTeach where reTeachid= '$xKey'")){
return 1;
}else {
return 0;
}
}
//****************** You can add new functions below **********************//
function SumPointByRQid($xdefineid,$xRQid){
$this->SetQuery("select sum(point) as num from ResultRQTeach A, DoAssessmentTeach B where A.doTeachid = B.doTeachid and defineid = '$xdefineid' and RQid = '$xRQid' group by RQid");
$result = $this->GetResult();
return $result['num'];
}
function SearchPointByRQid($xdefineid,$xRQid){
if ($this->SetQuery("select point from ResultRQTeach A, DoAssessmentTeach B where A.doTeachid = B.doTeachid and defineid = $xdefineid and RQid = '$xRQid'")){
return 1;
}else {
return 0;
}
}
function SearchPointByDoTeachidRQid($xdoTeachid,$xRQid){
if ($this->SetQuery("select point from ResultRQTeach where doTeachid = '$xdoTeachid' and RQid = '$xRQid'")){
return 1;
}else {
return 0;
}
}
function SearchPointByDoTeachidSectionRQid($xdoTeachid,$xsectionRQid){
if ($this->SetQuery("select point from ResultRQTeach where doTeachid = '$xdoTeachid' and sectionRQid = '$xsectionRQid'")){
return 1;
}else {
return 0;
}
}
function CountPointJoinByRQidDefineidPoint($xRQid,$xdefineid,$xscore){
$this->SetQuery("select count(point) as num from DoAssessmentTeach A ,ResultRQTeach B WHERE A.doTeachid = B.doTeachid and RQid = '$xRQid' and defineid = '$xdefineid' and point = '$xscore'");
$result = $this->GetResult();
return $result['num'];
}
function SearchResultIXbarSDByDefineidSectionRQid($xdefineid,$xsectionRQid){
if ($this->SetQuery("
SELECT total / (doAss * numRQ) AS xbar, SQRT((sumpow / (doAss * numRQ))-pow(total/(doAss * numRQ),2)) AS sd
FROM
(
SELECT sum( point ) AS total, sum(point *point) AS sumpow
FROM DoAssessmentTeach da
INNER JOIN ResultRQTeach rrq ON rrq.doTeachid = da.doTeachid
WHERE da.defineid = '$xdefineid'
AND rrq.sectionRQid = '$xsectionRQid'
)r1, (
SELECT count(*) AS doAss
FROM DoAssessmentTeach
WHERE defineid = '$xdefineid'
)r2, (
SELECT count( DISTINCT RQid ) AS numRQ
FROM DoAssessmentTeach da
INNER JOIN ResultRQTeach rrq ON rrq.doTeachid = da.doTeachid
AND da.defineid = '$xdefineid'
AND rrq.sectionRQid = '$xsectionRQid'
)r3
")){
return 1;
}else {
return 0;
}
}
function SearchResultIXbarSDEachRQidByDefineidSectionRQid($xdefineid,$xsectionRQid,$xRQid){
if ($this->SetQuery("
SELECT total / (doAss) AS xbar, SQRT((sumpow / doAss)-pow(total/(doAss),2)) AS sd
FROM
(
SELECT sum( point ) AS total, sum(point *point) AS sumpow
FROM DoAssessmentTeach da
INNER JOIN ResultRQTeach rrq ON rrq.doTeachid = da.doTeachid
WHERE da.defineid = '$xdefineid'
AND rrq.sectionRQid = '$xsectionRQid'
AND rrq.RQid = '$xRQid'
)r1, (
SELECT count(*) AS doAss
FROM DoAssessmentTeach
WHERE defineid = '$xdefineid'
)r2
")){
return 1;
}else {
return 0;
}
}
} //--End class ResultRQTeach--
?>
|