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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

PHP

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

Q&A

解決済

3回答

7054閲覧

MySQL4から5へアップデート

isuke

総合スコア4

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

PHP

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

0グッド

0クリップ

投稿2020/03/24 03:04

現在使用しているサーバーがMySQL4から5へ完全切り替えを行うことになり、現在使用しているプログラムのテスト移行を
行っているのですが、上手く動作せず困っております。

現在使用しているプログラムというのはPHPを使用して物件検索を行うものです。
同じ種類の別のサーバーでMySQL5上で設置してみたのですが、以下のエラーが出て詳細ページが表示されません。

Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result resource in

エラー箇所は以下になります。

function getNextChk($nextpage, $disp, $where){ $start = $disp * $nextpage; $limit = " LIMIT ".$start.", ".$disp; $con = dbConnect(); $sql = "SELECT id FROM estate_other".$where.$limit; $rst = mysql_query($sql, $con); dbClose($con); $val = mysql_fetch_array($rst); ←エラー行 return $col['id']; }

エラーを検索したところこちらのサイトで

mysql_fetch_array($rst) を $rst->fetch() に置きかえれますと見つけたので変更したのですが、
そうすると、次に

Fatal error: Call to a member function fetch() on a non-object in

という風になってしまいました。

どなたかご教示いただけないでしょうか。

よろしくお願いします。

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

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

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

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

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

m.ts10806

2020/03/24 03:07

PHPのバージョンも相当古いのでは?
退会済みユーザー

退会済みユーザー

2020/03/24 03:28

クエリー文字列を、変数との文字列連結で作っているとか、そこもプリペアドステートメントにするといいんだろうなぁ。
yoorwm

2020/03/24 03:46

というか、これ以前動いてたんでしょうか? dbClose($con)の内容が分からないのでなんともいえませんが、結果行を取得する前にデータベースのコネクションを閉じてしまっているように見えるのですが。
guest

回答3

0

直接の原因はmysql_queryが失敗してる=正しくSQL組めてない
ことだと思われるのでmysql_queryの実行結果を確認し、実行予定のSQLがMySQL直に実行して想定の結果を得られるか確認してください。

ただ、そもそも接続時点(mysql_connectですよね)でエラーがでないということと、もともとMySQLも4だったということから、PHP自体も相応に古いものと推察されます。
様々な事情はあるかと思いますが、サポート終了したバージョンをいつまでも使い続けるのはリスクでしかないので、PHP自体も早い段階でなるべくバージョンアップするようにご検討ください。
※ただ、やはり削除された機能を利用されてるので大幅な書き換えは避けられません

投稿2020/03/24 03:24

m.ts10806

総合スコア80875

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

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

0

php側の問題でmysqlのバージョンの問題ではないですね
mysql_*関数はもう使うのをやめるとして
phpinfoでmysql関連の情報を確認し、mysqli_*やpdoが
適切にインストールされているのを確認してください

投稿2020/03/24 03:18

yambejp

総合スコア116724

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

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

0

自己解決

適切な回答ありがとうございました。

私の知識では及びそうにないので別の方法を模索したいと思います。

ありがとうございました!

投稿2020/03/25 00:41

isuke

総合スコア4

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問