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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。

Q&A

解決済

2回答

3783閲覧

PHPとMySQLを使った不動産物件検索システムで、建物が同じ場合はその下にまとめて部屋情報が表示されるようにしたい

morie

総合スコア29

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。

0グッド

2クリップ

投稿2016/04/27 10:50

よくある不動産物件検索サイトで、建物が同じ場合には、その1つの建物の中に家賃や階数などの部屋情報をまとめて表示するための方法が分からなくて困っています。

家賃や間取りなどの検索条件を指定し、それらをSQL文として実行した値を変数に入れ、いろいろ試してみたのですが思うような結果が得られません。。

DBはMYSQLを使っており、行には、ID番号や建物名、家賃や専有面積など、既にたくさんのデータが入っています。

イメージ説明

やりたい事は、例えばPHPのwhile文やforeach文などでのループの中で、建物名が同じであれば、建物の表示に関しては1度だけに限り出力し、あとは家賃や階数などの部屋情報に限ってまとめて出力したいです。SQL文やPHPで、どのような工夫をすべきでしょうか?

イメージ説明

現在運営している不動産物件サイトの表示の仕方を上記のようにしたいのですが、何かヒントになるような助言が頂ければ幸いです。よろしくお願いいたします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

検索時にマンション名で部屋の情報を名寄せするのはナンセンスです。
格納時にマンションの情報と部屋の情報を分けてあらかじめ名寄せしておき、1対多(部屋情報)の関係で設計したほうが無駄がないと思います。

似たようなシステムのDB設計をしたことがありますが、やはり
建物の情報(マンション名とか住所)と部屋の情報(部屋番号とか広さとか)を分けてテーブルを作り、部屋情報のほうに建物のIDを付けて管理していました。

ある特定のマンションの部屋の一覧をだしたいということなら、まず建物のIDをキーにして部屋の情報テーブルを検索すれば一覧を出せますよね?

また、面積がxxm2以上の登録があるマンションをすべて出したい、
というような場合には、2つのテーブルをJOINして検索すればよいでしょう。

投稿2016/04/27 14:29

CodeLab

総合スコア1939

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

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

morie

2016/04/28 10:38

部屋テーブルの建物IDを、建物テーブルに紐づけるためにはどのようにすればよいのでしょうか。また、どこまでをSQL文で取得して、どこからをPHPで処理すべきか、悩んでいます。。
guest

0

sql

1CREATE TABLE `Building` ( 2 `id` int(11) unsigned NOT NULL AUTO_INCREMENT, 3 `buildingName` varchar(255) DEFAULT NULL, 4 PRIMARY KEY (`id`) 5) ENGINE=InnoDB;

sql

1CREATE TABLE `Room` ( 2 `id` int(11) unsigned NOT NULL AUTO_INCREMENT, 3 `buildingId` int(11) DEFAULT NULL, 4 `roomName` varchar(64) DEFAULT NULL, 5 PRIMARY KEY (`id`) 6) ENGINE=InnoDB;

こんなかんじで。

投稿2016/04/27 10:57

編集2016/04/27 11:00
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

KiyoshiMotoki

2016/04/27 11:02

BuildingテーブルとRoomテーブルの紐付けが抜けていませんか?
morie

2016/04/27 13:29

既存のテーブルの他に、BuildingテーブルとRoomテーブルを作った方がよいでしょうか?またそれらをどのように関連させればよいでしょうか。
退会済みユーザー

退会済みユーザー

2016/04/27 13:57

既存のテーブルの代わりに、です。
KiyoshiMotoki

2016/04/28 00:58

コメント入力中に修正されたようですねw 失礼しました。
morie

2016/04/28 10:40

紐付けのために、`Building`テーブルの方にも、`buildingId`が必要になりますか?
退会済みユーザー

退会済みユーザー

2016/04/30 06:20

> 紐付けのために、`Building`テーブルの方にも、`buildingId`が必要になりますか? なんで?必要ないでしょ。
morie

2016/05/01 11:47

両方のテーブルに共通のカラム名があるからこそ、紐付けできるのではないでしょうか。
退会済みユーザー

退会済みユーザー

2016/05/01 11:48

提示した分で十分です
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問