douzi9211 2019-05-15 12:51
浏览 296
已采纳

如果特定列中不存在值,则将数据插入数据库

I've tried to follow several answers on this question but can't seem to get it to work for my specific problem.

I want to insert data but only if the flight_number doesn't exists already. How can I do that?

$sql = mysqli_query($con,
  "INSERT INTO space (`flight_number`, `mission_name`, `core_serial`, `payload_id`)
  VALUES ('".$flight_number."', '".$mission_name."', '".$core_serial."', '".$payload_id."')"
);
  • 写回答

2条回答 默认 最新

  • doulu4534 2019-05-15 13:05
    关注

    Rob since you saying flight_number is a unique then you can use INSERT IGNORE

    <?php
    
    
        $sql = "INSERT IGNORE INTO space (`flight_number`, `mission_name`, `core_serial`, `payload_id`) VALUES (?,?,?,?)";
    
        $stmt = $con->prepare($sql);
        $stmt->bind_param('isss',$flight_number,$mission_name,$core_serial,$payload_id);
        if($stmt->execute()){
    
            echo 'data inserted';
            // INSERT YOUR DATA
        }else{
    
            echo $con->error;
        }
    
    ?>
    

    OR you could select any row from your database that equal to the provided flight number then if u getting results don't insert.

    $sql = "SELECT mission_name WHERE flight_number = ? ";
        $stmt = $con->prepare($sql);
        $stmt->bind_param('i',$flight_number);
        if(mysqli_num_rows($stmt) === 0){
    
    
            // INSERT YOUR DATA
        }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)