質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

2回答

1170閲覧

PHP ページング エラー: Uncaught Error: Undefined class constant 'PRAM_INT'

Nekoreset

総合スコア2

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2022/10/15 15:28

現在独学でよく分かる PHPの教科書 PHP7対応版を読んでコードを書いています。
222ページのchapter5-7件数の多いレコードを、ページを分けるの途中の工程でエラーが発生して解決できなくお助け願います。

環境

Mac M1
PHP 7.4.21
MySQL Ver 8.0.30 for macos12.4 on x86_64 (Homebrew)

発生している問題・エラーメッセージ

Fatal error: Uncaught Error: Undefined class constant 'PRAM_INT' in /Applications/MAMP/htdocs/php_book/chapter5/chapter5-7/page.php:20 Stack trace: #0 {main} thrown in /Applications/MAMP/htdocs/php_book/chapter5/chapter5-7/page.php on line 20

該当のソースコード

<?php // 共通化するためのファイル // ファイルの一番上にrequire( "dbconnect.php" ) ;で共通化できる try { $db = new PDO('mysql:dbname=php_test;host=localhost;charset=utf8','root','root'); echo "接続OK!"; } catch (PDOException $e) { echo 'DB接続エラー!: ' . $e->getMessage(); } ?>
<?php require('/Applications/MAMP/htdocs/php_book/chapter5/chapter5-6/dbconnect.php'); ?> <!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <h2>Practice</h2> <?php // データの一覧・詳細画面を作る // データの一覧表示 // 文字数の多いレコードだとスマホなどで見るのが大変になるので見やすくするため文字の表示を制限する // 切り取られた文字列 = mb_substr(切り取る文字列, 最初の位置, 文字数); // 0から10文字までの制限 // hrefの中、PHPのパラメータを作っている $memos = $db -> prepare( 'select * from memos order by id limit ?, 5' ); $memos -> bindParam( 1, $_REQUEST[ 'page' ], PDO::PRAM_INT ); $memos -> execute(); ?> <?php // 10文字以上だった場合...と表示するコードの書き方 // 三項演算子 // echo mb_strlen( $memo[ "memo" ] ) > 10 ? "..." : "" ; // 引数1に条件,引数2に成立したら表示したい内容,引数3成立しなかったら””で何もしない ?> <article> <?php while ( $memo = $memos -> fetch() ) : ?> <p> <a href = "show.php?id=<?php echo $memo[ "id" ] ; ?>"> <?php echo mb_substr( $memo[ 'memo' ], 0, 10); ?> <?php echo mb_strlen( $memo[ "memo" ] ) > 10 ? "..." : "" ; ?> </a> </p> <time><?php echo $memo[ 'created' ] ; ?></time> <hr> <?php endwhile ; ?> </article> </body> </html>

試したこと

コードのtypoミスを疑い何度も書き直したのですがtypoミスじゃなく
エラー文に出ているPDO::PRAM_INTがうまく動いていないの考えてるのですがどうすればいいか分からずです。

ここにより詳細な情報を記載してください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

コードのtypoミスを疑い何度も書き直したのですがtypoミスじゃなく

当該書籍が手元にないので確認できませんが、
目視による確認なのであれば、人間の目ほど信用できないものはないです。
思い込みがあるからです。一字一字読み上げましたか?
既存機能のPDOのものなので、PHPマニュアルを確認するとわかります。
https://www.php.net/manual/ja/pdo.constants.php

  \記述
質問者さんPDO::PRAM_INT
PHPマニュアルPDO::PARAM_INT

本当に書籍にPRAM_XXXとあるのでしたら、出版元に問い合わせて指摘してください。

いずれにしても参考書籍とは言えど、手動での複写のためにあるのではなく、ロジック参考として「コードの書き方」を学ぶものとして鵜呑みにするのは良くないです。
機能については必ずPHPマニュアルを確認し、コピペするくらいの慎重さは持った方が良いかもしれません。

また、もし、メモ帳や一般的なテキストエディタをご利用でしたら、構文チェックや機能サジェスチョンができるプログラミングに特化したプラグイン導入可能なエディタや統合環境(IDEと言われるもの)を利用しましょう。
この手のミスが一気に減ります。

例えばIDEの一つであるeclipseではPDO::まで打ったところで利用できる機能の候補が出ます。
候補を選択すると自動でコードとして挿入されるので、ミスがなくなります。
イメージ説明

投稿2022/10/15 20:16

編集2022/10/16 04:19
m.ts10806

総合スコア80850

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Nekoreset

2022/10/16 09:21

Aが抜けてました。 ご回答ありがとうございます
guest

0

投稿2022/10/15 16:43

javahack

総合スコア1088

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問