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

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

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

MySQLiはPHP5より導入されているデータベース用のドライバです。MySQL 4.1.3以降の新しい機能の利点をまとめています。

PHP

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

Q&A

解決済

2回答

987閲覧

MySQLのOUTER JOINで絞り込んだ結果をPHPで画面に表示させたい

terapro

総合スコア39

mysqli

MySQLiはPHP5より導入されているデータベース用のドライバです。MySQL 4.1.3以降の新しい機能の利点をまとめています。

PHP

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

0グッド

0クリップ

投稿2019/05/03 05:21

編集2019/05/03 06:07

joblistテーブルとskipテーブルがあります。

joblistテーブルは応募者のデータが格納されており、
skipテーブルはuser(企業番号)ごとに不採用者のデータが格納されています。

joblist.jobは求人番号です。
joblist.awuserとskip.awuserは重複している番号があります。
求人番号ごとに、skipテーブルに存在しないawuserの一覧を表示させたいです。

PHPでMySQLには手続き型で接続します。
(オブジェクト指向は使いません)

MySQL

1CREATE TABLE `aw`.`joblist` ( 2 `id` INT(255) NOT NULL AUTO_INCREMENT , 3 `job` INT(255) NOT NULL , 4 `awuser` INT(255) NOT NULL , 5 `date` DATETIME NOT NULL , 6 PRIMARY KEY (`id`) 7) ENGINE = InnoDB; 8 9CREATE TABLE `aw`.`skip` ( 10 `id` INT(255) NOT NULL AUTO_INCREMENT , 11 `user` VARCHAR(255) NOT NULL , 12 `awuser` INT(255) NOT NULL , 13 PRIMARY KEY (`id`)) ENGINE = InnoDB;

そこで、上記の条件を満たす、以下を作成しました。

PHP

1 2$user = 1; 3$array = [3533346 ,3562611]; 4 5$connection = mysqli_connect('localhost', 'root', '', 'aw'); 6 7$query = "SELECT * FROM joblist LEFT OUTER JOIN skip ON (joblist.awuser = skip.awuser) WHERE (user != '$user' OR user IS null) AND job IN ('implode(",", "$array")')"; 8 9$select_job_query = mysqli_query($connection, $query); 10while($row = mysqli_fetch_array($select_job_query)) { 11 echo $myApplicant = $row['awuser']; 12}

実行すると
Parse error: syntax error, unexpected ','
が$queryの行に出ます。

惜しいところまできているはずなのですが、
awuserを画面に出力する方法で間違っている箇所をご指摘いただければ幸いです。
よろしくお願いいたします。

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

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

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

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

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

guest

回答2

0

SQLインジェクション脆弱性になり得るので,文字列のはめ込みはプレースホルダで。

php

1<?php 2 3$user = 'user'; 4$array = ['foo', 'bar', 'baz']; 5 6$query = sprintf( 7 ' 8 select * from 9 left join skip on joblist.awuser = skip.awuser 10 where (user != ? or user is null) and job in (%s) 11 ', 12 implode(', ', array_fill_keys(array_keys($array), '?')) 13); 14 15$stmt = mysqli_prepare($connection, $query); 16mysqli_stmt_bind_param($stmt, 's' . str_repeat('s', count($array)), $user, ...$array); 17mysqli_stmt_execute($stmt); 18$result = mysqli_stmt_get_result($stmt); 19 20while ($row = mysqli_fetch_array($result)) { 21 /* ... */ 22}

どちらかと言うとオブジェクト指向型のほうがおすすめです。手続き型は関数名が長すぎてうんざり…

php

1<?php 2 3$user = 'user'; 4$array = ['foo', 'bar', 'baz']; 5 6$query = sprintf( 7 ' 8 select * from 9 left join skip on joblist.awuser = skip.awuser 10 where (user != ? or user is null) and job in (%s) 11 ', 12 implode(', ', array_fill_keys(array_keys($array), '?')) 13); 14 15$stmt = $connection->prepare($query); 16$stmt->bind_param('s' . str_repeat('s', count($array)), $user, ...$array); 17$stmt->execute(); 18$result = $stmt->get_result(); 19 20while ($row = $result->fetch_array()) { 21 /* ... */ 22}

投稿2019/05/03 06:55

編集2019/05/03 07:00
mpyw

総合スコア5223

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

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

退会済みユーザー

退会済みユーザー

2019/05/03 07:33

すんません、横着してしまいました
terapro

2019/05/04 11:42

ご回答ありがとうございます。 本来はこちらの書き方が完成形なのだと思いますが、現状xamppで自分だけが利用している状況ですのでSQLインジェクション対策は考えずに平文で作りました。プレースホルダやオブジェクト指向の考え方は現在の私にはまだ難しく私のレベルでは思ったように再現ができませんでした。今後の学習課題とさせていただきます。 ようやく調べながらコードが書いて動かせるようになったレベルですが、次は他の人にも使ってもらえるようなアプリの制作を目指してこれからも勉強頑張ります。
guest

0

ベストアンサー

php

1<?php 2$user = 'user'; 3$array = ['foo', 'bar', 'baz']; 4 5array_walk($array, function (&$val) { 6 $val = "'" . $val . "'"; 7}); 8$query = "SELECT * FROM joblist LEFT OUTER JOIN skip ON (joblist.awuser = skip.awuser) WHERE (user != '$user' OR user IS null) AND job IN (" . implode(", ", $array) . ")"; 9echo $query;

結果

SELECT * FROM joblist LEFT OUTER JOIN skip ON (joblist.awuser = skip.awuser) WHERE (user != 'user' OR user IS null) AND job IN ('foo', 'bar', 'baz')

投稿2019/05/03 06:09

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

terapro

2019/05/04 11:35

無事動きました。私の質問に対して真っ直ぐに回答いただき、誠にありがとうございました。 現状ギリギリ理解できる範疇でした。本当にありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問