php - 通过嵌套 foreach 循环将数据从 PHP 插入到 Mysql

标签 php mysql sql arrays json

我正在尝试将从 json 获取的数据输入到数据库中。我已将数据作为多维数组获取,并使用 foreach 循环来循环数组。

我正在尝试将此数据插入 mysql 数据库,但我不断收到错误错误:字段“摘要”没有默认值

我的数据库表在称为跟踪的数据库中称为文章,具有以下字段:article_id、url、domain、favicon、title、summary、likes、tweets、plusones、image、category

我的php文件名为json_parser.php,如下所示

<?php
define('DB_NAME', 'tracking');
define('DB_USER', 'xxxxxxxxxxx');
define('DB_PASSWORD', 'xxxxxxxxx');
define('DB_HOST', 'localhost');

$link = mysql_connect(DB_HOST, DB_USER, DB_PASSWORD);

if (!$link){
    die('Could not connect: ' . mysql_error());
}

$db_selected = mysql_select_db(DB_NAME, $link);

if(!$db_selected){
    die('Cannot use '. DB_NAME . ': ' .mysql_error());
}

$url = "http://digitalrand.net/api/url_data/?key=abacus&pass=aba123cuxza%";
$json = file_get_contents($url);
$obj = json_decode($json, true);

foreach($obj as $article_array){

    $url = $article_array['url'];
    $domain = $article_array['domain'];
    $favicon = $article_array['favicon'];
    $title = $article_array['title'];
    $category = $article_array['category'];
    echo $category . "<br>";
    echo $domain . "<br>";
    echo $favicon . "<br>";
    echo $title . "<br>";
    echo $url . "<br>";

    $sql = 'INSERT INTO articles '.
               '(url, domain, favicon, title) '.
               'VALUES ( "$url", "$domain","$favicon","$title" )';
    if (mysql_query($sql)){
        echo "success.......";
    }


    if(!mysql_query($sql)){
       die('Error: ' . mysql_error());
    }

    $large_summary = $article_array['summary'];
    foreach ($large_summary as $summary){
        mysql_query("INSERT INTO articles(summary) VALUES('$summary')");
        echo "$summary <br>";
    }
    $images = $article_array['images'];
    foreach ($images as $image){        
        $image_first= reset($image);
        echo $image_first;
        mysql_query("INSERT INTO articles(image) VALUES($image_first)");
        echo "<img src=$image_first>";
    }
    $social_shares = $article_array['social_shares'];

    foreach($social_shares as $social_share=>$include){
        echo $social_share . ": " . $include . "<br>";
    }

    $entities = $article_array["entities"];

    foreach($entities as $entity_cat=>$entities_arr){
        foreach($entities_arr as $key=>$entity){
            echo $entity_cat.' >> '.$entity. "<br>";
        } 
    }
}   

?>

如何循环遍历数组项并将其显示在适当的字段上

最佳答案

首先,您的代码中有一个错误:

foreach ($large_summary as $summary){ mysql_query("INSERT INTO articles(summary) VALUES($summary)"); echo "$summary <br/>"; }

foreach ($large_summary as $summary){ mysql_query("INSERT INTO articles(summary) VALUES('$summary')"); echo "$summary <br/>"; }

然后,请记住您正在插入仅包含 (url, domain, favicon, title) 的行。字段,然后是一些仅包含 (summary) 的行然后另一个只有 (image) .
我认为您不想插入到同一行中,不是吗?

如果你不想让它工作,你必须设置一个默认值:

ALTER TABLE `articles` CHANGE `summary` `summary` TEXT NULL DEFAULT NULL;

[编辑回答 Mutuma 评论]

您的数据库设置不正确。您对一组 (url, domain, favicon, title) 的总结很少.

所以你必须创建另一个表,例如 summaries(id, ref_article, summary) ...
images 也是如此!

请重新考虑基本结构。

关于php - 通过嵌套 foreach 循环将数据从 PHP 插入到 Mysql,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22557389/

相关文章:

cakephp - Cakephp 1.3 和 PHP 5.3.2 的时区和更多问题

mysql - 两列使用 SUM 和 GROUPED 的 SQL

sql - 在 Entity Framework 中的 SQL View 上使用外键

javascript - 这个javascript和php代码有什么问题吗?

php - 无法在数据库中更新和/或插入图像(显示它也有问题)

javascript - 如何在 MySQL 上存储 cron 时间表达式

PHP、MySQL、引号和输入字段

mysql - 如果值不正确,则在 MySQL 函数中设置默认变量

mysql - 使用表中的数据作为列标题

php - 使用 php Imagick 保留背景调整 PNG 的大小