|
|
|
รบกวนสอบถามเรื่องการเช็คข้อมูลซ้ำก่อน insert ลงใน database หน่อยครับ |
|
|
|
|
|
|
|
คือถ้าจะทำการเช็ค ชื่อร้านที่กำลังจะ insert ใหม่เข้า database ไม่ให้ซ้ำกับชื่อร้านที่มีอยู่แล้วใน database ควรจะเขียนโค้ดยังไงดีครับ
ลองประยุกต์จากที่ search ในเน็ตดูแล้วมันก็ยัง insert ข้อมูลซ้ำเข้าให้ รบกวนหน่อยนะครับ (เช็คจากค่า $shop_name อ่ะครับที่ไม่ให้ซ้ำกับ ที่มีอยู่ใน database)
Code (PHP)
<?php
require 'connect.php';
$ser_id = $_POST["ser_id"];
$shop_name = $_POST["name"];
$address = $_POST["address"];
$shop_detail = $_POST["detail"];
$phone = $_POST["phone"];
$lat = $_POST["lati"];
$log = $_POST["longti"];
$username = $_SESSION['user'];
$result = mysql_query("INSERT INTO `seniorpr_eb54-01`.`shop_info` (`shop_id`, `ser_id`, `shop_name`, `address`, `shop_detail`, `phone`,`lat`,`log`) VALUES (NULL, '".$ser_id."', '".$shop_name."', '".$address."', '".$shop_detail."', '".$phone."','".$lat."','".$log."');");
if (!$result) {
die('Invalid query: ' . mysql_error());
}else{
header("Location: rr_manage_shop.php");
}
mysql_close($con);
?>
Tag : PHP, MySQL
|
|
|
|
|
|
Date :
2015-05-01 01:18:09 |
By :
Nasit |
View :
1479 |
Reply :
4 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ลองดูแล้วครับ ตอนกด insert หน้าเว็บมันฟ้องแบบนี้อ่ะครับ
Warning: mysql_fetch_array() expects parameter 1 to be resource, boolean given on line 19
ตอนนี้ตื้อหมดละครับ
Code (PHP)
<?php
require 'connect.php';
session_name('tzLogin');
session_set_cookie_params(2*7*24*60*60);
session_start();
$ser_id = $_POST["ser_id"];
$shop_name = $_POST["name"];
$address = $_POST["address"];
$shop_detail = $_POST["detail"];
$phone = $_POST["phone"];
$lat = $_POST["lati"];
$log = $_POST["longti"];
$username = $_SESSION['user'];
$strSQL = 'SELECT * FROM shop_info WHERE shop_name = '.$shop_name;
$objQuery = mysql_query($strSQL);
$objResult = mysql_fetch_array($objQuery);
if(!$objResult)
{
$result = mysql_query("INSERT IGNORE INTO `seniorpr_eb54-01`.`shop_info` (`shop_id`, `ser_id`, `shop_name`, `address`, `shop_detail`, `phone`,`lat`,`log`) VALUES (NULL, '".$ser_id."', '".$shop_name."', '".$address."', '".$shop_detail."', '".$phone."','".$lat."','".$log."');");
}
else
{
echo "ชื่อร้านซ้ำ";
}
mysql_close($con);
?>
|
|
|
|
|
Date :
2015-05-01 02:24:23 |
By :
Nasit |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ลองอีกวิธีครับ
set unique key ไว้ที่ฟีลด์ที่ต้องการ
Code (PHP)
mysql_query( 'insert ......');
switch ( mysql_errno()){
case 1062: $err=mysql_error(); break; // Duplicate entry 'value' for key 'PRIMARY' or Duplicate entry 'value' for key 'keyname'
case 1054: // syntax error
}
ก็ลองเช็ค error number เอาเองนะครับ ว่า หมายถึงอะไร
|
|
|
|
|
Date :
2015-05-01 07:46:20 |
By :
Chaidhanan |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Load balance : Server 01
|