mysql - laravel php 数据存储 Array toJson
<code>$goods = ""; foreach($carts as $key => $c){ $good = Goods::where(["product_id" => $c->product_id,"merchant_id" => $c->merchant_id])->first(); $good -> number = $c->number; $goods[] = $good; } $order = new Order; $order -> json = $goods; if( $order->save()){ return response()->json(array( 'status' => 1, 'msg' => "下单成功")); }else{ return Redirect::back()->withInput()->withErrors('保存失败!'); } </code>
$goods 的到的数据 是一组数组
保存到数据库是就成了 Array 了
然后 用 json 转一下
<code>$goods = $goods->toJson(); </code>
toJson() 报错了
Call to a member function toJson() on array
有大神可以指导一下吗
回复内容:
<code>$goods = ""; foreach($carts as $key => $c){ $good = Goods::where(["product_id" => $c->product_id,"merchant_id" => $c->merchant_id])->first(); $good -> number = $c->number; $goods[] = $good; } $order = new Order; $order -> json = $goods; if( $order->save()){ return response()->json(array( 'status' => 1, 'msg' => "下单成功")); }else{ return Redirect::back()->withInput()->withErrors('保存失败!'); } </code>
$goods 的到的数据 是一组数组
保存到数据库是就成了 Array 了
然后 用 json 转一下
<code>$goods = $goods->toJson(); </code>
toJson() 报错了
Call to a member function toJson() on array
有大神可以指导一下吗
从你的foreach
来看,最后的$goods
是一个普通的数组,这个数组跟toJSON
没有什么必然联系,在我的记忆中,toJSON
应该不是php内置的吧。
想到的解决方案:
<code>$order -> json = json_encode($goods); </code>
对于上面的代码,还有以下的建议:
<code>foreach($carts as $key => $c){ $good = Goods::where(["product_id" => $c->product_id,"merchant_id" => $c->merchant_id])->first(); $good -> number = $c->number; $goods[] = $good; } </code>
上面这一段,我觉得你好好看看Eloquent的Relationship部分,这个应该会很好地解决了。
第二,else关键字其实很多时候是可以不用的:
<code>if( $order->save() ) { return response()->json(array( 'status' => 1, 'msg' => "下单成功")); } return Redirect::back()->withInput()->withErrors('保存失败!'); </code>
以上的代码应该也是行得通的
赞楼上,json_encode()是php最常用的内置函数之一,lz不要太过于依赖框架了

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









MySQLは、インストールが簡単で、強力で管理しやすいため、初心者に適しています。 1.さまざまなオペレーティングシステムに適した、単純なインストールと構成。 2。データベースとテーブルの作成、挿入、クエリ、更新、削除などの基本操作をサポートします。 3.参加オペレーションやサブクエリなどの高度な機能を提供します。 4.インデックス、クエリの最適化、テーブルパーティション化により、パフォーマンスを改善できます。 5。データのセキュリティと一貫性を確保するために、バックアップ、リカバリ、セキュリティ対策をサポートします。

NAVICATプレミアムを使用してデータベースを作成します。データベースサーバーに接続し、接続パラメーターを入力します。サーバーを右クリックして、[データベースの作成]を選択します。新しいデータベースの名前と指定された文字セットと照合を入力します。新しいデータベースに接続し、オブジェクトブラウザにテーブルを作成します。テーブルを右クリックして、データを挿入してデータを挿入します。

手順に従って、NAVICATで新しいMySQL接続を作成できます。アプリケーションを開き、新しい接続(CTRL N)を選択します。接続タイプとして「mysql」を選択します。ホスト名/IPアドレス、ポート、ユーザー名、およびパスワードを入力します。 (オプション)Advanced Optionsを構成します。接続を保存して、接続名を入力します。

NAVICATでSQLを実行する手順:データベースに接続します。 SQLエディターウィンドウを作成します。 SQLクエリまたはスクリプトを書きます。 [実行]ボタンをクリックして、クエリまたはスクリプトを実行します。結果を表示します(クエリが実行された場合)。

MySQLは、オープンソースのリレーショナルデータベース管理システムです。 1)データベースとテーブルの作成:createdatabaseおよびcreateTableコマンドを使用します。 2)基本操作:挿入、更新、削除、選択。 3)高度な操作:参加、サブクエリ、トランザクション処理。 4)デバッグスキル:構文、データ型、およびアクセス許可を確認します。 5)最適化の提案:インデックスを使用し、選択*を避け、トランザクションを使用します。

NAVICATがデータベースとそのソリューションに接続できない一般的な理由:1。サーバーの実行ステータスを確認します。 2。接続情報を確認します。 3.ファイアウォール設定を調整します。 4.リモートアクセスを構成します。 5.ネットワークの問題のトラブルシューティング。 6.許可を確認します。 7.バージョンの互換性を確保します。 8。他の可能性のトラブルシューティング。

データベースに接続するときの一般的なエラーとソリューション:ユーザー名またはパスワード(エラー1045)ファイアウォールブロック接続(エラー2003)接続タイムアウト(エラー10060)ソケット接続を使用できません(エラー1042)SSL接続エラー(エラー10055)接続の試みが多すぎると、ホストがブロックされます(エラー1129)データベースは存在しません(エラー1049)

and:mysql:Alter table_name add column_name data_type; postgresql:column column_name data_typeを変更するcolumn column_name datape; oracle:alter table_name add(column_name data_type);
