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

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

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

Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。

SQL

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

Q&A

解決済

5回答

1162閲覧

SQLの曖昧な検索条件

yamaguti

総合スコア185

Oracle

Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。

SQL

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

0グッド

3クリップ

投稿2018/03/14 02:01

お世話になります。

できないとは思いますが質問させて頂きます。

SQLで商品が入っているテーブルがあるとします

商品名 金額 商品A 10000 商品B 10000 商品C 10000

こういったテーブルのなかから、2万円分を特に指定なしに抽出することはできるのでしょうか。

宜しくお願い致します。

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

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

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

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

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

guest

回答5

0

ベストアンサー

投稿2018/03/14 05:14

sazi

総合スコア25184

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

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

yambejp

2018/03/14 05:29

昔はCDアルバムの曲をカセットテープのAB面にどううまく 振り分けるか・・・とか命題でありましたよね いまの子供はカセットテープとかA面B面言っても イメージわかないでしょうけど
sazi

2018/03/14 05:35

そのさらに昔は、レコード自体がA面B面だったので、 その命題自体が存在しませんでしたけどねw
guest

0

基本的には総当たりで処理するしかないでしょう

sample

oracleとちょっと文法が違うかもしれませんが参考までに

  • 元データ

SQL

1create table tbl(id int unique,name varchar(10) unique,price int); 2insert into tbl values(1,null,0),(2,'A',10000),(3,'B',10000),(4,'C',10000);
  • 組み合わせ結果
select t1.name as name1 ,t2.name as name2 ,t3.name as name3 ,t1.price+t2.price+t3.price as sum from tbl as t1 left join tbl as t2 on t1.name!=t2.name and t1.id<t2.id or t2.name is null left join tbl as t3 on not t3.name in (t1.name,t2.name) and t1.id<t3.id and t2.id<t3.id or t3.name is null

投稿2018/03/14 03:05

編集2018/03/14 03:44
yambejp

総合スコア114814

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

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

0

参考情報

  • SQLで数学パズルを解く 部分和問題

http://www.geocities.jp/mickindex/database/db_puzzle_math_a_cmb.html#LocalLink-ssp_dec

投稿2018/03/14 22:44

katoy

総合スコア22324

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

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

0

2万以下でもいいのであれば
ランダムな並び順をつけてsum overし2万以下selectでいけそうなんですが。
その後不足分を埋めるとかで結局一筋縄ではいきませんね

投稿2018/03/14 03:28

sousuke

総合スコア3828

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

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

0

ある程度で業務でSQLは使っていますが、いい方法は思いつきません。。。
実現しようとするならPHPやRuby等のプログラミング言語と組み合わせるかたちになってしまいます。

投稿2018/03/14 02:35

編集2018/03/14 02:36
bassbone

総合スコア767

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問