目次
プログラムのエンコーディングはutfです-8、phpMyAdminもutf-8です

php mysqlデータ操作の問題

Jun 23, 2016 pm 01:50 PM
mysql php 操作する データ

先輩に指導してもらいましょう!

図に示すように、テーブルには 2 つのデータがあります。1 つ目は phpMyAdmin に挿入され、2 つ目は php ページから挿入されます
org_name varchar 型 open_time timestamp 型
php コードは次のとおりです。 :
<?php
include_once(" pay/CommonUtil.php");
include_once dirname(__FILE__).'/db/DbOperation.php';
$db = new DbOperation('z_org'); array(
"org_id" => 2 ,
"org_name" => "北京",
"open_time" => time()
);
$db->addObject($org); = $db->getAll() ;
var_dump($rs);
?>
問題:
1. php から挿入されたデータが文字化けしており、時刻が 0000-00-00 00:00 です。 :00
2. テーブル全体の最初の漢字データをクエリします。コードが文字化けします。2 番目は正常です。 array(2) { [0]=> array(3) { ["org_id"]=> (1) "1" ["組織名"]=> 文字列(3 ) "???" ["open_time"]=> 文字列(19) "2014-08-23 18:35:18" } [1 ]=> 配列(3) { ["組織ID"]=> 文字列(1) "2" ["組織名"]=> 文字列(19) ) "0000-00-00 00:00:00" } }



ディスカッションへの返信(解決策)

プログラムのエンコーディングは何ですか? phpmyadminと同じエンコーディングに変更してください

プログラムのエンコーディングはutfです-8、phpMyAdminもutf-8です

Du Niangは、データベース接続を取得するときに更新する必要があると言いました(名前をutf_8に設定します)

それを追加した後、エラーメッセージ「致命的エラー:キャッチされない例外「DB_Exception」とメッセージ「更新」が表示されました失敗しました: 不明な文字セット: 'utf''


('set names utf8')
ではありません

(' set names utf_8')


さて、utf8 を使用してみましたが、問題は解決しました
これで、残りのタイムスタンプが問題: time() 関数が機能しません。date("Y-m-d h:i:s") を試しました。問題は次のとおりです。
array(3) { ["org_id"]=> ) "1" ["組織名"]=> 文字列(9) "上海市" ["open_time"]=> 文字列(19) "2014-08-23 18:35:18" }

配列(3) { ["org_id"]=> 文字列(1) "2" ["org_name"]=> 文字列(20) " ["open_time"]=> "0000-00-00 00:00:00" }

array(3) { ["org_id"]=> string(1) "3" ["org_name"]=> string(9) "重慶市" ["open_time"]=> string(19) "0000-00-00 00:00:00" }
array(3 ) { ["org_id"]=> string(1) "4" ["org_name" ]=> string(9) "天津市" ["open_time"]=> string(19) "2014-08-23 12:00:31" }
array(3) { ["org_id"]=&gt ; 文字列(1) "5" ["組織名"]=> 文字列(9) "河北省" ["open_time"] => 文字列(19) "2014-08-23 12:02:34" }通常より8時間遅いのですが、タイムゾーンの問題なのかわかりませんが、どう設定すればよいのでしょうか?

$org = array(
"org_id" => 2,
"org_name" => "Beijing",
"open_time" => 'now()'
);データベースの関数は OK です

ツリー ゾーンが適切に設定されていないため、日付の時刻が間違っています

date_default_timezone_set('PRC'); を追加しました
書き込み時刻は ["open_time"]= > 文字列です(19) "2014-08-23 08:11:27"、24 時間時計ではないようです
"open_time" => 'now()' を試してみたところ、["open_time"] が返されました。 => string(19) "0000-00-00 00:00:00"、すべての書き込みパラメータがスラッシュでエスケープされています、これが問題かどうかはわかりません

PHP には now() 関数はありません
now() は date("Y-m-d H:i:s" ) と同等です

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド

CakePHP の日付と時刻 CakePHP の日付と時刻 Sep 10, 2024 pm 05:27 PM

CakePHP の日付と時刻

CakePHP プロジェクトの構成 CakePHP プロジェクトの構成 Sep 10, 2024 pm 05:25 PM

CakePHP プロジェクトの構成

CakePHP ファイルのアップロード CakePHP ファイルのアップロード Sep 10, 2024 pm 05:27 PM

CakePHP ファイルのアップロード

CakePHP ルーティング CakePHP ルーティング Sep 10, 2024 pm 05:25 PM

CakePHP ルーティング

CakePHP について話し合う CakePHP について話し合う Sep 10, 2024 pm 05:28 PM

CakePHP について話し合う

MySQL 8.4 で mysql_native_password がロードされていないエラーを修正する方法 MySQL 8.4 で mysql_native_password がロードされていないエラーを修正する方法 Dec 09, 2024 am 11:42 AM

MySQL 8.4 で mysql_native_password がロードされていないエラーを修正する方法

CakePHP クイックガイド CakePHP クイックガイド Sep 10, 2024 pm 05:27 PM

CakePHP クイックガイド

See all articles