質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Stripe

Stripeとは、米国のオンライン決済システム提供企業、及び同社が提供する決裁システムを指します。Webサイトやモバイルアプリにコードを組み込むことでクレジットカードなどの決済サービスが簡潔に追加できます。

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

解決済

2回答

2301閲覧

laravel/cashierを用いたsubscription機能

hirao_program

総合スコア16

Stripe

Stripeとは、米国のオンライン決済システム提供企業、及び同社が提供する決裁システムを指します。Webサイトやモバイルアプリにコードを組み込むことでクレジットカードなどの決済サービスが簡潔に追加できます。

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2020/02/06 17:24

編集2020/02/07 08:34

laravelでsubscription機能を作成するために、stripeとの連携を終え、管理画面での定期購入用プランの作成をしました、
その後controllerでの処理を書いたのですが「SQLSTATE[42S22]: Column not found: 1054 Unknown column 'user_user_id' in 'field list' (SQL: insert into subscriptions (name, stripe_id, stripe_plan, quantity, trial_ends_at, ends_at, user_user_id, updated_at, created_at) values (main, ****, 1, ?, ?, ****, 2020-02-06 17:04:22, 2020-02-06 17:04:22))」(一部伏せ字)となってしまい、うまく処理が完了されませんでした

laravel6
laravel/cashier 9.x

public function post(Request $request){ try { Stripe::setApiKey(env('STRIPE_SECRET')); $user_id = Auth::id();//user_id取得 $user = User::find($user_id); $user->newSubscription('main', '*****')->create($request->stripeToken); return back(); } catch (\Exception $ex) { return $ex->getMessage(); } }

##現時点での問題点
uuidを使用しているため、user_idの型をbig_integerからvar_charに変更しなければいけない
「Unknown column 'user_user_id'」の表記からどこかでuser_user_idと記述が間違えている可能性がある(自分で書いたコードは上記のものだけです)

##知りたいこと
(解決済み)subscriptionsのmigrationファイルがdatabaseの中に見つからなかったのでどこにあるのか教えていただきたいです。
(回答にあるコマンドの後、自分でファイルを作成し、実行しました。)

二つ目に関して、まだ調べきれていないところもありますが、詳しい解決法などが分かる方がおられましたら教えていただきたいです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

subscriptionsのmigrationファイルがdatabaseの中に見つからなかったのでどこにあるのか教えていただきたいです。

php artisan vendor:publish --tag="cashier-migrations"

を実行すれば出てきます。

user_user_id

リレーションの命名規則がバグった様な見た目をしている気がしますが・・・

関連しそうなのは下記ですね

https://github.com/laravel/cashier/blob/9.0/src/SubscriptionBuilder.php#L219

https://github.com/laravel/cashier/blob/9.0/src/Billable.php#L212

Userモデルで
subscriptionsやgetForeignKeyをいじった記憶とかはないでしょうか?

投稿2020/02/07 03:24

編集2020/02/07 05:49
mikkame

総合スコア5036

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hirao_program

2020/02/07 06:00

```php artisan vendor:publish --tag="cashier-migrations" を実行した結果 ``` Unable to locate publishable resources. Publishing complete. ``` と表示され、database以下には何も生成されませんでした... 調べても情報が出てこなかったのですが、解決策は何がありますか。。? すいません送信されておらず、遅くなってしまいました。。
hirao_program

2020/02/07 06:03

userに関しては本文でも記載していますが、uuidを使用している以外には思い当たるような変更等はしていません
hirao_program

2020/02/07 11:42

最終的にuser_user_idはuserモデルに /** * Get the default foreign key name for the model. * * @return string */ public function getForeignKey() { return $this->getKeyName(); } と記載したことで解決しました。
mikkame

2020/02/08 05:16

謎いですが解決した様でしよかったです
guest

0

VALUESのカッコの中の文字列と日付データはシングルクォートで囲んでください。
日付型と時刻型(DATE, TIME, DATETIME, TIMESTAMP, YEAR) も参考に。

質問にCREATE TABLE文を提示できた方が適切なコメントが付き易いです。

投稿2020/02/06 20:06

Orlofsky

総合スコア16415

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hirao_program

2020/02/07 03:31

回答ありがとうございます laravelのプラグインを用いての作業で、そもそもmigrationファイルが見つからなかったので、それがどこにあるのか不明だったため、質問をさせていただきました。 丁寧にURLまで添付いただきありがとうございます。
mikkame

2020/02/07 04:18

> VALUESのカッコの中の文字列と日付データはシングルクォートで囲んでください。 これに関してはLaravelのクエリビルだが出してくるやつなのであまり関係ないかと思います・・・
Orlofsky

2020/02/07 04:48

>SQLSTATE[42S22]: Column not found: 1054 Unknown column 'user_user_id' in 'field list' (SQL: insert into subscriptions (name, stripe_id, stripe_plan, quantity, trial_ends_at, ends_at, user_user_id, updated_at, created_at) values (main, **, 1, ?, ?, **, 2020-02-06 17:04:22, 2020-02-06 17:04:22)) user_user_id 列が存在しないのでは?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問