Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/251.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
使用php将嵌套对象写入mysql_Php_Mysql_Object_Multidimensional Array - Fatal编程技术网

使用php将嵌套对象写入mysql

使用php将嵌套对象写入mysql,php,mysql,object,multidimensional-array,Php,Mysql,Object,Multidimensional Array,我想加载一个xml文件,过滤并在数据库中放入几行。到目前为止,它可以加载、解析到字符串、过滤。但是如何才能正确访问对象的第二级 object(SimpleXMLElement)#2 (2) { ["message_header"]=> object(SimpleXMLElement)#3 (1){ ["@attributes"]=> array(6) { ["source"]=> string(10) "Alltron AG"

我想加载一个xml文件,过滤并在数据库中放入几行。到目前为止,它可以加载、解析到字符串、过滤。但是如何才能正确访问对象的第二级

object(SimpleXMLElement)#2 (2) {
  ["message_header"]=> object(SimpleXMLElement)#3 (1){
      ["@attributes"]=> array(6) {
         ["source"]=> string(10) "Alltron AG" 
         ["message_type"]=> string(5) "price" 
         ["document_version_date"]=> string(10) "12.07.2013"
         ["document_version"]=> string(4) "2.00"
         ["generation_date"]=> string(10) "11.11.2016"
         ["generation_time"]=> string(8) " 2:58:02" } } 

  ["item"]=> array(85715) {
     [0]=> object(SimpleXMLElement)#4 (2) { 
        ["LITM"]=> string(4) "1289" 
           ["price"]=> object(SimpleXMLElement)#85719 (4) {
              ["INPR"]=> string(5) "34.25" 
              ["EXPR"]=> string(5) "31.71" 
              ["VATR"]=> string(1) "8" 
              ["ECPR"]=> string(2) "45" } } 
     [1]=> object(SimpleXMLElement)#5 (2) {
        ["LITM"]=> string(4) "1510"
and so on... 
现在我从加载和解析开始:

$data = file_get_contents("../cache/PreisdatenV2.xml");
$xml = simplexml_load_string($data);
和foreach的:

foreach ($xml -> item as $row){
    $litm = $row -> LITM;   
    $inpr = $row -> INPR;
    $expr = $row -> EXPR;
    $ecpr = $row -> ECPR;

    if ($litm == 1289)

        {
        $sql = "INSERT INTO `preisdaten`(`litm`,`inpr`,`expr`,`ecpr`)" .
        "VALUES ('$litm','$inpr','$expr','$ecpr')"; 
                if ($conn->query($sql) === FALSE) {echo "Error: " . $sql . "
                <br>" . $conn->error;}
        }; 
};
foreach($xml->item as$row){
$litm=$row->litm;
$inpr=$row->inpr;
$expr=$row->expr;
$ecpr=$row->ecpr;
如果($litm==1289)
{
$sql=“插入到'preisdaten'('litm'、'inpr'、'expr'、'ecpr')”。
“值('$litm'、'$inpr'、'$expr'、'$ecpr')”;
如果($conn->query($sql)==FALSE){echo“错误:“.$sql。”

“$conn->错误;} }; };

对于$litm,它可以正常工作,但对于其他值则不行。如何将最后一个部分更改为第二个级别的正确值?非常感谢您花时间帮助我。

最后三个变量是价格的子项。所以你需要改变

$inpr = $row -> INPR;
$expr = $row -> EXPR;
$ecpr = $row -> ECPR;


这么简单的解决方案?你的好,它工作:)再给我8分钟接受你的回答!非常感谢你!!
$inpr = $row -> price -> INPR;
$expr = $row -> price -> EXPR;
$ecpr = $row -> price -> ECPR;