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

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

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

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

MySQL

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

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

Q&A

解決済

2回答

2914閲覧

毎日変わる日付のパス指定

s_ayana

総合スコア35

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

MySQL

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

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

0グッド

0クリップ

投稿2018/06/04 07:40

編集2018/06/04 08:36

現在CSVファイルをサーバーにアップされてからMYSQL5.7にインポートするバッチを書いているのですが、日付を指定する条件が分からずにいます。

具体的にはまずサーバーに/tmp/0620/file_20180619.csv
......................................./0619/file_20180618.csv

のようにファイルがアップされます。アップされたファイルで本日が6/20の場合、20日のフォルダ内にある「file_20180619.csv」(-1日)を読み込むバッチを書いているのですが、0620ディレクトリとcsvファイルの名前は毎日変わるので、変わっても対応できるpathの指定の仕方を教えてください。

バッチ処理

#データベース接続
mysql -hxxx -uxx -pxxxx

#データベース選択
use database;

#POSデータインポート
LOAD DATA LOCAL INFILE '/bk_uriage/tmp/DD(0620)/file_YYYMMDD.csv' FIELDS TERMINATED BY "," INTO TABLE table FIELDS TERMINATED BY ',';

上記の/DD(0620)/file_YYYMMDD.csvの部分は日付が変わるのでどんなふうにインポートするパスを指定すればよろしいでしょうか。

ご回答宜しくお願い致します。

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

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

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

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

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

guest

回答2

0

ベストアンサー

今日の日付MMDD ・・・・・ date +%m%d
昨日の日付YYYYMMDD ・・・ date +%Y%m%d -d '1 day ago'

Bash

1FILE=/bk_uriage/tmp/$(date +%m%d)/$(date +file_%Y%m%d.csv -d '1 day ago') 2 3mysql -hxxx -uxx -pxxxx <<EOF 4use database; 5LOAD DATA LOCAL INFILE '$FILE' ~~ 6EOF

投稿2018/06/04 11:53

otn

総合スコア84423

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

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

s_ayana

2018/06/05 00:55

いきました。ありがとうございます。
guest

0

winですよね?wsh(vbs)で日付をコントロールしてみてはどうでしょうか?

perl

perl

1/* 当日 */ 2my ($sec, $min, $hour, $mday, $mon, $year, $wday, $yday, $isdst) = localtime(tim 3e); 4printf("%04d%02d%02d", $year + 1900, $mon + 1, $mday); 5/* 前日 */ 6my ($sec, $min, $hour, $mday, $mon, $year, $wday, $yday, $isdst) = localtime(tim 7e - 24 * 3600 ); 8printf("%04d%02d%02d", $year + 1900, $mon + 1, $mday);

投稿2018/06/04 08:29

編集2018/06/04 09:31
yambejp

総合スコア114572

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

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

s_ayana

2018/06/04 08:35

すみません。aws上のlinuxです。
yambejp

2018/06/04 09:32

失礼しましたlinuxですね。やはりperlあたりがラクですかね
s_ayana

2018/06/05 00:55

ありがとうございます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問