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

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

ただいまの
回答率

90.46%

  • SQL

    2475questions

    SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

  • Oracle Database 11g

    197questions

    Oracle DatabaseはRDBMSの商品です。具体的な発売商品として知られているのが、 Oracle9i、Oracle10g、Oracle 11gとOracle 12cです。

SQL PLUSの質問です。

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 919

anna10

score 41

データーベースはoracle11gを使用しています。

company_table

code | company
001  | ジオニック社
002  | ツィマッド社
003  | アナハイム社

code:コード
company:社名

day_table

code | day
001  | 1993/3/5
002  | 1932/2/15
003  | 1986/5/23

code:コード
day:設立日

どちらのテーブルもPrimary Keyはcodeです。

この2つのテーブルから、「現在月(今は2月)の会社と設立日、設立何年目か」を取り出したいです。
イメージとしては現在は2月ですので、上記の表で行けば、

ツィマッド社 | 1932/2/15 | 83

としたい所です。

select company,day,
  trunc(months_between(sysdate,day)/12+0.999)
    from company_table,day_table
      where company_table.code=day_table.code
/

これで一応値を取得する事は出来るのですが、全ての会社と設立日、2015年までの設立年数が取得されてしまいます。
現在の月だけ、という条件を付与して値を取り出す方法を教えて頂けないでしょうか。
よろしくお願い致します。
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

0

抽出条件に以下の条件を加えてはどうでしょうか。
extract(month from day_table.day) = extract(month from sysdate)

具体的には、元のSQLに条件を加えます。
select company,day, 
  trunc(months_between(sysdate,day)/12+0.999) 
    from company_table,day_table 
      where company_table.code=day_table.code 
      and extract(month from day_table.day) = extract(month from sysdate)

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2015/02/18 21:30

    回答誠にありがとう御座います。参考させて頂いたのですが、=の部分でエラーが表示されてしまいます。あつかましいお願いなのですが、使用例などを教えて頂けないでしょうか?

    キャンセル

  • 2015/02/19 09:13

    実際のSQLを追記しました。

    キャンセル

  • 2015/02/19 18:37

    何度も投稿して頂き申し訳ありません。大変助かりました。ありがとう御座いました。

    キャンセル

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

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

関連した質問

  • 解決済

    Ruby ハッシュから配列に変更したい

    Ruby初心者です。 ハッシュから配列にしたいのですが、何か方法はありますでしょうか? どなたか教えていただけませんでしょうか? サンプルプログラムも書いていただけるとありがた

  • 解決済

    Ruby 二次元配列/ハッシュについて

    こんにちは。初めて質問させて頂きます。プログラミング初心者です。 Rubyの二次元配列/ハッシュ(どちらなのか定かではない)について質問です。 例えば、 ary = {"A" 

  • 解決済

    Ruby 配列について

    A配列の1部をB配列に入れたのですが、なかなかうまくいきません。 どうすればいいですか? A配列date ID,NAME,OLD,ADDRESS, 001,ピーター,38,NY 0

  • 解決済

    次の次の…の値をかえすには?

    以下の irb(main):002:0 で行なっていることを簡単にできないでしょうか? irb(main):001:0> i = 100 => 100 irb(main):002

  • 解決済

    初歩的な事か思いますがjavascriptで困ってます。初心者です。

    前提・実現したいこと javascript初心者です。 勉強の為に以下のようjsを作っています。 javascriptを使って、 ulタグの中のliタグの中にあるa要素

  • 解決済

    ssh-lastlogに残っていた接続履歴について

    お世話になります。 sshのログについて質問させてください。 さくらVPSを使用しております、rootでログイン後、 コマンドで、#lastlogと入力すると、 各ユーザの最終ログ

  • 解決済

    javascriptの配列代入の表記方法

     質問内容 ユーザーの「ID」「氏名」が入った二次元配列に対して、IDが重複していたら重複を削除する(後ろに入っているレコードを残す)というプログラムがあるのですが、 表記方法が見

  • 解決済

    ubuntuのdockerコンテナでpythonから録音したい

     前提・実現したいこと Dockerでコンテナ内でpythonから録音・再生をしたい(pyaudio使用)  発生している問題・エラーメッセージ root@418e4d6433

同じタグがついた質問を見る

  • SQL

    2475questions

    SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

  • Oracle Database 11g

    197questions

    Oracle DatabaseはRDBMSの商品です。具体的な発売商品として知られているのが、 Oracle9i、Oracle10g、Oracle 11gとOracle 12cです。