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

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

新規登録して質問してみよう
ただいま回答率
85.48%
SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

SQL

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Laravel 5

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

Q&A

解決済

1回答

646閲覧

laravelでeloquentを使用したいのですがエラーが出てしまいます。

cofee

総合スコア44

SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

SQL

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Laravel 5

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

0グッド

0クリップ

投稿2018/01/10 07:08

編集2018/01/10 07:09

Laravel5でeloquentを使用してクエリを書いているのですがわからなかくなったので質問します。

SQL

1 2select convert(varchar,work,111) as 作業日,count(mail) as 件数 3from comp_mail 4inner join arrival 5on comp_mail.key_no = arrival.key_no 6where mail = (select convert(date,SYSDATETIME())) 7group by convert(varchar,work,111) 8order by convert(varchar,work,111) desc 9

上記のSQLをLaravelで書きたいのですがどうしてもエラーが出てしまいます。

Laravel

1 2$reads = Read::select('convert(varchar,work,111)') 3 ->join('arrival','comp_mail.key_no','=','arrival.key_no') 4 ->where('mail','=','(SELECT CONVERT(date,SYSDATETIME()))') 5 ->groupBy('convert(varchar,work,111)') 6 ->count('mail');

SQLserverの方では正常にできますが、
Laravelでは'convert(varchar,work,111)' が無効です。
とエラーが出てしまいます。
どのように書けばよいのでしょうか?
よろしくお願い致します。

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

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

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

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

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

guest

回答1

0

ベストアンサー

未検証ですが…

php

1->groupBy(DB::raw('convert(varchar,work,111)'))

ではどうでしょうか?

投稿2018/01/10 07:20

motuo

総合スコア3027

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

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

cofee

2018/01/10 07:28

回答ありがとうございます。 エラー内容が「文字列から日付と時刻、またはそのいずれかへの変換中に、変換が失敗しました。」 に変わりました!
motuo

2018/01/10 07:41

クエリビルダの最後に->toSql()をつけると、発行されるSQLを文字列で取得できるようになります。 例えば、 $reads = Read::select('convert(varchar,work,111)') ->join('arrival','comp_mail.key_no','=','arrival.key_no') ->where('mail','=','(SELECT CONVERT(date,SYSDATETIME()))') ->groupBy(DB::raw('convert(varchar,work,111)')) ->count('mail')->toSql(); dd($reads); として画面に表示されるSQLを質問文に追記して貰えると、もう少し突っ込んだ回答が出来るかもしれません。
cofee

2018/01/10 08:24 編集

これでいいのでしょうか?? (SQL: select count([mail]) as aggregate from [comp_mail] inner join [arrival] on [comp_mail].[key_no] = [arrival].[key_no] where [mail] = (SELECT CONVERT(date,SYSDATETIME())) group by [CONVERT(varchar,work,111)]) よろしくお願いします。
motuo

2018/01/10 08:44

ざっと見た感じでは、あまり変なところはなさそうですね… ちなみに、 select('convert(varchar,work,111)')は、 selectRaw('convert(varchar,work,111)') しないと、Selectからは無くなってしまいます。 エラーメッセージを見る限りでは、文字列を日付に変換する事に失敗しているようですが、データに問題が無いか、念の為に確認してみては如何でしょうか?
cofee

2018/01/10 08:51

回答ありがとうございます。 $reads = Read::select(DB::raw('CONVERT(varchar,work,111)')) ->join('arrival','comp_mail.key_no','=','arrival.key_no') ->whereIn('mail',function($query) { $query->select(DB::raw('CONVERT(date,SYSDATETIME())')); }) ->groupBy((DB::raw('CONVERT(varchar,work,111)'))) ->count('mail'); これで正常にできました! 回答ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問