douchongzhang9267 2019-04-08 02:38
浏览 549

使用laravel在mysql中插入多维数组json

Im trying to insert this multidemensional array from a nested json but im not sure how to tackle this. The array shows as the following when printed:

{ 
    "CompanyCode": "12345", 
    "CustomerNumber": "ABC0012300DEF", 
    "RequestID": "2017262221400000001975", 
    "ChannelType": "2014", 
    "CustomerName": "Customer Virtual Account", 
    "CurrencyCode": "IDR", 
    "PaidAmount": "60000.00", 
    "TotalAmount": "100000.00", 
    "SubCompany": "", 
    "TransactionDate": "15/03/2014 22:07:40", 
    "Reference": "", 
    "DetailBills": [ 
        { 
            "BillAmount": "25000.00", 
            "BillNumber": "1234567890", 
            "BillSubCompany": "00002", 
            "BillReference": "12345678900" 
        }, 
        { 
            "BillAmount": "35000.00", 
            "BillNumber": "2234567891", 
            "BillSubCompany": "00003", 
            "BillReference": "22345678901" 
        } 
    ], 
    "FlagAdvice": "N", 
    "Additionaldata": "" 
}

here's my code in laravel with db::insert :

DB::insert('insert into bca_company_payload (companyCode, customerNumber, requestID, channelType, customerName, paidAmount, totalAmount, subCompany, transactionDate, reference, flagAdvice, addtionalData) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)', [$company_code, $customer_number, $request_id, $channel_type, $customer_name, $currency_code, $paid_amount, $total_amount, $sub_company, $transaction_date, $reference, $detail_bills, $flag_advice, $addtional_data]);
        return response()
            ->json('The data was successfully inserted', 200)
            ->header('Access-Control-Allow-Origin', '*');
  • 写回答

1条回答 默认 最新

  • dongmi4927 2019-04-08 03:29
    关注

    you can do this,

    //I am asuming that you are taking the json from you the $request
    $responseData = json_decode($request->response);
    
    //if you are using laravel 5.8 you need you Arr class like this Arr::only()
    $data = array_only($responseData , ['CompanyCode', 'CustomerNumber', 'RequestID', 'ChannelType', 'CustomerName', 'PaidAmount', 'TotalAmount', 'SubCompany', 'TransactionDate', 'Reference', 'FlagAdvice', 'AddtionalData'])
    
    DB::insert('insert into bca_company_payload (companyCode, customerNumber, requestID, channelType, customerName, paidAmount, totalAmount, subCompany, transactionDate, reference, flagAdvice, addtionalData) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)', $data);
    
    评论

报告相同问题?

悬赏问题

  • ¥15 seatunnel-web使用SQL组件时候后台报错,无法找到表格
  • ¥15 fpga自动售货机数码管(相关搜索:数字时钟)
  • ¥15 用前端向数据库插入数据,通过debug发现数据能走到后端,但是放行之后就会提示错误
  • ¥30 3天&7天&&15天&销量如何统计同一行
  • ¥30 帮我写一段可以读取LD2450数据并计算距离的Arduino代码
  • ¥15 飞机曲面部件如机翼,壁板等具体的孔位模型
  • ¥15 vs2019中数据导出问题
  • ¥20 云服务Linux系统TCP-MSS值修改?
  • ¥20 关于#单片机#的问题:项目:使用模拟iic与ov2640通讯环境:F407问题:读取的ID号总是0xff,自己调了调发现在读从机数据时,SDA线上并未有信号变化(语言-c语言)
  • ¥20 怎么在stm32门禁成品上增加查询记录功能