mysql で利用可能な誕生日のタイプ: 1. DATE タイプ、表現できる日付形式は「YYYY-MM-DD」で、保存に 3 バイトが必要です; 2. DATETIME タイプ、日付形式は表現できる日付形式は「YYYY-MM-DD HH:MM:SS」で、格納時に8バイト必要です; 3. TIMESTAMP型、表現できる日付形式は「YYYY-MM-DD HH:MM:SS」です、保存時は4バイト必要です。
このチュートリアルの動作環境: Windows7 システム、mysql8 バージョン、Dell G3 コンピューター。
MySQL の誕生日に適した日付と時刻のタイプ
タイプ名 | 日付形式 | 日付範囲 | ストレージ要件 |
---|---|---|---|
DATE | YYYY-MM-DD | 1000- 01-01 ~ 9999-12-3 | 3 バイト |
DATETIME | YYYY-MM-DD HH:MM:SS | 1000-01-01 00:00:00 ~ 9999-12-31 23:59:59 | 8 バイト |
TIMESTAMP | YYYY-MM-DD HH:MM:SS | 1980-01-01 00:00:01 UTC ~ 2040-01-19 03:14:07 UTC | 4 バイト |
DATE 型
DATE 型は、時刻部分を除いて日付値のみが必要な場合に使用され、格納に 3 バイトが必要です。日付形式は「YYYY-MM-DD」です。YYYY は年、MM は月、DD は日を表します。
DATE 型フィールドに値を割り当てる場合、DATE の日付形式に準拠していれば、文字列型または数値型のデータを挿入できます。以下に示すように:
「YYYY-MM-DD」または「YYYYMMDD」文字の形式で表される日付。値の範囲は「1000-01-01」~「9999」です。 - 12-3'。たとえば、「2015-12-31」または「20151231」と入力すると、データベースに挿入される日付は 2015-12-31 になります。
日付を「YY-MM-DD」または「YYMMDD」文字列形式で表します。YY は 2 桁の年の値を表します。 MySQL は 2 桁の年の値のルールを解釈します。「00 ~ 69」の範囲の年の値は「2000 ~ 2069」に変換され、「70 ~ 99」の範囲の年の値は「2000 ~ 2069」に変換されます。 「1970年〜1999年」。たとえば、「15-12-31」と入力すると、データベースに挿入される日付は 2015-12-31 になり、「991231」と入力すると、データベースに挿入される日付は 1999-12-31 になります。
YYMMDD 数値形式で表現された日付は前と同様で、00 ~ 69 の範囲の年の値は 2000 ~ 2069 に変換され、年の値は 2000 ~ 2069 に変換されます。 80~99の範囲は1980~1999に変換されます。たとえば、「151231」と入力すると、データベースに挿入される日付は 2015-12-31 になり、「991231」と入力すると、データベースに挿入される日付は 1999-12-31 になります。
現在のシステム日付を挿入するには、CURRENT_DATE または NOW() を使用します。
ヒント: MySQL では「緩和された」構文が許可されています。任意の句読点を日付部分間の区切り文字として使用できます。たとえば、「98-11-31」、「98.11.31」、「98/11/31」、および「98@11@31」は同等であり、これらの値はデータベースに正しく挿入されます。
DATETIME 型
DATETIME 型は、日付と時刻の情報の両方を含む必要があり、格納に 8 バイトを必要とする値に使用されます。日付形式は「YYYY-MM-DD HH:MM:SS」です。ここで、YYYY は年、MM は月、DD は日、HH は時、MM は分、SS は秒を表します。
##DATETIME 型のフィールドに値を割り当てる場合、以下に示すように、DATETIME の日付形式に準拠している限り、文字列型または数値型のデータを挿入できます。 #「YYYY-MM-DD HH:MM:SS」または「YYYYMMDDHHMMSS」の文字列形式で表される日付。値の範囲は「1000-01-01 00:00:00」~」です。 9999-12-3 23:59:59」。たとえば、「2014-12-31 05:05:05」または「20141231050505」と入力すると、データベースに挿入される DATETIME 値は 2014-12-31 05:05:05 になります。- 「YY-MM-DD HH:MM:SS」または「YYMMDDHHMMSS」文字列形式で表される日付。YY は 2 桁の年の値を表します。先ほどと同様に、「00~79」の範囲の年の値は「2000~2079」に変換され、「80~99」の範囲の年の値は「1980~1999」に変換されます。たとえば、「14-12-31 05:05:05」と入力すると、データベースに挿入される日時は 2014-12-31 05:05:05 となり、141231050505 と入力すると、データベースに挿入される日時は 2014 になります。 -12-31 05:05:05 。
- YYYYMMDDHHMMSS または YYMMDDHHMMSS 数値形式で表される日付と時刻。たとえば、20141231050505 と入力すると、データベースに挿入される DATETIME は 2014-12-31 05:05:05 になり、140505050505 と入力すると、データベースに挿入される DATETIME は 2014-12-31 05:05:05 になります。
- ヒント: MySQL では「緩和された」構文が許可されています。任意の句読点を日付部分または時刻部分の間の区切り文字として使用できます。たとえば、「98-12-31 11:30:45」、「98.12.31 11 30 35」、「98/12/31 11*30*45」、「98@12@31 11^30^45」などです。同様に、これらの値はデータベースに正しく挿入できます。
TIMESTAMP型
TIMESTAMPの表示形式はDATETIMEと同じで、表示幅は19文字固定、日付形式はYYYYです。 MM-DD HH:MM : SS、ストレージに 4 バイトが必要です。ただし、TIMESTAMP カラムの値の範囲は、DATETIME の値の範囲である '1970-01-01 00:00:01'UTC ~ '2038-01-19 03:14:07'UTC よりも小さくなります。データを挿入するときは、それが正当な値の範囲内であることを確認してください。
ヒント: 協定世界時 (英語: Coowned Universal Time、フランス語: Temps Universel Coordonné) は、世界統一時、世界標準時、および国際協定時とも呼ばれます。英語 (CUT) とフランス語 (TUC) の略称は異なるため、妥協案として略称は UTC になります。
DATETIME 日付データを保存する場合、次に従って保存されます。つまり、タイム ゾーンに関係なく、入力された内容はすべて保存されます。TIMESTAMP と DATETIME、ストレージ バイトとサポートされる範囲の違いに加えて、最大の違いは次のとおりです。
- TIMESTAMP 値は UTC (世界標準時) 形式で保存され、保存されます。現在のタイムゾーンに正しく変換し、取得時に現在のタイムゾーンに再変換します。つまり、クエリ時に表示される時刻値は、現在のタイムゾーンに応じて異なります。
ヒント: DATE 値を DATETIME または TIMESTAMP オブジェクトに割り当てると、結果の値の時刻部分が '00:00:00' に設定されるため、DATE 値は時間情報は含まれていません。 DATE オブジェクトに DATETIME または TIMESTAMP 値が割り当てられている場合、結果の値の時刻部分が削除されるため、DATE 値には時刻情報が含まれません。
#時刻と日付の関数
- ##システム時刻関数 now()、current_timestamp、sysdate ( )
上の図は、sysdate() によって返される時刻が now() の current_timestamp とは異なり、2 秒遅いことを示しています。その理由は次のとおりです。
- 時間の加算および減算関数
-
① date_add および date_sub
select date_add('2017-12-18 22:51:00', interval 1 second), date_add('2017-12-18 22:51:00', interval 1 minute), date_add('2017-12-18 22:51:00', interval 1 hour), date_add('2017-12-18 22:51:00', interval 1 day), date_add('2017-12-18 22:51:00', interval 1 month), date_add('2017-12-18 22:51:00', interval 1 year);閏月が発生したときに date_add を処理するにはどうすればよいですか? MySQL は、閏月の場合は 2 月 29 日を返し、閏月でない場合は 2 月 28 日を返します。
select date_add('2016-02-29 22:51:00', interval -1 year), date_add('2016-02-29 22:51:00', interval 4 year);
2015-02-28 22:51:002020-02-29 22:51:00② datediff と timediff datediff(date1,date2): 2 つの日付 date1 - date2 を減算し、日数を返します。 select datediff('2016-02-29 22:51:00','2016-03-29 22:51:00');
timediff(time1,time2):two 減算各日付から time1 - time2 を計算し、時差を返します (形式: 838:59:59)。 select timediff('2016-02-29 22:51:00','2016-01-29 22:51:00');
注: timediff(time1,time2)関数の 2 つのパラメーターは同じ型である必要があります。
③ タイムスタンプの増減、変換関数
- -- 日付からタイムスタンプへの変換関数
-
- timestamp(date, time)
-- 日付時刻
- timestampadd(unit,interval,datetime_expr)
-- date_add と同様, 単位ごとに時間を増やしたり減らしたりします。
select timestampadd(second, 60, '2017-12-18 00:00:00'); select timestampadd(minute, 60, '2017-12-18 00:00:00'); select timestampadd(hour, 60, '2017-12-18 00:00:00');
- timestampdiff(unit,datetime_expr1,datetime_expr2)
--2 つの時間の差を計算します。 , 秒、分、時、日、月、年、週を計算できます
select timestampdiff(second, '2017-12-18 00:00:00','2017-12-18 12:00:00'); select timestampdiff(hour, '2017-11-18 00:00:00','2017-12-18 12:00:00'); select timestampdiff(day, '2017-10-17 00:00:00','2017-11-18 23:00:00');
④ date_format 関数
date_format 関数は主に日付の書式設定に使用されます
select date_format(now(),'%Y%m%d'), date_format(now(),'%Y-%m-%d'), date_format(now(),'%Y/%m/%d'), date_format(now(),'%m/%d/%Y');
注: データのクエリ時に日付フィールドにこの関数を使用すると、オプティマイザーはフィールドのインデックスを使用せず、インデックスを介してデータをクエリすることもできないため、クエリ効率が非常に低くなります。 、次のクエリ ステートメントでは、フィールドbirth_date インデックスがある場合、date_format 関数の使用によりインデックスは無効になります:
select * from employees where date_format(birth_date,'%Y-%m-%d') = '1961-08-03';
日付に関する従来のプログラミングの問題ユーザーの生年月日に応じて、現在の日付を使用して、最新の誕生日 (過去および将来の誕生日を含む) を計算します。
-- 上一年,当年,下一年生日与当前时间差最小的年就是用户最近的生日 select emp_no,first_name,last_name,birth_date,today,if(last_diff<=cur_diff and last_diff<=next_diff, last,if(cur_diff from ( -- 计算当前时间与上一年,当年,下一年生日的时间差 select emp_no,first_name,last_name,birth_date,datediff(today,last) as last_diff,abs(datediff(today,cur)) as cur_diff,abs(datediff(today,next)) as next_diff, last,cur,next,today from ( -- 用户最近的生日可能分布在前一年,当年,下一年。根据年度差year_diff计算上一年,当年,下一年用户的生日 select emp_no,first_name,last_name,birth_date, DATE_ADD(birth_date,INTERVAL year_diff year) as cur, DATE_ADD(birth_date,INTERVAL year_diff+1 year) as next, DATE_ADD(birth_date,INTERVAL year_diff-1 year) as last, today from ( -- 获取当前事前与出生日期的年度差 year_diff select emp_no,first_name,last_name,birth_date,(year(NOW())-year(birth_date)) as year_diff, NOW() as today from employees ) a ) b ) c
[関連する推奨事項:
mysql ビデオ チュートリアル以上がmysqlの誕生日にはどのような型が使用されますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于架构原理的相关内容,MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

mysql的msi与zip版本的区别:1、zip包含的安装程序是一种主动安装,而msi包含的是被installer所用的安装文件以提交请求的方式安装;2、zip是一种数据压缩和文档存储的文件格式,msi是微软格式的安装包。

方法:1、利用right函数,语法为“update 表名 set 指定字段 = right(指定字段, length(指定字段)-1)...”;2、利用substring函数,语法为“select substring(指定字段,2)..”。

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境
