30日より古いすべての行を削除するMySQLクエリ?
30日より古いすべての行を削除するには、間隔を指定してDELETEを使用する必要があります。
まずテーブルを作成しましょう-
mysql> create table DemoTable -> ( -> UserMessage text, -> UserMessageSentDate date -> ); Query OK, 0 rows affected (0.59 sec)
挿入コマンド-
を使用して、テーブルにいくつかのレコードを挿入しますmysql> insert into DemoTable values('Hi','2019-06-01'); Query OK, 1 row affected (0.11 sec) mysql> insert into DemoTable values('Hello','2019-07-02'); Query OK, 1 row affected (0.14 sec) mysql> insert into DemoTable values('Awesome','2019-05-04'); Query OK, 1 row affected (0.15 sec) mysql> insert into DemoTable values('Good','2019-01-10'); Query OK, 1 row affected (0.35 sec)
selectステートメントを使用してテーブルのすべてのレコードを表示する-
mysql> select *from DemoTable;
出力
+-------------+---------------------+ | UserMessage | UserMessageSentDate | +-------------+---------------------+ | Hi | 2019-06-01 | | Hello | 2019-07-02 | | Awesome | 2019-05-04 | | Good | 2019-01-10 | +-------------+---------------------+ 4 rows in set (0.00 sec)
以下は、30日より古いすべての行を削除するためのクエリです-
mysql> delete from DemoTable where UserMessageSentDate < now() - interval 30 DAY; Query OK, 3 rows affected (0.11 sec)
テーブルレコードをもう一度確認しましょう-
mysql> select *from DemoTable;
出力
+-------------+---------------------+ | UserMessage | UserMessageSentDate | +-------------+---------------------+ | Hello | 2019-07-02 | +-------------+---------------------+ 1 row in set (0.00 sec)
-
MySQLでタイムスタンプが5分より古いレコードを削除しますか?
これには、DELETEコマンドを使用します。まずテーブルを作成しましょう- mysql> create table DemoTable1851 ( DueDate datetime ); Query OK, 0 rows affected (0.00 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql> insert into DemoTable1851 values('2019-12-03 21:30:35'
-
MySQLで1日より古いタイムスタンプで更新された行をフェッチしますか?
このために、yYouはnow()と一緒にfrom_unixtime()を使用できます。 いくつかのデータ型でテーブルを作成しましょう- 例 mysql> create table demo75 -> ( -> due_date int(11) -> ); Query OK, 0 rows affected, 1 warning (2.87 挿入コマンド-を使用して、いくつかのレコードをテーブルに挿入します。 例 mysql> insert into demo75 values(uni