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

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

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

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

SQL

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

Q&A

解決済

4回答

20845閲覧

date型の日付のみ取得したい

pro-poke5

総合スコア46

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

SQL

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

0グッド

0クリップ

投稿2017/06/09 07:33

こんばんわ

VS2010
DBはpostgres
でかいています
SQlについての質問です

DBの中身はこのようになっています。
イメージ説明

sql

1SELECT sum_date as T_DATE ,user_cnt as M_NO 2FROM t_sumlist 3WHERE sum_date >= '2015-10-01' ;

これを出力しT_DATE、M_NOをc# 、.aspx 上で表示させると
sum_dateが

2015-10-01 0:00:00

と、時刻まで表示されてしまいます
これを日付だけ表示させるにはSQLをどのようにすればいいでしょうか?

アドバイスおねがいいたします。

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

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

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

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

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

guest

回答4

0

SQLの実行結果はDateTime型で受け取っているのでしょうか?
そうではなく文字列で受けるのであれば、他の方の回答を参考にSQL上で変換すればOKだと思います。

そうでないのであれば表示させる側でフォーマットを指定するとか。

ちなみに、C#でyyyy/MM/ddの文字列に変換する場合は↓のようなものもあります。私はよく使います。
DateTime.ToShortDateString メソッド ()

投稿2017/06/09 22:11

編集2017/06/09 22:13
suzu_cat

総合スコア81

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

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

0

ASP.NET では普通はフォーマッティングは SELECT クエリを細工して対処するのではなく、SELECT クエリには一切細工せず質問者さんが質問に書いたクエリのようにストレートに取得して、プロバイダで DateTime 型にして ASP.NET に渡します。そして ASP.NET 側で必要な形にフォーマッティングします。

PostgreSQL + Npgsql でどのようにできるか分かりませんが、もし、ASP.NET 側に DataTime 型で渡せるなら(.NET 用のプロバイダなら普通にできると思いますが)、同様にしてはいかがですか?

投稿2017/06/09 08:23

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

ベストアンサー

dateフォーマットを使います。
PostgreSQL/日付部分のみ取得しYYYYMMDDで取り出す方法

SQL

1SELECT 2to_char(sum_date,'YYYY-MM-DD') as T_DATE,user_cnt as M_NO 3FROM t_sumlist 4WHERE sum_date >= '2015-10-01' ; 5

投稿2017/06/09 07:40

編集2017/06/09 07:45
m.ts10806

総合スコア80850

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

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

0

CONVERT(VARCHAR(10), sum_date, 111) AS T_DATE

で、どうでしょうか。

投稿2017/06/09 07:38

yamashita166

総合スコア25

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問