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

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

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

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Q&A

0回答

552閲覧

VBAでMySQLに接続しTime型データの時刻のみを取得したい

taka45

総合スコア0

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

0グッド

1クリップ

投稿2020/11/01 11:48

前提・実現したいこと

VBAにてデータベース(MySQL8.0)に接続し、テーブルの値を取得しております。
以下のようなテーブルからTime型データを取得しようとすると、
VBA側では「2020/11/1 9:05:00」のように日付が追加されてしまいます。
時刻のみを取得する方法があれば教えていただきたいです。

+--------------+----------+
| Date | Time |
+--------------+----------+
| 2011-06-30 | 09:05:00 |
+--------------+----------+

該当のソースコード

VBA

1 Const MYDRIVER = "Driver={MySQL ODBC 8.0 Unicode Driver};" 'ドライバー 2 Const MYSERVER = "Server=localhost;" 'サーバー 3 Const MYPORT = "Port=3306;" 'ポート 4 Const MYDATABASE = "Database=testdb;" 'データベース名 5 Const MYCCODE = "STMT=SET NAMES sjis;" '文字コード(Excel側) 6 Const MYUSER = "UID=test;" 'ユーザー名 7 Const MYPASS = "PWD=;" 'パスワード 8 9 Dim cn As New ADODB.Connection 10 Dim rs As New ADODB.Recordset 11 Dim constr As String 12 Dim strSQL As String 13 Dim i As Long 14 Dim j As Long 15 16 constr = MYDRIVER & MYSERVER & MYPORT & MYDATABASE & MYCCODE & MYUSER & MYPASS 17 18 cn.ConnectionString = constr 19 cn.Open 20 21 strSQL = "select * from testdb.tbl1315;" 22 rs.Source = strSQL 23 rs.ActiveConnection = cn 24 rs.Open 25 26 Dim ws As Worksheet 27 Set ws = Worksheets("test") 28 29 i = 1 30 Do Until rs.EOF 31 32 For j = 0 To rs.Fields.Count - 1 33 ws.Cells(1 + i, 1 + j) = rs(j).Value 34 Next j 35 36 rs.MoveNext 37 i = i + 1 38 Loop

その他

現状、TimeValue(rs(j).Value)のようにして時刻データを取得しておりますが、
できれば、そのまま値を取得したいと考えております。

また、Date型の値は時刻が追加されずにそのまま取得することができております。

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2020/11/02 00:44

> 現状、TimeValue(rs(j).Value)のようにして時刻データを取得しておりますが、 > できれば、そのまま値を取得したいと考えております。 いまいちどういう回答を期待しているのかが見えないのですが、 TimeValueで取得出来ているのであれば問題ないのでは?
taka45

2020/11/02 05:45

「2020/11/1 9:05:00」のような形ではなく、 そのまま「9:05:00」という形でデータベースから データを取得できればと考えています。 TimeValueで取得できてはいるのですが、 これから作るテーブルのことを考えると、TimeValueを使わずに 値を取得できた方が良いな思いまして質問させていただきました。 どうしてこのような現象が起きるのか、 どのようにすれば時刻のデータのみを取得できるのか、 教えていただければと思います。
退会済みユーザー

退会済みユーザー

2020/11/02 06:06 編集

Time型カラムのField.Typeを取得するとadDBTimeが返ってはきているので、内部的には恐らく時刻データとしてODBCから渡されてきているとは思われますが、Value取得時点でADOが勝手に変換しているとしたら、結局TimeValueせざるを得ないのかもしれません。ODBCのAPIを直弄りすればひょっとしたら取得出来るかもしれませんが、逆に面倒そうです。
taka45

2020/11/02 07:19

ご回答ありがとうございます! > 結局TimeValueせざるを得ないのかもしれません。 > ODBCのAPIを直弄りすればひょっとしたら取得出来るかもしれませんが、逆に面倒そうです。 ODBCのAPIを弄るというのは私にはできないので、 TimeValueを使うか、データベース側を変えるか、考えてみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問