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

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

ただいまの
回答率

91.00%

  • PHP

    17792questions

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

  • Laravel 5

    1449questions

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

  • XAMPP

    427questions

    XAMPP(ザンプ)は、ウェブアプリケーションの実行に必要なフリーソフトウェアをパッケージングしたApacheディストリビューションです。 XAMPPひとつインストールするだけで、Apache、MySQL、PHP、Perlなどのソフトウェアと、 phpMyAdminなどの管理ツール、SQLiteなどのソフトウェアやライブラリモジュールなどを利用することが可能です。

Laravel初心者です。

解決済

回答 2

投稿

  • 評価
  • クリップ 1
  • VIEW 132

borabora

score 2

タイトルにある通りlaravel初心者です。参考書を買いその通りに進めているのですが、参考書通りにログイン画面を作り、/helloにアクセスしたところ、SQLSTATE[42S22]:Column not found:1054 Unknown column " in 'order clause' (SQL:select*from 'people' where 'age' > 20 order by "asc limit7 offset0)というエラーが出てしまいます。原因も解決策もわからず、初心者のため困っています。解決策と原因を教えていただきたいです。

コントローラのソースコード(参考書そのままです。)
<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use Illuminate\Http\Response;
use Illuminate\Support\Facades\Input;

use App\Http\Requests\HelloRequest;

use Illuminate\Support\Facades\DB;

use Validator;

use Illuminate\Support\Facades\Session;
use Illuminate\Support\Facades\Auth;

use App\Person;

class HelloController extends Controller
{

public function getAuth(Request $request)
{
$param = ['message' => 'ログインして下さい。'];
return view('hello.auth', $param);
}

public function postAuth(Request $request)
{
$email = $request->email;
$password = $request->password;
if (Auth::attempt(['email' => $email, 
'password' => $password])) {
$msg = 'ログインしました。(' . Auth::user()->name . ')';
} else {
$msg = 'ログインに失敗しました。';
}
return view('hello.auth', ['message' => $msg]);

public function index(Request $request)
{
$user = Auth::user();
$sort = $request->sort;
$items = Person::orderBy($sort, 'asc')
->simplePaginate(6);
$param = ['items' => $items, 'sort' => $sort,
'user' => $user];
return view('hello.index', $param);
}

public function post(Request $request)
{
$items = DB::select('select * from people');
return view('hello.index', ['items' => $items]);
}

public function show(Request $request)
{
$page = $request->page;
$items = DB::table('people')
->offset($page * 3)
->limit(3)
->get();
return view('hello.show', ['items' => $items]);
}

public function add(Request $request)
{
return view('hello.add');
}

public function create(Request $request)
{
$param = [
'name' => $request->name,
'mail' => $request->mail,
'age' => $request->age,
];
DB::table('people')->insert($param);
//DB::insert('insert into people (name, mail, age) values (:name, :mail, :age)', $param);
return redirect('/hello');
}

public function edit(Request $request)
{
$item = DB::table('people')
->where('id', $request->id)->first();
return view('hello.edit', ['form' => $item]);
}

public function update(Request $request)
{
$param = [
'name' => $request->name,
'mail' => $request->mail,
'age' => $request->age,
];
DB::table('people')
->where('id', $request->id)
->update($param);
//DB::update('update people set name =:name, mail = :mail, age = :age where id = :id', $param);
return redirect('/hello');
}

public function del(Request $request)
{
$item = DB::table('people')
->where('id', $request->id)->first();
return view('hello.del', ['form' => $item]);
}

public function remove(Request $request)
{
DB::table('people')
->where('id', $request->id)->delete();
return redirect('/hello');
}

}

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

回答 2

checkベストアンサー

+2

$sort = $request->sort;
$items = Person::orderBy($sort, 'asc')

おそらく$sortが空なのでは?
order by 句に空のカラム名でソートをしているように見えます。
たとえばこうでしょうか?

$sort = $request->sort;
if($sort!=="") $items = Person::orderBy($sort, 'asc')

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/01/13 22:53

    回答ありがとうございます。
    例の通りにしてみたんですけどうまくいかないです...
    何が何だかわからない状態です。
    知識不足で申し訳ないです。

    キャンセル

+1

まずは…
ソースコードは```(バッククォート3)つで囲いましょう。

エラー内容を見ると、order by に''がありますね。その為、カラムが見つからない、というエラーが出ているようです。

$sort = $request->sort;  
$items = Person::orderBy($sort, 'asc')  

あたりが怪しいので、$sortがきちんとviewから渡されているかどうか、確認してみてください。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/01/13 22:54

    回答ありがとうございます。
    知識不足なのでもう少し勉強しようと思います。

    キャンセル

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

  • ただいまの回答率 91.00%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • PHP

    17792questions

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

  • Laravel 5

    1449questions

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

  • XAMPP

    427questions

    XAMPP(ザンプ)は、ウェブアプリケーションの実行に必要なフリーソフトウェアをパッケージングしたApacheディストリビューションです。 XAMPPひとつインストールするだけで、Apache、MySQL、PHP、Perlなどのソフトウェアと、 phpMyAdminなどの管理ツール、SQLiteなどのソフトウェアやライブラリモジュールなどを利用することが可能です。