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

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

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

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

Visual Studio 2010

Microsoft Visual Studio 2010はMicrosoftが提供している統合開発環境(IDE)です。

ASP.NET

ASP.NETは動的なWebサイトやWebアプリケーション、そしてWebサービスを構築出来るようにする為、Microsoftによって開発されたウェブアプリケーション開発フレームワークです。

Q&A

解決済

1回答

3588閲覧

SqlDataSourceで日付が最新のレコードを取得したいです

taketake221

総合スコア17

SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

Visual Studio 2010

Microsoft Visual Studio 2010はMicrosoftが提供している統合開発環境(IDE)です。

ASP.NET

ASP.NETは動的なWebサイトやWebアプリケーション、そしてWebサービスを構築出来るようにする為、Microsoftによって開発されたウェブアプリケーション開発フレームワークです。

0グッド

0クリップ

投稿2016/09/07 05:19

先日からたびたびこちらでお世話になっております。

以下のようなビュー(VW_testFacValue_view)があります。
イメージ説明

このビューについて、tbl_testFaciの内容+それぞれのFacilityIDの日付が最新のレコードを一覧表示(SqlDataSourceとGridViewを用いて)させるには、「データソースの構成」でSQL文をどのように記述調整すればよいのでしょうか。

具体的には、select * from VW_testFacValue_viewと記述すると、以下の結果となるところを、
イメージ説明

このように、それぞれのFacility_IDの日付が最新のレコードのみを一覧として表示させたいのです。

イメージ説明

それとも、ビューの形式でなく適切な別の方法があるのでしょうか。
初歩的な質問で申し訳ありませんが、ご指摘・ご回答お待ちしております。
どうぞよろしくお願いいたします。

それぞれのテーブル構成は以下のとおりです。
イメージ説明
イメージ説明

※Visual Stdio 2010、SQL server 2012を使用しています。

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

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

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

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

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

guest

回答1

0

ベストアンサー

「データソースの構成」内でどの程度複雑なクエリが書けるのかちと判断できないので動かない場合はご容赦を・・・。

一番捻りのないクエリでは以下のようなイメージになるでしょうか。

SQL

1SELECT 2 v.* 3FROM 4 VW_testFacValue_view v 5 INNER JOIN ( 6 SELECT 7 FacilityID 8 , MAX(date) AS max_date 9 FROM 10 tbl_valueTest 11 GROUP BY 12 FacilityID 13 ) t 14 ON v.FacilityID = t.FacilityID 15 AND v.date = t.max_date 16

投稿2016/09/07 12:57

Panzer_vor

総合スコア1636

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

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

taketake221

2016/09/07 21:42

前回の質問に引き続いてご回答をお寄せくださりまことにありがとうございます。 ご提示いただいたSQLソースを試してみたのですが、 SqlDataSourceの「データソースの構成」でも、 SQlserverでの試験実行でも、 「'(' 付近に不適切な構文があります。」というエラーメッセージが表示されました。 よろしければお気づきになった点などご指摘いただければ幸いです。
taketake221

2016/09/07 22:45

>「'(' 付近に不適切な構文があります。」というエラーメッセージが表示されました。 こちらの不手際です、申し訳ありません。いただいたコードを改編し、質問用のテストビューでなく実装中のプログラムで試しており、そちらには同日のデータが複数格納されていたため、エラーが生じていたようです。 VW_testFacValue_viewで試したところ、求める結果が正しく表示されました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問