検索

フォーラムや私のトレーニング コースで、MySQL データベースに保存され、PHP で使用される日付を管理する最良の方法 (または任意の方法) について質問している人がたくさんいます。 3 つのオプションが続きますが、最初に問題があります。
PHP は、すべての日付機能に UNIX タイムスタンプを使用します。これらのタイムスタンプをほぼすべてのテキスト形式に変換するメソッドがありますが、内部的にはタイムスタンプ形式を使用します。タイムスタンプは単なる整数です。具体的には、1970 年 1 月 1 日の午前 0 時 (グリニッジ標準時) から経過した秒数です。
MySQL には、カラムで使用できる 3 つの日付タイプがあります。これらは、DATETIME、DATE、および TIMESTAMP です。 DATETIME 列には、日付と時刻が YYYY-MM-DD HH:MM:SS 形式の文字列として保存されます (例: 2006-12-25 13:43:15)。 DATE 列では、この形式の日付部分のみを使用します – YYYY-MM-DD (例: 2006-12-25)。 TIMESTAMP カラムは、その名前とは異なり、PHP で使用される UNIX タイムスタンプとはまったく異なります。 TIMESTAMP 列は、レコードの内容が変更されるたびに現在時刻に自動的に更新される単純な DATETIME 列です。 (これは単純化していますが、大まかには真実であり、ここでは詳細は重要ではありません)。特に、MySQL のバージョン 4.1 以降、TIMESTAMP 形式は DATETIME 形式とまったく同じです。
したがって、問題は、これら 2 つのまったく異なる日付形式 (PHP タイムスタンプ整数と MySQL DATETIME 文字列) をどのように扱うかということです。一般的な解決策は 3 つあります…
一般的な解決策の 1 つは、日付を DATETIME フィールドに格納し、PHP の date() 関数と strtotime() 関数を使用して PHP タイムスタンプと MySQL DATETIME の間で変換することです。メソッドは次のように使用されます -
$mysqldate = date( 'Y-m-d H:i:s', $phpdate );
$phpdate = strtotime( $mysqldate );
2 番目のオプションは、MySQL に作業を行わせることです。 MySQL には、データベースにアクセスする時点でデータを変換するために使用できる関数があります。 UNIX_TIMESTAMP は DATETIME から PHP タイムスタンプに変換し、FROM_UNIXTIME は PHP タイムスタンプから DATETIME に変換します。メソッドは SQL クエリ内で使用されます。したがって、次のようなクエリを使用して日付を挿入および更新します -
$query = "テーブルセットを更新します
    datetimefield = FROM_UNIXTIME($phpdate)
    どこ…」;
$query = "SELECT UNIX_TIMESTAMP(日時フィールド)
    テーブルのどこから...」;
最後のオプションは、どこでも PHP タイムスタンプ形式を使用することです。 PHP タイムスタンプは符号付き整数であるため、MySQL の整数フィールドを使用してタイムスタンプを保存します。この方法では、変換は行われず、まったく問題なく PHP タイムスタンプをデータベースに出入りするだけで済みます。 ただし、整数フィールドを使用して日付を保存すると、MySQL は日付が日付であることを認識しないため、MySQL 内の多くの機能が失われることに注意してください。 PHP のタイムスタンプは時間の経過とともに定期的に増加するため、日付フィールドでレコードを並べ替えることはできますが、データに対して MySQL の日付と時刻関数のいずれかを使用したい場合は、FROM_UNIXTIME を使用して関数の MySQL DATETIME を取得する必要があります。取り組んでください。
ただし、データベースを使用して日付情報を保存するだけであり、その操作はすべて PHP で行われる場合は問題ありません。 www.2cto.com
したがって、最終的にはどれを使用するかを選択することになります。私にとって、MySQL 内で日付を操作する必要がない場合は、競合はなく、最後のオプションが最適です。使い方は簡単で、データテーブルのストレージスペースとデータの読み書き時の実行速度の点で最も効率的です。
ただし、一部のクエリは日付フィールドに日付が含まれていないためより複雑になり (例: 誕生日が今日であるすべてのユーザーを選択するなど)、長期的には損をする可能性があります。この場合、オプション 1 または 2 のいずれかを使用する方がよいでしょう。どちらを使用するかは、作業を MySQL と PHP のどちらに配置するかによって異なります。私はオプション 2 を使用することが多いですが、正解も不正解もありません。お好みで選んでください。
最後の段落まで直接スキップした人のために要約すると、ほとんどの場合、私はオプション 3 を使用しますが、MySQL がフィールドに日付が含まれていることを認識する必要があるため、オプション 2 を使用することもあります。

著者:chenjie3392593

http://www.bkjia.com/PHPjc/478085.htmlwww.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/478085.html技術記事フォーラムや私のトレーニング コースで、MySQL データベースに保存され、PHP で使用される日付を管理する最良の方法 (または任意の方法) について質問している人がたくさんいます。 3 つのオプションが続きます。b...
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHPの継続的な使用:その持久力の理由PHPの継続的な使用:その持久力の理由Apr 19, 2025 am 12:23 AM

まだ人気があるのは、使いやすさ、柔軟性、強力なエコシステムです。 1)使いやすさとシンプルな構文により、初心者にとって最初の選択肢になります。 2)Web開発、HTTP要求とデータベースとの優れた相互作用と密接に統合されています。 3)巨大なエコシステムは、豊富なツールとライブラリを提供します。 4)アクティブなコミュニティとオープンソースの性質は、それらを新しいニーズとテクノロジーの傾向に適応させます。

PHPおよびPython:類似点と相違点を調査しますPHPおよびPython:類似点と相違点を調査しますApr 19, 2025 am 12:21 AM

PHPとPythonはどちらも、Web開発、データ処理、自動化タスクで広く使用されている高レベルのプログラミング言語です。 1.PHPは、ダイナミックウェブサイトとコンテンツ管理システムの構築によく使用されますが、PythonはWebフレームワークとデータサイエンスの構築に使用されることがよくあります。 2.PHPはエコーを使用してコンテンツを出力し、Pythonは印刷を使用します。 3.両方ともオブジェクト指向プログラミングをサポートしますが、構文とキーワードは異なります。 4。PHPは弱いタイプの変換をサポートしますが、Pythonはより厳しくなります。 5. PHPパフォーマンスの最適化には、Opcacheおよび非同期プログラミングの使用が含まれますが、PythonはCprofileおよび非同期プログラミングを使用します。

PHPおよびPython:さまざまなパラダイムが説明されていますPHPおよびPython:さまざまなパラダイムが説明されていますApr 18, 2025 am 12:26 AM

PHPは主に手順プログラミングですが、オブジェクト指向プログラミング(OOP)もサポートしています。 Pythonは、OOP、機能、手続き上のプログラミングなど、さまざまなパラダイムをサポートしています。 PHPはWeb開発に適しており、Pythonはデータ分析や機械学習などのさまざまなアプリケーションに適しています。

PHPとPython:彼らの歴史を深く掘り下げますPHPとPython:彼らの歴史を深く掘り下げますApr 18, 2025 am 12:25 AM

PHPは1994年に発信され、Rasmuslerdorfによって開発されました。もともとはウェブサイトの訪問者を追跡するために使用され、サーバー側のスクリプト言語に徐々に進化し、Web開発で広く使用されていました。 Pythonは、1980年代後半にGuidovan Rossumによって開発され、1991年に最初にリリースされました。コードの読みやすさとシンプルさを強調し、科学的コンピューティング、データ分析、その他の分野に適しています。

PHPとPythonの選択:ガイドPHPとPythonの選択:ガイドApr 18, 2025 am 12:24 AM

PHPはWeb開発と迅速なプロトタイピングに適しており、Pythonはデータサイエンスと機械学習に適しています。 1.PHPは、単純な構文と迅速な開発に適した動的なWeb開発に使用されます。 2。Pythonには簡潔な構文があり、複数のフィールドに適しており、強力なライブラリエコシステムがあります。

PHPとフレームワーク:言語の近代化PHPとフレームワーク:言語の近代化Apr 18, 2025 am 12:14 AM

PHPは、多数のWebサイトとアプリケーションをサポートし、フレームワークを通じて開発ニーズに適応するため、近代化プロセスで依然として重要です。 1.PHP7はパフォーマンスを向上させ、新機能を紹介します。 2。Laravel、Symfony、Codeigniterなどの最新のフレームワークは、開発を簡素化し、コードの品質を向上させます。 3.パフォーマンスの最適化とベストプラクティスは、アプリケーションの効率をさらに改善します。

PHPの影響:Web開発などPHPの影響:Web開発などApr 18, 2025 am 12:10 AM

phphassiblasifly-impactedwebdevevermentandsbeyondit.1)itpowersmajorplatformslikewordpratsandexcelsindatabase interactions.2)php'sadaptableability allowsitale forlargeapplicationsusingframeworkslikelavel.3)

スカラータイプ、リターンタイプ、ユニオンタイプ、ヌル可能なタイプなど、PHPタイプのヒントはどのように機能しますか?スカラータイプ、リターンタイプ、ユニオンタイプ、ヌル可能なタイプなど、PHPタイプのヒントはどのように機能しますか?Apr 17, 2025 am 12:25 AM

PHPタイプは、コードの品質と読みやすさを向上させるためのプロンプトがあります。 1)スカラータイプのヒント:php7.0であるため、基本データ型は、int、floatなどの関数パラメーターで指定できます。 3)ユニオンタイプのプロンプト:PHP8.0であるため、関数パラメーターまたは戻り値で複数のタイプを指定することができます。 4)Nullable Typeプロンプト:null値を含めることができ、null値を返す可能性のある機能を処理できます。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

PhpStorm Mac バージョン

PhpStorm Mac バージョン

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

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境