2016-05-23 3 views
-2

Я потратил около 2 часов на изменение сценария и поиск других способов сделать это, но не повезло. Если кто-нибудь может указать на какие-либо проблемы в моем сценарии, это было бы здорово. Большое спасибо.SQL Update или запрос запроса не работает

Я обновил сценарий, надеюсь, это даст лучшее понимание и более подробную информацию.

<?php 

    session_start(); 

if(!isset($_SESSION["user"]) or !is_array($_SESSION["user"]) or empty($_SESSION["user"])) { 
     // redirect to login page 
} 
$dbhost = "localhost"; 
$dbname = "**"; 
$dbuser = "root"; 
$dbpass = "**"; 

// database connection 
$conn = new PDO("mysql:host=$dbhost;dbname=$dbname",$dbuser,$dbpass); 
// new data 



error_reporting(E_ALL); 

        $work = $_POST['work']; 
        $education = $_POST['education']; 
        $location = $_POST['location']; 
        $relationship = $_POST['relationship']; 
        $phone = $_POST['phone']; 
        $email = $_POST['email']; 
        $website = $_POST['website']; 
        $language = $_POST['language']; 
        $skill = $_POST['skill']; 
        $tumblr = $_POST['tumblr']; 
        $instagram = $_POST['instagram']; 
        $skype = $_POST['skype']; 
        $facebook = $_POST['facebook']; 
        $youtube = $_POST['youtube']; 
        $twitter = $_POST['twitter']; 
        $about = $_POST['about']; 
        $user_id = $_SESSION['user']['id']; 

        echo $work."</br>"; 
        echo $education."</br>"; 
        echo $location."</br>"; 
        echo $relationship."</br>"; 
        echo $phone."</br>"; 
        echo $email."</br>"; 
        echo $website."</br>"; 
        echo $language."</br>"; 
        echo $skill."</br>"; 
        echo $tumblr."</br>"; 
        echo $instagram."</br>"; 
        echo $skype."</br>"; 
        echo $facebook."</br>"; 
        echo $youtube."</br>"; 
        echo $twitter."</br>"; 
        echo $about."</br>"; 
        echo $user_id; 

/* 
     "IF EXISTS (SELECT * FROM Table1 WHERE Column1=’SomeValue’) 
    UPDATE Table1 SET (…) WHERE Column1=’SomeValue’ 
ELSE 
    INSERT INTO Table1 VALUES (…)" 
*/ 

$sql = "IF EXISTS (SELECT * FROM user_details WHERE user_id=".$_SESSION['user']['id'].") 
    UPDATE user_details SET 
    (work='".$work."',education='".$education."',location='".$location."',relationship='".$relationship."',phone='".$phone."',email='".$email."',website='".$website."',language='".$language."',skill='".$skill."',tumblr='".$tumblr."',instagram='".$instagram."',skype='".$skype."',facebook='".$facebook."',youtube='".$youtube."',twitter='".$twitter."',about='".$about."') 
WHERE user_id='".$user_id."' 
ELSE INSERT INTO user_details (work,education,location,relationship,phone,email,website,language,skill,tumblr,instagram,skype,facebook,youtube,twitter,about,user_id) 
VALUES 
('".$work."','".$education."','".$location."','".$relationship."','".$phone."','".$email."','".$website."','".$language."','".$skill."','".$tumblr."','".$instagram."','".$skype."','".$facebook."','".$youtube."','".$twitter."','".$about."','".$user_id."')"; 
        $q = $conn->prepare($sql); 
        $q->execute(); 
     var_dump(mysql_error()) 



// header('Location: ../usr_settings.php'); 


?> 

ответ

2

Подробнее pls. Сообщение об ошибке, например, должно быть полезно. В UPDATE у вас есть $$ email (знак doulbe $$), который, вероятно, пытается ввести пустую электронную почту. Если он не может быть пустым - запрос может завершиться с ошибкой.

+0

Ну нет сообщения об ошибке. Все поля заполняются и отправляются из формы, как я проверял с помощью эхо-метода. Нет ошибок SQL или что-то еще. Я пытаюсь обновить таблицу базы данных, и если это не запрос с идентификатором пользователя, мне нужно вставить новый. –

+1

И, конечно, вы используете этот запрос с mysql_query или что-то подобное? –

+0

Yep mysql not mysqli –

Смежные вопросы