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

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

ただいまの
回答率

91.35%

  • MySQL

    4387questions

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

  • Linux

    2696questions

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

  • CentOS

    2007questions

    CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

  • if

    126questions

    if文とは様々なプログラミング言語で使用される制御構文の一種であり、条件によって処理の流れを制御します。

mysqlのテーブルのカラム日付をshellで読み込み、日にちの計算をしたいです。

解決済

回答 2

投稿 2017/11/30 12:04

  • 評価
  • クリップ 0
  • VIEW 75

s_ayana

score 3

現在テーブルに

テーブル名:sample_user
user_id  password   cility_id  kensh_div   lock_flg       crt_datetime       mcuser_id   del_flg
1              NULL        NULL      NULL       NULL                NULL                NULL        NULL
2              NULL        NULL      NULL        1          2017-12-05 00:00:00   NULL        NULL    

とあります。

このcrt_datetimeの2017-12-05 00:00:00だけを変数に直して日にちを計算することは可能でしょうか?

ちなみに書いたshell

!/bin/sh

date_1=3

if [ date = crt_datetime-date_1 ]; then
content=mysql -h 192.168.*.* -u ***_user --password=**** --database=sample  -e "select * from sample_user where crt_datetime = '2017-12-05'2>&1
echo $content
echo "$content" | mail -s "Reminder" "exe@example.jp"
echo "sendmail"
fi

~

このif文のとこで, if [ 現在の日付(date) = crt_datetime(2017-12-05) 引く(-) date_1(3日)]
とやっているつもりなのですが、うまくいきません。
このif文の日付の比較と計算が分かる方よろしくお願いします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

0

crt_datetimeが定義されていないから?

#!/bin/sh

# 基準となる年月日
crt_datetime=20171205

# n日前を生成
period=5

date1=`date --date "$crt_datetime $period days ago" +%Y-%m-%d`

# 現在の年月日と生成した年月日が同じなら~
if [ `date +%Y-%m-%d` = $date1 ]; then
echo wwww
fi

パッと見た感じですが、3日後のデータが欲しいのであれば現在から3日後を作成してSQLを投げればokなのかなと、、

#!/bin/sh

# n日後を生成
period=5

after=`date --date "$period days" +%Y-%m-%d`

echo $after

投稿 2017/11/30 13:11

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/11/30 16:46

    crt_datetime定義されてないからでしたでした!
    ありがとうございます
    ちなみにshellで定義したcrt_datetimeを直接mysqlのフィールドの2017-12-05を代入することは可能か、お分かりになりますでしょうか?

    キャンセル

  • 2017/11/30 17:13

    SQLの【crt_datetime = '2017-12-05'】の検索条件に指定するということでしょうか?
    であれば
    crt_datetime = '2017-12-05'

    crt_datetime = '${crt_datetime }'でいけませんかね?

    尚、上記date1にはn日前を生成した結果が入っていますので、そちらを参照する場合は
    crt_datetime = '${date1 }'でいけると思います。

    キャンセル

  • 2017/11/30 17:54

    申し訳ありません。いけませんでした。SQLのテーブルデータがshellに読み込まれていないから、shellが(crt_datetimeなんて知らないよ!) と認識しているのでしょうか?
    それともSQLのcrt_datetimeの日付とshellのdatetime日付を連動させることは不可能で両方とも毎回変えた方がいいのでしょうか?

    キャンセル

0

期日のデータを取得する部分のみですがサンプルを作成してみました

date_1=3
date_3=`date -d"+${date_1} days" +%Y-%m-%d`

mysql -h localhost -u uhoge --password=phoge --database=dhoge -Nse "
 select * from sample_user where crt_datetime = '${date_3}'" | while read -a rc;
do
        echo ${rc[0]} ${rc[5]}
        # mail send 
done

*注 日付'2017-12-03 00:00:00'は${rc[5]}と${rc[6]} に分かれています。

投稿 2017/11/30 13:56

編集 2017/11/30 14:04

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

ただいまの回答率

91.35%

関連した質問

同じタグがついた質問を見る

  • MySQL

    4387questions

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

  • Linux

    2696questions

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

  • CentOS

    2007questions

    CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

  • if

    126questions

    if文とは様々なプログラミング言語で使用される制御構文の一種であり、条件によって処理の流れを制御します。