sql >> データベース >  >> RDS >> MariaDB

MariaDBの日時値から秒を引く

    MariaDBの日時式から1秒以上を減算するためのいくつかのオプションを次に示します。

    SUBTIME() 機能

    SUBTIME() 時間または日時の値から指定された時間を減算します。

    例:

    SELECT SUBTIME('2021-05-01 10:00:00', '00:00:30');

    結果:

    +--------------------------------------------+
    | SUBTIME('2021-05-01 10:00:00', '00:00:30') |
    +--------------------------------------------+
    | 2021-05-01 09:59:30                        |
    +--------------------------------------------+

    時間、分など、他の時間単位を変更することもできます。

    DATE_SUB() 機能

    DATE_SUB() 関数を使用すると、日付または日時式から特定の数の日付/時刻単位を減算できます。したがって、この関数を使用して、特定の秒数を引いた日時の値を返すことができます。

    例:

    SELECT DATE_SUB('2021-05-01 10:00:00', INTERVAL 30 SECOND);

    結果:

    +-----------------------------------------------------+
    | DATE_SUB('2021-05-01 10:00:00', INTERVAL 30 SECOND) |
    +-----------------------------------------------------+
    | 2021-05-01 09:59:30                                 |
    +-----------------------------------------------------+

    SECONDに注意してください 1秒以上減算するかどうかに関係なく、キーワードは複数形のままです。

    日付と時刻の複合単位を使用することもできます。たとえば、数分と数秒をすべて一度に実行できます。

    例:

    SELECT DATE_SUB('2021-05-01 10:00:00', INTERVAL '15:30' MINUTE_SECOND);

    結果:

    +-----------------------------------------------------------------+
    | DATE_SUB('2021-05-01 10:00:00', INTERVAL '15:30' MINUTE_SECOND) |
    +-----------------------------------------------------------------+
    | 2021-05-01 09:44:30                                             |
    +-----------------------------------------------------------------+

    日付だけを渡す

    日付の値だけを指定すると、次のようになります。

    SELECT DATE_SUB('2021-05-01', INTERVAL 30 SECOND);

    結果:

    +--------------------------------------------+
    | DATE_SUB('2021-05-01', INTERVAL 30 SECOND) |
    +--------------------------------------------+
    | 2021-04-30 23:59:30                        |
    +--------------------------------------------+

    時刻は00:00:00から始まると想定しているため、SECOND そこから金額が差し引かれます。

    減算演算子(-

    日時の値から1秒以上を減算する別の方法は、減算演算子(-)を使用することです。 )、マイナス演算子とも呼ばれます。

    例:

    SELECT '2021-05-01 10:00:00' - INTERVAL 30 SECOND;

    結果:

    +--------------------------------------------+
    | '2021-05-01 10:00:00' - INTERVAL 30 SECOND |
    +--------------------------------------------+
    | 2021-05-01 09:59:30                        |
    +--------------------------------------------+

    加算演算子(+

    または、加算演算子(+)を使用することもできます。 )負の金額と一緒に。

    例:

    SELECT '2021-05-01 10:00:00' + INTERVAL -30 SECOND;

    結果:

    +---------------------------------------------+
    | '2021-05-01 10:00:00' + INTERVAL -30 SECOND |
    +---------------------------------------------+
    | 2021-05-01 09:59:30                         |
    +---------------------------------------------+

    秒を引く他の方法

    日時の値から1秒以上を引くために使用できる他のアプローチは次のとおりです。

    • SUBTIME() 機能。
    • ADDTIME() 関数(負の金額を指定すると、日時の値からその金額が差し引かれます)。
    • SUBDATE() 関数(これはDATE_SUB()の同義語です 同じ構文で使用した場合)
    • DATE_ADD() 関数(負の金額を指定すると、日時の値からその金額が差し引かれます)。
    • ADDDATE() 関数(負の金額を指定すると、日時の値からその金額が差し引かれます)。

    1. MySQLは、あるデータベースから別のデータベースに挿入します

    2. IN句のすべての値を一致させる

    3. mysqlのgroup_concatに似たOracleの関数はありますか?

    4. トランザクションの影響を受けないシーケンス?