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

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

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

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

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

Q&A

解決済

4回答

683閲覧

php artisan migrate でのエラー

退会済みユーザー

退会済みユーザー

総合スコア0

Laravel

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

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

0グッド

2クリップ

投稿2017/08/18 07:55

編集2017/08/18 08:15

laravel5 で認証画面を作成中です。
ubuntu16.04
php7.0
最終的にsqlserverに接続が目標です。

php artisan migrate
と打ったところ下記のエラーメッセージが出ました。

[Illuminate\Database\QueryException]
could not find driver (SQL: select * from sysobjects where ty
pe = 'U' and name = migrations)

[PDOException]
could not find driver

env など見直しましたが、わかりません。
ご教授いただけますでしょうか。

.env
APP_NAME=Laravel
APP_ENV=local
APP_KEY=base64:HeGYpAyoOns3i2Z3pIIYxC7Ac+5N1XPf8mAGA/TFv7A=
APP_DEBUG=true
APP_LOG_LEVEL=debug
APP_URL=http://localhost

DB_CONNECTION=sqlsrv
DB_HOST=
DB_PORT=
DB_DATABASE=
DB_USERNAME=
DB_PASSWORD=

BROADCAST_DRIVER=log
CACHE_DRIVER=file
SESSION_DRIVER=file
QUEUE_DRIVER=sync

REDIS_HOST=127.0.0.1
REDIS_PASSWORD=null
REDIS_PORT=6379

MAIL_DRIVER=smtp
MAIL_HOST=smtp.mailtrap.io
MAIL_PORT=2525
MAIL_USERNAME=null
MAIL_PASSWORD=null
MAIL_ENCRYPTION=null

PUSHER_APP_ID=
PUSHER_APP_KEY=
PUSHER_APP_SECRET=

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

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

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

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

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

aro10

2017/08/18 08:07 編集

driverが無いというエラーなので、秘密情報を省いた形でenvの中身を質問に記載すると回答できる事が増えるかと思います(簡単に検索するとsql-serverを利用する場合のエラーみたいなので、Laravelのバージョンと利用しているOS、データベースも記載するとよいかと思います)
退会済みユーザー

退会済みユーザー

2017/08/18 08:20 編集

ありがとうございます。内容を追加しましたのでご確認いただけますでしょうか。不慣れでして申し訳ありません。。laravel5.4です。失礼しました。
guest

回答4

0

ベストアンサー

CentOS7ですが以下の記事がLaravel5.3でのSQLServer設定例もあり参考になるかと思います。
CentOS 7.2 上の PHP 7.1 から SQL Server に接続する
Ubuntuは12.04LTSの記事ですが以下が参考になるかと思います。
Linux PHPからSQL Serverに接続
現状のLaravel5.4では、config/databaseにsqlsrvの設定は最初からあるようですがkawaxさんの情報からマイナーバージョンによって違うかもしれないので確認してみてください。
SqlServerが手元に無いので推測になりますが手順としては、Ubuntu16.04でphp7.0用のSQLServerクライアントのPHP拡張をインストールしてから、Laravelでの接続を試すと解決するかと思います

投稿2017/08/18 08:54

aro10

総合スコア4106

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

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

退会済みユーザー

退会済みユーザー

2017/08/18 09:33

ご回答ありがとうございます。 おっしゃるとおり、sqlsrvの設定は最初からあり、必要な箇所を設定しなおしました。 php拡張をインストールすることで解決できそうなので試してみます。 参考にしていたサイトは http://qiita.com/naga3/items/4f3defde59b31a1a797e です。 ubuntu にsqlsrvを入れるのではなく元々ある?sqlsrvに認証画面から接続という形ですのでそうすると紹介していただいたサイトは少し異なりますか?
aro10

2017/08/18 09:47 編集

別に稼働しているSQLServerのDBサーバーに対して、PHP(Laravel)を使ってクライアント接続するという形なので紹介したサイトの方法(PHPでのSQLServerクライアントの導入)でcould not find driver は解決するかと思います。 多分php7.0-sybaseを入れたら解決するかと思います。 ちなみにconfig/databaseのread/writeの設定は、複数DB運用時に読み書きを分けたい場合の設定なので、1台のDBサーバーでの運用であれば分けて書く必要ないです。 紹介したサイトは5.3等少し古い情報なので、5.4とは差異がある部分もあるので、5.4のマニュアルを正として参考にしてください。
退会済みユーザー

退会済みユーザー

2017/08/19 14:17

login画面は表示されました!ありがとうございます。 Registerをクリックするとエラーになるのでそこは何とかやってみます。 php7.0-sybaseもいれたのですがFreetdsファイルが編集できないので停滞しております。アドバイスいただいた通りやってみます。どうもありがとうございました。
guest

0

デフォルトではconfig/database.phpにSQLサーバーの設定ないので自分で追加する必要があります。
https://readouble.com/laravel/5.4/ja/database.html

投稿2017/08/18 08:34

kawax

総合スコア10377

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

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

退会済みユーザー

退会済みユーザー

2017/08/18 09:28

ご回答ありがとうございます。 sqlsrvの設定は最初からあり、必要な箇所を設定しなおしました。 色々なサイトを参考にしましたが1コマンドで出来るというほど単純ではないですね。。。
退会済みユーザー

退会済みユーザー

2017/08/18 09:33

紹介いただいたサイトのRead/Write接続 は sqlsrvの部分にも追加するのでしょうか?
guest

0

migrate ができなかった理由はsqlserverでデータを作成した場所が間違っていたから。
直打ちで接続したいところにデータを作ったらmigrateできました。

FreeTDSで接続する方法ではなく、MSが公式でSQLServerのドライバーが提供しているので、そのドライバーを使ったら接続できました。

SQLSRVに接続したときの参考サイト
http://qiita.com/arachan@github/items/bce9841568f63902f80c

参考になるサイトがあまりなく、あちこちのサイトを見て回りここまでたどり着きましたが初心者にとって超いばらの道でした。
最終的に編集したファイルは.env・database.php・app.php の3つです。

投稿2017/08/28 02:03

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

migrate ができなかった理由はsqlserverでデータを作成した場所が間違っていたから。
直打ちで接続したいところにデータを作ったらmigrateできました。

FreeTDSで接続する方法ではなく、MSが公式でSQLServerのドライバーが提供しているので、そのドライバーを使ったら接続できました。

SQLSRVに接続したときの参考サイト
http://qiita.com/arachan@github/items/bce9841568f63902f80c

参考になるサイトがあまりなく、あちこちのサイトを見て回りここまでたどり着きましたが初心者にとって超いばらの道でした。
最終的に編集したファイルは.env・database.php・app.php の3つです。

投稿2017/08/28 02:02

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問