電車の時刻表を表示させるプログラムの構成を考えています。
関係データベースは各路線ごと上下4つ作って
レコード構成は電車番号、休日の状況、電車の種類(行き先)、××線と○○線を跨ぐか、駅の発車時刻(駅ごとに列)にしたいと思っています。
そして、各線ごとの2つの表にSelect文で駅名と発車時刻と行き先を表示して、
各駅の発車時刻の項目がnullの場合と別の表にない場合、駅名と発車時間を非表示にしたりしたいのですがWHERE文が分からなくなりました。
上記の場合どのようにすればいいのか助言していただけませんでしょうか。
末文になりますが、乱文になってしまい申し訳ありません。
No.1ベストアンサー
- 回答日時:
以下を補足説明してくれなければ、誰も適切なアドバイスはできないと思います。
(1)表と表の構成列
(2)格納データ例
(3)得たい結果例
(4)MySQLのバージョン
(2)と(3)は、得たいデータ、得たくないデータが、他人が見て分かるように示してください。
この回答への補足
分かり難い書き方をしてすみません。下記に私なりですが書かせていただきます。
また、不明な点や分かり難い点は失礼ながら回答していただけると嬉しいです。
表:下記の運行表が本線・支線の上下4つ、目的地の表、
表の構成:
運行表
発車番号 休日状況 電車の種類 ×線と○線を跨ぐか △駅発車時刻 □駅発車時刻 ……
T999 休日運休 特急 跨がない 8:00 null
A002 休日運行 快速 跨ぐ 8:10 8:15
目的地の表
H=博多、N=長崎、SG=佐賀、SS=佐世保、K=久留米
得たい結果:
駅ごとの発車時刻(射影)、列車を選択して停車駅を表示(上記運行表を参考に)
MYSQLのバージョン:おそらくですが4.2.0だと思います。
No.3
- 回答日時:
「MySQLのバージョンを明確にできない」
「やりたいことを具体的に説明できない」
では、回答のしようがないし、具体的なアドバイスができません。
>なにぶんデータベースを作成するのが初めてなもので~ご回答お待ちしております
待たないで、ace_getさんが主体的に調べたり、試行錯誤してください。
ここは、「仕様を提示して作ってもらう」というサイトでなく、「自分なりに考えて分からない点を、具体的に示して質問する」というサイトです。
>>各駅の発車時刻が範囲内か、あるいはnullかといった判定を、その全列に対して指定するのですか?
>はいそういった構成でいこうと思います。
正規化について、調べてみてください。
ace_getさんが考えている仕様がイマイチ具体的でないですが、例えば、私がテーブル設計するなら、次のようにすると思います。
駅テーブル(駅id、駅名)
電車テーブル(電車id、電車名)
発車時刻テーブル(電車id、駅id、発車時刻)
質問のタイトルと質問内容が合わなくなっているし、質問日時も古くなってきていますよね?
しかも、補足説明も、具体的になっていないので、他の人もアドバイスしにくいと思います。一旦、この質問は締めて、テーブル設計方法から質問してみてはいかがでしょうか?
No.2
- 回答日時:
補足説明をしてもらいましたが、内容がかなり曖昧ですが?
>MYSQLのバージョン:おそらくですが4.2.0だと思います
MySQL 4.2って、聞いたことがないのですが?
MySQL 4.0以前では、サブクエリが使えないといった制限があります。
MySQL 5.0以降なら、ストアドプロシジャを使えるようになっています。
操作性が大きく違ってくるので、バージョンは明確にしてください。
SQLが入力できる状態で、「select version()」と入力することで確認できます。
>発車番号 休日状況 電車の種類 ×線と○線を跨ぐか △駅発車時刻 □駅発車時刻 ……
駅が10個あれば列を10個、100個あれば列を100個作ろうと考えているのですか?
各駅の発車時刻が範囲内か、あるいはnullかといった判定を、その全列に対して指定するのですか?
駅の管理表、列車の管理表、その2表と関連付ける運行時刻表というように分割することを考えてみては?
この回答への補足
chukenkenkouさんの仰るとおりです。
>各駅の発車時刻が範囲内か、あるいはnullかといった判定を、その全列に対して指定するのですか?
はいそういった構成でいこうと思います。
chukenkenkouさんのご提案を私の想像ですがまとめてみました。
発車番号(列車番号でした)をキーにして、
駅の管理表(駅名だけですか?)列車の管理表、運行時刻表を作成、副問合わせを行い出力する。
といった感じでしょうか?
なにぶんデータベースを作成するのが初めてなもので失礼とは思いますがご回答お待ちしております。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- 電車・路線・地下鉄 国鉄東海道線、快速の各停区間での種別案内変更はいつから? 4 2022/04/19 09:12
- 電車・路線・地下鉄 品川駅の接続について 1 2022/05/14 10:50
- 電車・路線・地下鉄 江ノ島駅について この前電車を待ってた時に江ノ島電鉄江ノ島駅の留置線を見ました 鎌倉方面のホームに行 1 2023/07/19 18:01
- 電車・路線・地下鉄 東横線と田園都市線 帰宅ラッシュの激しいのはどっち!? 5 2023/05/05 12:04
- 派遣社員・契約社員 派遣バイトの待ち合わせ、合流について 初めての派遣バイトで待ち合わせについてよく分からなくてお聞きし 2 2023/02/08 23:25
- 電車・路線・地下鉄 緩急接続について 3 2022/08/15 11:38
- 新幹線 気象や事故などの影響で爆延の新幹線深夜到着 8 2023/08/17 05:27
- 電車・路線・地下鉄 京王線・千歳烏山から本八幡迄 5 2022/04/21 09:32
- 電車・路線・地下鉄 新潟駅から高田駅まで電車を使っていく場合は、どの電車に乗れば行けますか? そっち方面に電車で行ったこ 6 2022/04/05 11:50
- 電車・路線・地下鉄 時間調整について 3 2022/07/26 18:47
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
副問合せの書き方について
-
SQL Left Join で重複を排除す...
-
inner joinをすると数がおかし...
-
updateを1行ずつ実行したい。
-
テーブル名を省略して「h.id」...
-
ID毎に最新の値を取得する
-
MySQLのint型で001と表示する方...
-
Unionした最後にGROUP BYを追加...
-
SQLサーバから、項目の属性(型...
-
ギターのコードが分からない
-
カラム名でseqとidではどちらが...
-
テーブルが5つの時の結合の仕...
-
VIEWの元のテーブルのindexって...
-
PL/SQLの変数について
-
差集合について
-
ある条件の最大値+1を初番する...
-
1テーブル&複数レコードの更新...
-
上位3位を求めるSQL文は?
-
group by 関数で表示するカラム...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQL Left Join で重複を排除す...
-
副問合せの書き方について
-
SQLサーバから、項目の属性(型...
-
VIEWの元のテーブルのindexって...
-
select文のwhere句に配列を入れ...
-
selectした大量データをinsert...
-
センノシド異性体構造式
-
Unionした最後にGROUP BYを追加...
-
insertを高速化させたい
-
SQLにて特定の文字を除いた検索...
-
マイクラPC版のコマンドで効率...
-
ある条件の最大値+1を初番する...
-
inner joinをすると数がおかし...
-
sqlで、600行あるテーブルを100...
-
エクセルの関数について教えて...
-
Access パラメータクエリをcsv...
-
URL と行番号の指定
-
複数テーブルのGROUP BY の使い...
-
PL/SQLの変数について
おすすめ情報