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

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

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

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

解決済

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

Nekoreset
nnkk

総合スコア2

PHP

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

2回答

0グッド

0クリップ

293閲覧

投稿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がうまく動いていないの考えてるのですがどうすればいいか分からずです。

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

以下のような質問にはグッドを送りましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

グッドが多くついた質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

回答2

1

ベストアンサー

コードの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

総合スコア79961

javahack👍を押しています

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

回答へのコメント

Nekoreset

2022/10/16 09:21

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

1

投稿2022/10/15 16:43

javahack

総合スコア1069

m.ts10806👍を押しています

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

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

ただいまの回答率
86.12%

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

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

質問する

関連した質問

同じタグがついた質問を見る

PHP

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