PHPmySQL ソート 昇順降順

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 2,374

いつもお世話になっております。

私はPHPとmysqlを使って下記画像の物を作成しております。
イメージ説明

私が実装したい機能は昇順と降順です。
ドスパラなど通販サイトにある上向きの▲を押すと昇順、下▼なら降順といった感じにしたいです。
イメージ説明

今回その機能をつけたい場所はイベント名のところにつけたいと思っております。

<?php
session_start();

if($link !== false)
{
    $page = (int)$_GET['page'];
    if($page <= 0){
        $page = 1;
    }
    //件数を取得する
    $sql = "SELECT count(uketuke.uketuke_id) as total FROM  uketuke , login WHERE uketuke.login_id=login.login_id";
if($_POST['select2'] != ""){
    $sql .= " AND uketuke.login_id=".$_POST['select2'];
}

if($_POST['nyuryoku'] != ""){
    $sql .= " AND uketuke.eventmei like '%".$_POST['nyuryoku']."%'";
}

    $result    = mysql_query($sql);
    $total = mysql_result($result, 0, 'total');


    // テーブルのデータを取得する
    $sql = "SELECT uketuke.*, login.name FROM  uketuke , login WHERE uketuke.login_id=login.login_id";
if($_POST['select2'] != ""){
    $sql .= " AND uketuke.login_id=".$_POST['select2'];
}

if($_POST['nyuryoku'] != ""){
    $sql .= " AND uketuke.eventmei like '%".$_POST['nyuryoku']."%'";
}

    $sql .= " ORDER BY login_id LIMIT ".(($page-1)*10).",10";

if( ){
    $sql .= " ORDER BY eventmei ASC LIMIT ".(($page-1)*10).",10";
}

if( ){
    $sql .= " ORDER BY eventmei DESC LIMIT ".(($page-1)*10).",10";
}

    $result    = mysql_query($sql);
    $count    = mysql_num_rows($result);

    // テーブルのデータを取得する
    $sql = "SELECT login.* FROM login";

    $result2    = mysql_query($sql);
    $count2    = mysql_num_rows($result2);

    // テーブルのデータを取得する
    $sql = "SELECT login.* FROM login";

    $result3    = mysql_query($sql);
    $count3    = mysql_num_rows($result3);


コードは上記のようになっており、昇順降順はASCとDESCとわかっているのですが、if文の中身がいまいちわかりません。

下記データベースがuketukeという名のテーブルになりその次がloginという名のテーブルになります。
イメージ説明
イメージ説明

phpとmysqlはまだ触って日も浅いので質問の意図、問題の説明がわかりにくいと思いますが、
その場合はお手数ですが質問の修正依頼をお願いいたします。

ご教授よろしくお願い致します。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • shi_ue

    2016/07/12 14:16

    全体をコードブロックに入れるとは・・・斬新ですね。

    キャンセル

  • syosinsyapurogu

    2016/07/12 14:20

    shi_ueさん
    すみません私の勘違いで全体をコードブロックしてしまいました。
    とてもお恥ずかしいです、、、汗


    キャンセル

  • syosinsyapurogu

    2016/07/12 14:24

    yambejpさん
    追加・修正の依頼ありがとうございます!
    PDOについて調べさせていただいたのですが
    「PHP Data Objects」の略なんですね!
    PODは使ったことがないので勉強させていただきます。

    キャンセル

回答 2

checkベストアンサー

+3

phpとmysqlはまだ触って日も浅いので質問の意図、問題の説明がわかりにくいと思いますが、 
その場合はお手数ですが質問の修正依頼をお願いいたします。

インデントも滅茶苦茶だし、postされたデータをそのまんまSQLに突っ込んでいるし、何のフィールドが何を表しているかも分からないし、廃止されるという mysql APIを使っているし・・・

ちょっと直すべきことが多すぎて、どこから指摘していいものやら・・・

「こうしたいです」というのは丸投げです。
「こうしたけどうまく動きませんでした」というなら直せます。

もう少し頑張ってみたらどうですか?
ヒントとして、GETでpageを付けていますが、それと似たような感じです。昇順降順にしたいフィールドをパラメータで持たせればいいです。
http://www.example.com/test.php?page=1&event_name=desc
みたいにやって、order byの条件を作ってやってください。

pdo、パラメータクエリ、なども検索してみてください。
頑張って!

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/07/12 15:53

    shi_ueさん
    ご回答ありがとうございます!
    私のコードなどがめちゃくちゃでお見苦しい物を見せててしまい大変申し訳ないです。
    教えて頂いた改善点はしっかり時間をかけ、理解しながら修正させていただきます。
    質問の仕方も丸投げにならないように気を付けたいと思います。

    ヒントとしていただいた、GETでpageを付けるやつを参考にさせていただき無事動くようになりました!大変ありがとうございました。またなにかありましたらその時は宜しくお願い致します。。

    キャンセル

+1

簡単なサンプルです
今回はSQL文を確認できるようにベタうちしていますが、
PDOを利用する場合はもうちょっと工夫が必要です。

<?PHP
$page=filter_input(INPUT_GET,"page",FILTER_VALIDATE_INT,array('options'=>array('default'=>1,'min_range'=>1,'max_range'=>10)));
$sort=filter_input(INPUT_GET,"sort");
$sort_list=array("X","Y","Z");
if(!in_array($sort,$sort_list)) $sort=$sort_list[0];
$asc=filter_input(INPUT_GET,"asc");
$asc_list=array("asc","desc");
if(!in_array($asc,$asc_list)) $asc=$asc_list[0];
$count_per_page=10;
$limit=(($page-1)*$count_per_page).",".$count_per_page;

print <<<eof
<table border>
<tr>
<th>X <a href="?page={$page}&amp;sort=X&amp;asc=asc">▲</a> <a href="?page={$page}&amp;sort=X&amp;asc=desc">▼</a></th>
<th>Y <a href="?page={$page}&amp;sort=Y&amp;asc=asc">▲</a> <a href="?page={$page}&amp;sort=Y&amp;asc=desc">▼</a></th>
<th>Z <a href="?page={$page}&amp;sort=Z&amp;asc=asc">▲</a> <a href="?page={$page}&amp;sort=Z&amp;asc=desc">▼</a></th>
</tr>
<tr>
<td>・・・</td>
<td>・・・</td>
<td>・・・</td>
</tr>
</table>
<hr>
<a href="?page=1&amp;sort={$sort}&amp;asc={$asc}">1</a>
<a href="?page=2&amp;sort={$sort}&amp;asc={$asc}">2</a>
<a href="?page=3&amp;sort={$sort}&amp;asc={$asc}">3</a>
<hr>
eof;
$sql ="SELECT * FROM WHERE 1 ";
$sql.="OERDER BY {$sort} {$asc} ";
$sql.="LIMIT {$limit}";
print  $sql;

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/07/12 15:55

    yambejpさん
    ご回答ありがとうございます。
    無事解決することができました!

    キャンセル

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

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