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

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

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

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

Q&A

解決済

1回答

886閲覧

select文のカラム名に変数を使えますか?

tukino-hikari

総合スコア26

PHP

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

0グッド

0クリップ

投稿2019/04/06 09:27

製品の管理をするプログラムを作成中でが手ごわいです。完全素人です!
データベースに製品に関するデータ、12項目を入力しています。
indexno,kaisyamei,tantousya,hinmei,sinaban,suuryou,tanka,zyutyuugappi,saizu,bikou,filename,timestampの12項目です。

select文のカラム名に変数を使い、12個のカラムから任意のカラムが抽出されるようにしたいのですが可能でしょうか?

//検索フォームからのデータを配列に入れる
$data=array();

if(!empty($_POST['indexno'])){$indexno=$_POST['indexno'];
$data=array_merge($data,array("indexno"=>"$indexno"));
// print_r($data);
}
if(!empty($_POST['kaisyamei'])){$kaisyamei=$_POST['kaisyamei'];
$data=array_merge($data,array("kaisyamei"=>"$kaisyamei"));
// print_r($data);
}
if(!empty($_POST['tantousya'])){$tantousya=$_POST['tantousya'];
$data=array_merge($data,array("tantousya"=>"$tantousya"));
}
if(!empty($_POST['hinmei'])){$hinmei=$_POST['hinmei'];
$data=array_merge($data,array("hinmei"=>"$hinmei"));
}
if(!empty($_POST['sinaban'])){$sinaban=$_POST['sinaban'];
$data=array_merge($data,array("sinaban"=>"$sinaban"));

}
if(!empty($_POST['zyutyuugappi'])){$zyutyuugappi=$_POST['zyutyuugappi'];
$data=array_merge($data,array("zyutyuugappi"=>"$zyutyuugappi"));

}
if(!empty($_POST['filename'])){$filename=$_POST['filename'];
$data=array_merge($data,array("filename"=>"$filename"));
}
if(!empty($_POST['bikou'])){$bikou=$_POST['bikou'];
$data=array_merge($data,array("bikou"=>"$bikou"));
}

//print_r($data);

$keyno01=$posno01=$keyno02=$posno02=NULL;

$current=reset($data);
$keyno01= key($data)."<br>";
$posno01= pos($data);

next($data); $keyno02= key($data)."<br>"; $posno02= pos($data);

print_r($data);

try{
$dbh = new PDO($dsn, $user, $password);

print('<br>'); if ($dbh == null){ print('接続に失敗しました。<br>'); }else{ // print('接続に成功しました。<br>'); } $dbh->query('SET NAMES utf8'); $sql="SELECT * FROM seihin_data WHERE :a=:b and :c=:d"; $stmt=$dbh->prepare($sql);

ここに:a,:b,:c,:dを取得するコードを書きたい!

$stmt->execute();

//

while($result = $stmt->fetch(PDO::FETCH_ASSOC)){ print $result['indexno']; print $result['kaisyamei']; print $result['tantousya']; print $result['hinmei']; print $result['sinaban']; }

}
catch (PDOException $e){
print('Error:'.$e->getMessage());
die();
}

?>

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

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

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

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

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

guest

回答1

0

ベストアンサー

端的に文字列を連結すればできますが、アスタリスクで全て取得して、取得した連想配列から任意個の任意のカラムを取得してはどうでしょうか?

投稿2019/04/06 14:21

papinianus

総合スコア12705

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

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

tukino-hikari

2019/04/06 19:13

ありがとうございます!かなりのヒントになりました。出来るかどうかは分かりませんが、脳ミソフル回転で頑張ってみます!もし、一週間頑張っても出来なかった場合は、再度質問してもよろしいでしょうか^^?。
tukino-hikari

2019/04/06 20:51

思ったより、あっさりできました!ヒントがあったおかげです!!感謝、感謝です。ありがとうございました。コードは全面的に書き換えました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問