繁体   English   中英

如何以json格式将相同值的数组插入到列php mysql中

[英]How to insert arrays of same values in json format into a column php mysql

我有一个JSON格式如下

{
    "results": [
{
"url": "someurl",
"imageUrl": "somepath",
    "tickets": [
                {
                    "id": 98655,
                    "name": "ADULT TICKET",
                    "soldOut": false,
                    "provisionallySoldOut": false,
                    "price": 100,
                    "salesStart": "2018-06-26T11:52:00",
                    "salesEnd": "2018-07-28T17:00:00",
                    "description": "",
                    "donation": false,
                    "vendorTicket": false
                },
                {
                    "id": 98656,
                    "name": "UNDER 12",
                    "soldOut": false,
                    "provisionallySoldOut": false,
                    "price": 80,
                    "salesStart": "2018-06-26T11:53:00",
                    "salesEnd": "2018-07-28T17:00:00",
                    "description": "",
                    "donation": false,
                    "vendorTicket": false
                }
            ]
},
{
"url": "someurl",
"imageUrl": "somepath",
"tickets": [
                {
                    "id": 98735,
                    "name": "ADULT EARLY BIRD",
                    "soldOut": false,
                    "provisionallySoldOut": false,
                    "price": 150,
                    "salesStart": "2018-06-26T12:47:00",
                    "salesEnd": "2018-08-12T10:00:00",
                    "description": "",
                    "donation": false,
                    "vendorTicket": false
                },
                {
                    "id": 98736,
                    "name": "UNDER 12 - EARLY BIRD",
                    "soldOut": false,
                    "provisionallySoldOut": false,
                    "price": 120,
                    "salesStart": "2018-06-26T12:47:00",
                    "salesEnd": "2018-08-12T10:00:00",
                    "description": "",
                    "donation": false,
                    "vendorTicket": false
                }
            ]
}
],
"pageSize": 10,
    "pages": 1,
    "records": 2,
    "extras": null,
    "message": null,
    "statusCode": 0
}

我的数据库中有一个表为“ event_tickets”,它具有名称和价格列,我想在同一列中显示名称ADULT TICKET和UNDER 12,并用逗号分隔,在同一列中分别将价格100和80分隔为逗号

我想让它在我的表上显示这样的内容。为了更加清楚,我想使用php插入上表中提到的值。 表格格式应该像这样

name                                      |   price
ADULT TICKET,UNDER 12                     |  100,80
ADULT EARLY BIRD, UNDER 12 - EARLY BIRD   |  150,120

有什么办法可以用php实现呢?

因为当我尝试运行我的代码时,名称显示在不同的列中,价格显示在不同的列中

提前致谢

PHP中的一种解决方案:

// This is your json data.
$jsonData = '{
    "results": [
{
"url": "someurl",
"imageUrl": "somepath",
    "tickets": [
                {
                    "id": 98655,
                    "name": "ADULT TICKET",
                    "soldOut": false,
                    "provisionallySoldOut": false,
                    "price": 100,
                    "salesStart": "2018-06-26T11:52:00",
                    "salesEnd": "2018-07-28T17:00:00",
                    "description": "",
                    "donation": false,
                    "vendorTicket": false
                },
                {
                    "id": 98656,
                    "name": "UNDER 12",
                    "soldOut": false,
                    "provisionallySoldOut": false,
                    "price": 80,
                    "salesStart": "2018-06-26T11:53:00",
                    "salesEnd": "2018-07-28T17:00:00",
                    "description": "",
                    "donation": false,
                    "vendorTicket": false
                }
            ]
},
{
"url": "someurl",
"imageUrl": "somepath",
"tickets": [
                {
                    "id": 98735,
                    "name": "ADULT EARLY BIRD",
                    "soldOut": false,
                    "provisionallySoldOut": false,
                    "price": 150,
                    "salesStart": "2018-06-26T12:47:00",
                    "salesEnd": "2018-08-12T10:00:00",
                    "description": "",
                    "donation": false,
                    "vendorTicket": false
                },
                {
                    "id": 98736,
                    "name": "UNDER 12 - EARLY BIRD",
                    "soldOut": false,
                    "provisionallySoldOut": false,
                    "price": 120,
                    "salesStart": "2018-06-26T12:47:00",
                    "salesEnd": "2018-08-12T10:00:00",
                    "description": "",
                    "donation": false,
                    "vendorTicket": false
                }
            ]
}
],
"pageSize": 10,
    "pages": 1,
    "records": 2,
    "extras": null,
    "message": null,
    "statusCode": 0
}';

$servername = '';
$username   = '';
$password   = '';
$dbname     = ''; 

// Connect to your database
$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
} 

$formatedData = json_decode($jsonData);

foreach($formatedData->results as $result) {

    $names  = array();
    $prices = array();

    foreach($result->tickets as $ticket) {
        // Add each price and name to arrays
        $names[]  = $ticket->name;
        $prices[] = $ticket->price;
    }

    // Glue the arrays with comma into strings
    $combinedNames  = implode(',', $names);
    $combinedPrices = implode(',', $prices);

    // Perform your database query
    $sql = "INSERT INTO your_table 
         (name, price) 
       VALUES
         ('$combinedNames', '$combinedPrices')";
    // Remember to watch out for SQL injections
    if ($conn->query($sql) === true) {
        echo "New record created successfully";
    } else {
        echo "Error: " . $sql . "<br>" . $conn->error;
    }


}
$conn->close();   

暂无
暂无

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

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