
No.3ベストアンサー
- 回答日時:
モジュールを作成し、その中に関数を作成します。
Function myMax(ParamArray a())
Dim i
myMax = -9999
For i = 0 To UBound(a())
If a(i) > myMax Then myMax = a(i)
Next
End Function
で、クエリに
最高点: myMax([n01],[n02],[n03])
というふうに関数を使えます。SQLでは
SELECT t8.name, t8.n01, t8.n02, t8.n03, myMax([n01],[n02],[n03]) AS 最高点 FROM t8;
となります。
頑張ってくださいヽ(^。^)ノ
回答くださり、ありがとうございます。
がんばってみました!
・・・と言っても、まったく意味も分からず、snoopy64さんの書き込みをただコピー&ペーストしただけなんですが。
大成功でした。どうもありがとうございます。助かりました!
No.2
- 回答日時:
選択クエリのフィールド名に
最大値:IIf([1回目の得点]>=[2回目の得点],IIf([1回目の得点]>[3回目の得点],[1回目の得点],[3回目の得点]),IIf([2回目の得点]>=[3回目の得点],[2回目の得点],[3回目の得点]))
で可能です。
また、#1の方もおっしゃっていますが、得点のフィールドが今後も増えていくことが予想されるなら、テーブルの設計を見直したほうが良いかもしれません。
そうしないと、フィールドが増えるたびにクエリを作り直さないといけなくなりますから。
ただ、個人の得点は絶対に3回までというのであればこのままでも問題ないとは思います。
回答くださり、ありがとうございました。
いままで、IIfという関数は使ったことがなかったので、勉強になります。
レコードは大量に増えるのですが、フィールドは増えていかないので、一度設定すれば大丈夫そう!
別の目的でテーブル設計されたものを利用しようとするのは、ほんと私の知識では手に負えません。どうもありがとうございました。
No.1
- 回答日時:
UNIONクエリを使用すれば可能です (下記を参照)
SELECT qry01.名前, Max(qry01.得点) AS 得点の最大
FROM [SELECT 各人の成績表.名前, 各人の成績表.1回目の得点 AS 得点
FROM 各人の成績表
UNION
SELECT 各人の成績表.名前, 各人の成績表.2回目の得点 AS 得点
FROM 各人の成績表
UNION
SELECT 各人の成績表.名前, 各人の成績表.3回目の得点 AS 得点
FROM 各人の成績表
UNION
SELECT 各人の成績表.名前, 各人の成績表.4回目の得点 AS 得点
FROM 各人の成績表
UNION SELECT 各人の成績表.名前, 各人の成績表.5回目の得点 AS 得点
FROM 各人の成績表
ORDER BY 名前, 得点]. AS qry01
GROUP BY qry01.名前
ORDER BY qry01.名前
しかし、現状のテーブルは話にならないほどひどい設計と言えます。
SQLが複雑化するのも偏に設計が悪いからです。
具体的にどうするか、ですが、下記の解説を一読されるとよいでしょう。
[テーブルの正規化]
www8.pekori.to/~zoma/kanki_t.html
さっそくにお手数おかけしました。
回答ありがとうございます。
設計につきましては、現実にはもっとたくさんのフィールドがあり、毎月毎月レコードが万単位で作製されているデーターベースのため、本当に必要な部分だけ、例としてだしました。申し訳ございません。
テーブルの設計の見直しは、本筋の業務から無理なのです。ごめんなさい。アドバイスありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
ACCESSにてフィールド間の最小値を表示するためのモジュール
その他(データベース)
-
ACCESSのMax(Min)関数使用方法
Access(アクセス)
-
ACCESS クエリで重複データを最新の1件だけ表示
Access(アクセス)
-
-
4
あるフィールドの最大値を条件にデータを抽出する方法
その他(データベース)
-
5
Accessのクエリでフィールドの一番大きな数字を抽出させるには?
その他(データベース)
-
6
2つのテーブルに共通するレコードを削除したい
Access(アクセス)
-
7
アクセスで#エラーを表示させない方法は?
Access(アクセス)
-
8
ACCESSで空白のデーターをクエリで判定/識別する方法を教えてくださ
Access(アクセス)
-
9
【Access】Dcount関数の複数条件で順位を付ける方法について
Access(アクセス)
-
10
サブフォームに対してGoToRecordするには?
その他(Microsoft Office)
-
11
Accessのクエリで、replace関数を使い、データの中にある”をブランクに置き換えたいのですが
Access(アクセス)
-
12
角丸四角形を描きたい
Excel(エクセル)
-
13
Accessのマクロでモジュールを実行させたい。
Access(アクセス)
-
14
[Access]帳票フォームにて連続する非連結コントロールに個々の値を入れるには
Access(アクセス)
-
15
Accessのフォーム上にレコード数とレコード番号の表示
その他(データベース)
-
16
falseとtrue 0,1,-1 の意味が知りたいです
PowerPoint(パワーポイント)
-
17
Access 同じデータをたくさんのレコード(同一列)に一度に入力するには
Access(アクセス)
-
18
ACCESSのクエリで集計で、先頭・最後とは?
その他(データベース)
-
19
Access VBAで int型にnullを入れる方法について
Windows Vista・XP
-
20
Accessのクエリーのゼロデータ行の非表示の仕方
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
同級生で抜くってやばいですか?
-
高成績と好成績の違い
-
「功績をあげる」の「あげる」...
-
学年末テストで1桁(8点)とった...
-
伸びるの反対は、縮む?
-
Aマイナス評価とは
-
Access 各レコードの中での最大...
-
アヒル
-
イギリスの大学院での成績につ...
-
慶応のGPA
-
彼女が成績悪かって落ち込んで...
-
教育実習の評価と教員採用試験
-
旧日本海軍のエースパイロット...
-
エクセル 特定の範囲を使用し...
-
英文の成績証明書の最後の方に...
-
どうやったら成績をあげられま...
-
最終学歴の卒業証明書及び成績...
-
正規留学生の就職活動
-
ハーバード・ビジネス・スクー...
-
エクセル 成績順に並べ変えたい
おすすめ情報