php - 检查mysql中是否存在值

标签 php mysql

我有一个小脚本,用于将数据从 csv 文件上传到 mysql 数据库,我想检查 csv 文件内的值列表。

CSV 文件:

code,alert_quantity
12345,10

PHP 文件:

    <?php
    $link_id = mysql_connect("localhost", "root", "")
               or die("Could not connect.");

    if(!mysql_select_db("database",$link_id))
    die("database was not selected.");

    function _checkIfCodeExists($code){

    $sql        = "SELECT COUNT(*) AS count_no FROM products WHERE code = ?";
    $count      = $sql;
    if($count > 0){
        return true;
    }else{
        return false;
    }
    }

    function _updateData($line_of_data){
    $code            = $line_of_data[0];
    $newAlert       = $line_of_data[1];

    $sql = "UPDATE ";
}

    $file_handle = fopen("file.csv", "r");

    while (($line_of_data = fgetcsv($file_handle, 1000, ",")) !== FALSE) {

    $query = mysql_query("SELECT * FROM products WHERE code ='$line_of_data[0]'") or die(mysql_error());
    $message = '';
    $count   = 1;

    if(_checkIfCodeExists($line_of_data[0])){
        try{
            _updateData($_data);
            $message .= $count . '> Success:: Product with code  (' . $line_of_data[1] . ') Exist (' . $line_of_data[0] . '). <br />';

        }catch(Exception $e){
            $message .=  $count .'> Error:: While updating alert (' . $line_of_data[1] . ') of code (' . $line_of_data[0] . ') => '.$e->getMessage().'<br />';
        }
    }else{
        $message .=  $count .'> Error:: Product code   (' . $line_of_data[0] . ')   Doesnt exist<br />';
    }
    $count++;
}
echo $message;

?>

我不想导入这些值,只是想检查是否存在并获取结果。

感谢任何帮助。

最佳答案

正如其他人所说,您确实应该使用 PDO。但是,为了回答您的问题,mysql_num_rows 是您的解决方案。

$query = mysql_query("SELECT * FROM products WHERE code='$line_of_data[0]' AND alert_quantity = '$line_of_data[1]'") or die(mysql_error());

if (mysql_num_rows($query))
// Data is already in database
else
// Data not in database

关于php - 检查mysql中是否存在值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14343702/

相关文章:

php - angularjs和PHP:在飞行前响应中,Access-Control-Allow-Headers不允许请求 header 字段Access-Control-Allow-Origin

php - 电子邮件消息队列 - X worker 和停止重叠

mysql - 使用另外 2 个表中的数据插入到表中

php - 如何使用带有mysql的php codeigniter压缩数据

php - 如何在获取非重复条目的同时查询重复条目?

javascript - Jquery在循环中执行一些记录计算

php - 我不能在网站标题/标题上呈现句号吗

php - 具有第二个表 id 的 3 列的 Sql 表

mysql - 如何使用两个值来定义MySQL中的顺序但优先其中一个?

mysql - 使用 MySQL 计算曾经在线的大多数用户