検索
ホームページバックエンド開発PHPチュートリアルPDO は結果セットの数をどのように計算しますか?

有这样一段代码,怎么取也取不到结果集的数目....请各位大神看看...
$stmt=$dbc->prepare('select count(*) from loginlog');
    $rows=$stmt->execute();
    pageDivide($rows,10);
$result=$dbc->prepare('select * from loginlog order by logintime desc limit $sqlfirst,$shownu');
$result->execute();
echo'一共有'.$rows.'条登录记录';
echo '

';
echo '
';
echo '
';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
while($row=$result->fetch()){
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
}
echo '
用户名密码登录IP登录时间登录状态尝试次数在线状态
'.$row['name'].''.$row['password'].''.$row['ip'].''.$row['logintime'].''.$row['status'].''.'1'.''.'在线'.'
';
echo '';
echo '
';
echo '
';
echo '
>'; ->fetch(PDO::FETCH_NUM); echo $result[0] ; //そのように書かれていますか?
$stmt=$dbc->prepare('ログインログから * を選択');

$rows=$stmt->execute();

$rowsNum=$rows->fetch(PDO::FETCH_NUM);

LZ は $stmt=$dbc->prepare('select * from loginlog');
$rows=$stmt->execute();

$rowsNum=$rows->fetch(PDO::FETCH_ASSOC) );

print_r($rowsNum->rowCount());

LZ は $stmt=$dbc->prepare('select * from loginlog');
$rows=$stmt->query(); ;
$rowsNum=$rows->fetch(PDO::FETCH_ASSOC);
print_r($rowsNum->rowCount());

上記には少し問題があります。 rowCount()) ;



LZ は $stmt=$dbc->prepare('select * from loginlog');
$rowsNum=$rows-> ;fetch(PDO ::FETCH_ASSOC);

print_r($rowsNum->rowCount());

上記には若干の問題があります。それは print_r($rows->rowCount()); です。非オブジェクト i でのメンバー関数 fetch() の呼び出し
$stmt=$dbc->prepare('select * from loginlog');
$rows=$stmt->execute(); $rows->fetch(PDO ::FETCH_ASSOC);
$rowsN=$rows->rowCount();
$stmt=$dbc->prepare('ログインログから * を選択'); $stmt->execute() ;

$rowsNum= $stmt->fetch(PDO::FETCH_NUM);

$stmt=$dbc->prepare('ログインログから * を選択'); $stmt->execute() ;
$rowsNum= $stmt->fetch(PDO::FETCH_NUM);
配列をエコーし​​ます。 。 。 rowCount(); が必要ですか?

$stmt=$dbc->prepare('ログインログから count(*) を選択');
$stmt->execute();
$rowsNum=$stmt->fetch(PDO::FETCH_NUM); // 配列を返します
print_r($rowsNum);

または次のようにします:
$stmt=$dbc->prepare('select count(*) from loginlog');

$stmt->execute();

$rowsNum = $stmt->fetchColumn();
echo $rowsNum;

int PDOStatement::rowCount (void)


PDOStatement::rowCount() 対応する PDOStatement によって実行された最後の DELETE、INSERT、または UPDATE を返します。 object ステートメントによって影響を受ける行の数。

関連する PDOStatement によって実行された最後の SQL ステートメントが SELECT ステートメントであった場合、一部のデータはこのステートメントによって返された行数を返す場合があります。ただし、このアプローチはすべてのデータに対して機能することが保証されていないため、ポータブル アプリケーションには依存しないでください。

$stmt=$dbc->prepare('select count(*) from loginlog');
$stmt->execute();
$rowsNum=$stmt->fetch(PDO::FETCH_NUM);  //返回一个数组
print_r($rowsNum);

或者这样:
$stmt=$dbc->prepare('select count(*) from loginlog');
$stmt->execute();
$rowsNum = $stmt->fetchColumn();
echo $rowsNum;

$stmt=$dbc->prepare('select count(*) from loginlog');
    $rows=$stmt->execute();
    $rowsNum = $rows->fetchColumn();
    pageDivide($rowsNum,10);
$result=$dbc->prepare('select * from loginlog order by logintime desc limit $sqlfirst,$shownu');
$result->execute();
//if($stmt){
/*$result=mysql_query('select * from loginlog order by logintime desc ');
$total=mysql_num_rows($result);
pageDivide($total,10);
$result=mysql_query("select * from loginlog order by logintime desc limit $sqlfirst,$shownu ");*/
echo'一共有'.$rowsNum.'条登录记录';
echo '

';
echo '
';
echo '
';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
//while($tota=mysql_fetch_assoc($result)){
while($row=$result->fetch()){
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
echo '';
}
echo '
用户名密码登录IP登录时间登录状态尝试次数在线状态
'.$row['name'].''.$row['password'].''.$row['ip'].''.$row['logintime'].''.$row['status'].''.'1'.''.'在线'.'
';
echo '';
echo '
';
echo '
';
echo '
';

全体的なコードは次のようになりますが、ページでは常にエラーが報告されます
致命的なエラー: 非オブジェクトのメンバー関数 fetchColumn() の呼び出し これはなぜですか?

$rows= $stmt->execute();
$rowsNum = $stmt->fetchColumn();

$rowsNum = $stmt-> fetchColumn();

$stmt=$dbc->prepare('ログインログから count(*) を選択');
$rowsNum = $rows->fetchColumn( );
このように書かれています... エラー~


この投稿は xuzuning によって最終編集されました: 2013-06-26 15:38:19

$stmt->execute();

$rowsNum = $ stmt- >fetchColumn();

$stmt->execute();

そうです、理由を教えてください。今後このような間違いをしないようにしたいです
PDO::prepare は $stmt である PDOStatement オブジェクトを返します

そして PDOStatement::execute は実行が成功したかどうかを示す論理値を返します
$ と書くとrows= $stmt->execute();
そうすると、$rows は true になります

もちろん、fetchColumn メソッドはないので、エラーが報告されます


まず、使い方だけでなく、マニュアルを読む必要がありますただし、プロトタイプ宣言の読み方も学びましょう
2 つ目は、エラー メッセージの読み方を学ぶ必要があります

PDO::prepare は、$stmt である PDOStatement オブジェクトを返します
そして、PDOStatement::execute は、実行が正しいかどうかを示す論理値を返します成功したかどうか
$rows=$stmt ->execute(); と書くと
その場合、$rows は単に true になります

もちろん、fetchColumn メソッドがないため、エラーが報告されます


最初は、マニュアルでは、使用方法だけでなく、プロトタイプ宣言の読み方も学びます
2 つ目は、エラー メッセージの読み方を学ぶことです

はい、はい、わかりました、ありがとう... 私は常にプロジェクト主導の方法で PHP を学習してきました。そして、問題が発生した場合にのみマニュアルを読みます...

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
絶対的なセッションタイムアウトとアイドルセッションのタイムアウトの違いは何ですか?絶対的なセッションタイムアウトとアイドルセッションのタイムアウトの違いは何ですか?May 03, 2025 am 12:21 AM

絶対セッションのタイムアウトはセッションの作成時に開始され、アイドルセッションタイムアウトはユーザーの操作なしに開始されます。絶対セッションタイムアウトは、金融アプリケーションなど、セッションライフサイクルの厳格な制御が必要なシナリオに適しています。アイドルセッションタイムアウトは、ソーシャルメディアなど、ユーザーが長い間セッションをアクティブに保つことを望んでいるアプリケーションに適しています。

セッションがサーバーで機能していない場合、どのような措置を講じますか?セッションがサーバーで機能していない場合、どのような措置を講じますか?May 03, 2025 am 12:19 AM

サーバーセッションの障害は、手順に従って解決できます。1。セッションが正しく設定されていることを確認するために、サーバーの構成を確認します。 2.クライアントCookieを確認し、ブラウザがそれをサポートしていることを確認し、正しく送信します。 3. Redisなどのセッションストレージサービスを確認して、それらが正常に動作していることを確認します。 4.アプリケーションコードを確認して、正しいセッションロジックを確認します。これらの手順を通じて、会話の問題を効果的に診断および修復し、ユーザーエクスペリエンスを改善することができます。

session_start()関数の重要性は何ですか?session_start()関数の重要性は何ですか?May 03, 2025 am 12:18 AM

session_start()iscrucialinphpformangingusersions.1)itInitiateSanewsessionifnoneExists、2)resumesanexistingsession、および3)SetSessionCookieforcontinuityAcrossRequests、ApplicationslicationSliviseSlikeUserauthicationAnticatent。

セッションクッキーにHTTPonlyフラグを設定することの重要性は何ですか?セッションクッキーにHTTPonlyフラグを設定することの重要性は何ですか?May 03, 2025 am 12:10 AM

HTTPonlyフラグを設定することは、XSS攻撃を効果的に防止し、ユーザーセッション情報を保護することができるため、セッションCookieにとって重要です。具体的には、1)HTTPONLYフラグは、JavaScriptがCookieにアクセスするのを防ぎます。2)Flagは、PHPとFlaskのSetCookiesとMake_Responseを介して設定できます。

PHPセッションはWeb開発でどのような問題を解決しますか?PHPセッションはWeb開発でどのような問題を解決しますか?May 03, 2025 am 12:02 AM

phpsessionssolvetheprobrof of maintainsea crossmultiplehttprequestsbyStoringdataontaonsociatingitiTauniquesessionid.1)それらは、通常はヨーロッパの側面、および一般的には、測定されている

どのデータをPHPセッションに保存できますか?どのデータをPHPセッションに保存できますか?May 02, 2025 am 12:17 AM

phpssionscanStorestrings、numbers、arrays、andobjects.1.strings:textdatalikeusernames.2.numbers:integersorfloatsforcounters.3.arrays:listslikeshoppingcarts.4.objects:complextructuresthataresialized。

どのようにPHPセッションを開始しますか?どのようにPHPセッションを開始しますか?May 02, 2025 am 12:16 AM

tostartaphpsession、outsession_start()atthescript'sbeginning.1)placeitbe foreanyouttosetthesscookie.2)usesionsionsionsionserdatalikelogintatussorshoppingcarts.3)再生セッションインドストップレベントフィックスアタック

セッションの再生とは何ですか?また、セキュリティをどのように改善しますか?セッションの再生とは何ですか?また、セキュリティをどのように改善しますか?May 02, 2025 am 12:15 AM

セッション再生とは、新しいセッションIDを生成し、セッション固定攻撃の場合にユーザーが機密操作を実行するときに古いIDを無効にすることを指します。実装の手順には次のものが含まれます。1。感度操作を検出、2。新しいセッションIDを生成する、3。古いセッションIDを破壊し、4。ユーザー側のセッション情報を更新します。

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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

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

PhpStorm Mac バージョン

PhpStorm Mac バージョン

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

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。