→ MOONRAKER: 這是當然的好嗎,constructor不回傳東西 07/24 11:04
→ MOONRAKER: 你有什麼理由非要這樣 連多呼叫一個$value->getValue() 07/24 11:05
→ MOONRAKER: 都不想嗎 07/24 11:05
謝謝M大回覆~沒錯我去多呼叫可以解決!!
問題原由是因為我在處理連結資料庫的時候,有出現有連上,但無法query問題。
細找問題後,發現CONNECT根本沒有回傳,所以才衍生出這樣的提問。
https://blog.csdn.net/welovesunflower/article/details/7776438
裡面範例他有一個 db_connect.php ,相較於我上頭的config.php,準備提供引入用。
內容有斷如下:
class DB_CONNECT {
// constructor
function __construct() {
// connecting to database
$this->connect(); //這裡用了類似作法
}
function connect() {
// import database connection variables
require_once __DIR__ . '/db_config.php';
// Connecting to mysql database
$con = mysql_connect(DB_SERVER, DB_USER, DB_PASSWORD) ...;
....
// returing connection cursor
return $con; //回傳connect //這裡用了類似作法
}
再來範例裡面有一個 get_all_products.php,相較於我的main.php,
裡面開頭如下:
==============================================
...
// include db connect class
require_once __DIR__ . '/db_connect.php';
// connecting to db
$db = new DB_CONNECT(); //此處根本沒有得到值。
// get all products from products table
$result = mysql_query("SELECT *FROM products") or die(mysql_error())
...
==============================================
$db因為沒有得到值,所以query不到。
當然如您建議我加個 $con = $db->connect(); 就沒問題了。
所以是不是其實真不該這樣寫呢?
應該明瞭了!!! 觀念問題,謝謝M大~
→ MOONRAKER: 這樣我就看不懂了 為什麼他的資料庫包裝會這樣 07/24 11:59
→ MOONRAKER: 一時想不通 但是什麼時候了還在用mysql_connect()這種 07/24 12:13
→ MOONRAKER: 爛招 新的php早就沒了 new會跑不出東西八成是這個原因 07/24 12:15
→ MOONRAKER: 趕快找個教用pdo連資料庫的文件來看吧 起碼也要mysqli 07/24 12:16
→ MOONRAKER: 依照他這種爛招 再connect()一次也沒有東西 07/24 12:16
!!! 原來有這東西!!謝謝M大指導!!
※ 編輯: goodsheng (118.163.89.30), 07/24/2018 13:25:40
→ MOONRAKER: 從php 5.5開始廢棄 7.0拿掉 如今php 7.2都出了 07/24 13:55
→ MOONRAKER: WAMP一類套件包當然不會再放舊的 雖然你要也是找得到 07/24 13:56
→ goodsheng: 好的!! mysqli或是PDO處理 07/24 13:59
→ xdraculax: $db 得到了 class 啊,return 是供額外呼叫用 07/25 01:20
→ xdraculax: 它的 __construct 也沒有 return $this->connect() 07/25 01:21
→ xdraculax: 你怎麼會誤以為它 $db 是想取 $con 07/25 01:22
→ xdraculax: mysql_query 沒代入 con 就是預設上一個連線 07/25 01:24
→ xdraculax: 範例並沒有錯應該要有資料,沒資料一定是別的有錯 07/25 01:25
→ xdraculax: 以上指正你 new class 的誤解而非說可繼續用 mysql_xx 07/25 01:29
→ MOONRAKER: 有啦昨晚有想出來 他是佔mysql_query()沒給連線物件 07/25 14:52
→ MOONRAKER: 就自動沿用最近那個的便宜 實在不可取 07/25 14:52
對,其實一開始也不認為他會return東西,因為他mysql_query並沒有要帶入$con。
而照理說接下來的操作應該要沿用所謂"預設上一個連線"
但實作後卻發現並沒有,他並沒有延用到,所以mysql接下來操作都沒有反應。
所以我就天真自己加了$db進去,天真以為$db有東西。
$result = mysql_query($db,"SELECT *FROM products") or die(mysql_error())
想當然沒反應,$db不會有東西,因為如x大解說,return不回東西的。
但後來解決方式是再呼叫一次connect(),且也要帶入$con,才能成功,沒帶入不行。
$con = $db->connect();
$result = mysql_query($con,"SELECT *FROM products") or die(mysql_error())
所以才會有建構內return的疑問..
所以現在衍生的問題是:
1.一開始的方式,由建構來初始連線,但回主程式時,卻無法直接沿用後連線。
2.後來改再次呼叫connect()的方式,看起來也是無延續上一連線。必須要帶入$con。
看起來好像是同一問題,就副程式實體後的連線無法給主程式用?
但這問題可能也不是很重要,因為可以先用了.. (註:上述mysql我也都改成mysqli用了)
再次謝謝x大及M大~~
※ 編輯: goodsheng (118.163.89.30), 07/26/2018 16:05:02