简体   繁体   English

从两个mysql表中获取数据并导出为JSON

[英]Fetch data from two mysql tables and export to JSON

I need to create json data in this format: 我需要以这种格式创建json数据:

{
    "cols": [{
        "label": "ID",
        "type": "number"
    }, {
        "label": "Vrsta",
        "type": "string"
    }, {
        "label": "Artikl",
        "type": "string"
    }, {
        "label": "Neto kol",
        "type": "number"
    }, {
        "label": "Bruto kol",
        "type": "number"
    }, {
        "label": "Mera",
        "type": "string"
    }, {
        "label": "Neto iznos",
        "type": "number"
    }, {
        "label": "Bruto",
        "type": "number"
    }, {
        "label": "Porez",
        "type": "number"
    }, {
        "label": "Dobavljac",
        "type": "string"
    }, {
        "label": "Datum",
        "type": "date"
    }, {
        "label": "Skladiste",
        "type": "string"
    }, {
        "label": "Valuta",
        "type": "string"
    }, {
        "label": "Placeno",
        "type": "string"
    }, {
        "label": "Nacin placanja",
        "type": "string"
    }, {
        "label": "Placeni iznos",
        "type": "number"
    }, {
        "label": "Opis",
        "type": "string"
    }],
    "rows": [{
        "c": [{
            "v": 1
        }, {
            "v": "gorivo"
        }, {
            "v": "biodizel"
        }, {
            "v": 22
        }, {
            "v": 22
        }, {
            "v": "l"
        }, {
            "v": 29
        }, {
            "v": 36
        }, {
            "v": 20
        }, {
            "v": "Nis"
        }, {
            "v": "Date(2014, 02, 25)"
        }, {
            "v": "Bure 5"
        }, {
            "v": "e"
        }, {
            "v": "Da"
        }, {
            "v": "gotovinsko"
        }, {
            "v": 36
        }, {
            "v": "kupljeno gorivo za setvu"
        }]
    }, {
        "c": [{
            "v": 2
        }, {
            "v": "djubrivo"
        }, {
            "v": "b432"
        }, {
            "v": 5
        }, {
            "v": 5
        }, {
            "v": "m3"
        }, {
            "v": 100
        }, {
            "v": 120
        }, {
            "v": 20
        }, {
            "v": "STR polja"
        }, {
            "v": "Date(2014, 02, 25)"
        }, {
            "v": "dvoriste iza"
        }, {
            "v": "e"
        }, {
            "v": "da"
        }, {
            "v": "kompenzacija"
        }, {
            "v": 120
        }, {
            "v": "Djubrenje"
        }]
    }]
}

but I do this with one table with this code: 但是我用一个表用此代码来做到这一点:

try {
      /* Establish the database connection */
      $conn = new PDO("mysql:host=localhost;dbname=$dbname", $username, $password);
      $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

      /* select all the weekly tasks from the table googlechart */
      $result = $conn->query('SELECT * FROM zalihe');

      $rows = array();
      $table = array();
      $table['cols'] = array(

        array('label' => 'ID', 'type' => 'number'),
        array('label' => 'Vrsta', 'type' => 'string'),
    array('label' => 'Artikl', 'type' => 'string'),
    array('label' => 'Neto kol', 'type' => 'number'),
        array('label' => 'Bruto kol', 'type' => 'number'),
    array('label' => 'Mera', 'type' => 'string'),
        array('label' => 'Neto iznos', 'type' => 'number'),
    array('label' => 'Bruto', 'type' => 'number'),
        array('label' => 'Porez', 'type' => 'number'),  
        array('label' => 'Dobavljac', 'type' => 'string'),
        array('label' => 'Datum', 'type' => 'date'),
        array('label' => 'Skladiste', 'type' => 'string'),
        array('label' => 'Valuta', 'type' => 'string'),
        array('label' => 'Placeno', 'type' => 'string'),
        array('label' => 'Nacin placanja', 'type' => 'string'),
        array('label' => 'Placeni iznos', 'type' => 'number'),
        array('label' => 'Opis', 'type' => 'string')
    );
        /* Extract the information from $result */
        foreach($result as $r) {
          $temp = array();
          // the following line will be used to slice the Pie chart
          $temp[] = array('v' => (int) $r['ID']); 
          $temp[] = array('v' => (string) $r['vrsta']);
          $temp[] = array('v' => (string) $r['artikl']); 
          $temp[] = array('v' => (int) $r['neto_kol']);
          $temp[] = array('v' => (int) $r['bruto_kol']);
          $temp[] = array('v' => (string) $r['jmere']); 
          $temp[] = array('v' => (int) $r['neto_iznos']);
          $temp[] = array('v' => (int) $r['bruto_iznos']);
          $temp[] = array('v' => (int) $r['porez']);
          $temp[] = array('v' => (string) $r['dobavljac']); 
          $temp[] = array('v' => 'Date('.str_replace('-',', ',($r['datum'])).')');
          $temp[] = array('v' => (string) $r['skladiste']); 
          $temp[] = array('v' => (string) $r['valuta']); 
          $temp[] = array('v' => (string) $r['placeno']); 
          $temp[] = array('v' => (string) $r['nacin_placanja']); 
          $temp[] = array('v' => (int) $r['placeni_iznos']);
          $temp[] = array('v' => (string) $r['opis']); 


          // Values of each slice

          $rows[] = array('c' => $temp);
        }

    $table['rows'] = $rows;

    // convert data into JSON format
    $jsonTable = json_encode($table);
    //echo $jsonTable;
    } catch(PDOException $e) {
        echo 'ERROR: ' . $e->getMessage();
    }
    echo $jsonTable;

Now I have one more table from where I need to get data also and put in the same json file: 现在,我还有另外一张表,我也需要从该表中获取数据并放入相同的json文件中:

and this table is: 该表是:

CREATE TABLE IF NOT EXISTS `skladista` (
  `ID` int(11) NOT NULL AUTO_INCREMENT,
  `naziv` text NOT NULL,
  `kapacitet` int(11) NOT NULL,
  `jmere` text NOT NULL,
  `vlasnistvo` text NOT NULL,
  `beleske` text NOT NULL,
  PRIMARY KEY (`ID`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;

Now how I can add data from second table "skladista" to the php file and to create one php-JSON file with two mysql tables... 现在,我如何将第二个表"skladista"中的数据添加到php文件中,并使用两个mysql表创建一个php-JSON文件...

I will easily add "cols" becouse its just "string names" but then I need to fetch data from second table... 我将轻松添加“ cols”,因为它只是“字符串名称”,但随后我需要从第二个表中获取数据...

SO HOW to: mysql tables "zalihe" + "skladista" = one json file? 那么如何:mysql表“ zalihe” +“ skladista” =一个json文件?

please help! 请帮忙!

May be this small example will help you.. 可能这个小例子会对您有所帮助。

// Get the max key of your already existed $temp array
$max_key_val = max(array_keys($temp));

// Fetch data from table-skladista
$data = mysql_query("Your-SQL-query");
while($row = mysql_fetch_array($data))
{
    $temp[$max_key_val++] = array('v' =>  $row['tbl_col_name']); 
}

// Then follow your same procedure
$rows[] = array('c' => $temp);
$table['rows'] = $rows;

$jsonTable = json_encode($table);

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM