|
|
|
ปัญหาเรื่องการเพิ่มข้อมูล ผมทำหน้า web สำหรับเพิ่มสมาชิกได้โดยผู้ที่จะนำข้อมูลเข้าทางหน้า web นี้จะต้องเป็น admin |
|
|
|
|
|
|
|
ผมทำหน้า web สำหรับเพิ่มสมาชิกได้โดยผู้ที่จะนำข้อมูลเข้าทางหน้า web นี้จะต้องเป็น admin โดย Codemuj Code ที่ผมเขียนมีการ check id กับ email ก่อนว่ามีคนใช้ไปหรือยัง ถ้ายังจึงจะ เพิ่มข้อมูลลงไปได้ตามCตาม ตาม Code ด้านล่าง
<?php
include("connect.inc");
if($HTTP_SESSION_VARS['m_Type']==1 ){ // ตรวจวสอบ type user
if($strError==""){ // ตรวจวสอบ การ connect database
//---------------------------- หา ID กับ Email ใน table ว่าซ้ำหรือไม่
$Id=$HTTP_POST_VARS['memId'];
$Email=$HTTP_POST_VARS['memEmail'];
$sqlSelect="select * from member where memId=$Id or memEmail='$Email'";
mysql_query('SET NAMES utf8');
$dataMember=mysql_db_query($dbname,$sqlSelect);
if($numMember!=0){
// กรณีซ้ำ
$msg="รหัสสมาชิก หรือ e-mail นี้มีอยู่แล้วครับ<br>กรุณารอสักครู่...";
}else{
// กรณีไม่ซ้ำ
$Title=$HTTP_POST_VARS['memTitle'];
$Name=$HTTP_POST_VARS['memName'];
$Surname=$HTTP_POST_VARS['memSurname'];
$Level=$HTTP_POST_VARS['memLevel'];
$Position=$HTTP_POST_VARS['memPosition'];
$Organize=$HTTP_POST_VARS['memOrganize'];
$Provice=$HTTP_POST_VARS['memProvice'];
$Password=$HTTP_POST_VARS['memPwd1'];
$Rdate=date("Y-m-d H:i:s");
$Ldate=date("Y-m-d H:i:s");
$Type=$HTTP_POST_VARS['memType'];
$msg="กำลังทำการบันทึกข้อมูลอยู่<br>กรุณารอสักครู่....";
$sqladd="insert into member values (".$Id.",'".$Title."','".$Name."','".$Surname."','".$Level."','".$Position."','".$Organize."','".$Email."','".$Provice."','".$Password."','".$Rdate."','".$Ldate."','".$Type."')";
mysql_db_query($dbname,$sqladd);
mysql_close();
}
}else{
// กรณี connect database ไม่ได้
$msg=$strError;
}
print("<br> $msg");
}else{
// กรณีไม่ใช่ admin
header("Location: http://".$_SERVER['HTTP_HOST']);
}
?>
แต่ปัญหามีอยู่ว่าเวลาที่เพิ่มข้อมูลลงไปในกรณีที่ Id กับ Email ไม่ซ้ำ ข้อความที่แสดงดันบอกว่า
รหัสสมาชิก หรือ e-mail นี้มีอยู่แล้วครับ<br>กรุณารอสักครู่... แต่บันทึกข้อมูลลง table ได้ ไม่มี Error
ผมเลยทำการ check ค่า $numMember ได้ ไม่เท่ากับ 0 ทั้งๆที่ไม่มีข้อมูลอยู่ใน table แต่ดันเพิ่มข้อมูล
ข้อมูลลง table ได้ งงมาก ใครก็ได้ช่วยทีครับ ขอบคุณครับ
Tag : - - - -
|
|
|
|
|
|
Date :
8 ธ.ค. 2549 17:01:58 |
By :
alongkorn |
View :
2024 |
Reply :
4 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ง่านนิดเดียว ก็คุณไม่ได้ assign ค่าให้ตัวแปร $numMember นี้เลยคับ
ค่ามันเป็น null ซึ่งไม่เท่ากับ 0 อย่างที่เงื่อนไขเขียน ก็เลยแสดงข้อความนั้นออกมาคับ
|
|
|
|
|
Date :
8 ธ.ค. 2549 18:20:39 |
By :
nut_t02 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ผมทำการเพิ่ม $numMember=mysql_num_rows($dataMember); ก่อน check ค่า $numMember
ก็ยังมีปัญหาเหมือนเดิม ครับ
|
|
|
|
|
Date :
9 ธ.ค. 2549 08:59:52 |
By :
alongkorns |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
มันขึ้น error ว่าอะไรเหรอครับ และคุณใช้ $numMember=mysql_num_rows($dataMember); ไว้บรรทัดไหนครับ
ละช่วยเอาโค๊ดที่ปรับปรุงแล้วมาลงอีกที่ได้ไหมครับ
|
|
|
|
|
Date :
9 ธ.ค. 2549 11:15:57 |
By :
jankasion |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
มันไม่ขึ้น Error เลยแต่มันทำงานแปลกๆ เวลาที่ผมเพิ่มข้อมูลใหม่ลงไป มันไม่ยอมแสดงข้อความ
"กำลังทำการ..บันทึกข้อมูลอยู่<br>กรุณารอสักครู่...." แต่สามารถใส่ข้อมูลลงใน table ได้ แต่ข้อความที่แสดง
กับเป็น "รหัสสมาชิก หรือ e-mail นี้มีอยู่แล้วครับ<br>กรุณารอสักครู่..."
ส่วน $numMember=mysql_num_rows($dataMember); ผมแทรกก่อนบรรทัด if($numMerber!=0) ครับ
|
|
|
|
|
Date :
9 ธ.ค. 2549 12:51:44 |
By :
alongkorns |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Load balance : Server 01
|