مشکل در گرفتن query در php PDO

- 2 هفته پیش
توسط Alimotreb آپدیت شد
pasha ( 545 تجربه )
3 هفته پیش

سلام، در مورد گرفتن اطلاعات از پایگاه داده توسط pdo از mysql مشکل دارم. عبارت SELECT ساده که با fetchAll مینویسم. مثل اموزش قسمت PHP. اما چنین اروری میده:

Fatal error: Uncaught Error: Call to a member function fetchAll() on boolean in C:\xampp\htdocs\test\index\index.php:13 Stack trace: #0 {main} thrown in C:\xampp\htdocs\test\index\index.php on line 13

Alimotreb ( 54862 تجربه )
3 هفته پیش

سلام
@amir.psh

کدتون رو قرار بدید تا ببینیم چیه!
بعد از مرحله

$statment->execute();

چی میزنید که ارور میگیرید؟

pasha ( 545 تجربه )
3 هفته پیش

@Alimotreb ممنون از توجه‌ت علی جان. کد رو به این صورت نوشتم:

pasha ( 545 تجربه )
3 هفته پیش

<?php

try {
$dsn = "mysql:host=localhost;dbName=amir";
$PDO = new PDO($dsn, "root", "");

} catch (PDOException $e) {
die($e->getMessage());
}

$st = $PDO->prepare("SELECT * FROM users");
$res = $st->execute();
$result = $res->fetchAll(PDO::FETCH_OBJ);
print_r($result);
pasha ( 545 تجربه )
3 هفته پیش

البته ببخشید یکم بهم ریخته شد.
تشکر

Alimotreb ( 54862 تجربه )
3 هفته پیش

سلام مجدد
@amir.psh

ایرادی نداره
شما توی پرانتز رو خالی کنید

$result = $res->fetchAll();

مثال های بیشتر هم توی لینک زیر هست
https://www.php.net/manual/en/pdostatement.fetchall.php

اونی که شما نوشتید برای برگردوندن یه آبجکت هست
مثال هارو ببینید متوجه میشید خودتون.

pasha ( 545 تجربه )
3 هفته پیش

از اول هم توی پرانتز خالی بود، اینو یکم پیش اضافه کردم.
هرجور امتحان کردم، چه با prepare چه query این مشکلو دارم.
هر کاری میکنم به نتیجه نمیرسم.
شاید اشکال از xampp باشه

pasha ( 545 تجربه )
3 هفته پیش

@hesammousavi سلام اقای موسوی
میشه در این مورد راهنمایی کنید
@Alimotreb تشکر علی اقا، اما مشکل حل نشد

Alimotreb ( 54862 تجربه )
3 هفته پیش

سلام
@amir.psh

از فعال بودن pdo در ورژن PHP تون اطمینان داشته باشید
چیز خاصی نداره آخه! که دارید ارور میگیرید
یه phpinfo() بگیرید ببینید فعال هست!

pasha ( 545 تجربه )
3 هفته پیش

@Alimotreb ممنون علی اقا،
منم موندم چرا چیز به این سادگی کلا کار نمیکنه یا فقط یه آرایه خالی برمیگردونه.
حالا اگه pdo فعال نباشه چجوری باید فعال شه

Alimotreb ( 54862 تجربه )
3 هفته پیش

سلام
@amir.psh

خواهش میکنم
در فایل php.ini باید
extention های pdo نوشته شده
از حالت کامنت در بیارید تا فعال شه
; رو باید از اول خطشون پاک کنید
با نوت پد باز کنید
pdo رو سرچ کنید
هر کدوم کامنت بود از کامنت درش بیارید و وب سرور رو یه ریستارت کنید.

pasha ( 545 تجربه )
3 هفته پیش

متاسفانه اینکار رو هم کردم ولی جواب نداد.
شاید باید نسخه ی xampp رو عوض کنم

داود خانی ( 1928 تجربه )
3 هفته پیش

سلام خسته نباشی شما داری یه آبجکت بر می گردونی بهترین کار اینه که با یه for each اطلاعات رو چاپ کنی فکر نکنم دیگه ایراد بگیره اینم نمونه کد .شاید جواب بده

foreach ($result as $res){
echo $res;
}
pasha ( 545 تجربه )
3 هفته پیش

@davoodkhany
@Alimotreb
ممنون از توجه‌تون
اما مساله چیز دیگه‌یی بود ک خیلی اتفاقی فهمیدم. شاید باورتون نشه ولی اگه dbName رو‌ dbname مینوشتم درست کار میکرد! الان درست شده. من تو‌ یوتیوب یا جاهای دیگه دیده بودم که تو‌تعریف dsn هم dbname و‌هم dbName استفاده میکردن مشکلی پیش نمیومد.
حالا اینجا چرا اینجوری شد نمیدونم.
حتی خود phpstorm پیشنهاد میده که n رو‌ با حرف بزرگ بنویسیم. ولی با حرف کوچک کار میکنه
تشکر

Alimotreb ( 54862 تجربه )
3 هفته پیش

سلام
@amir.psh

من به قسمت کانکشنتون به دیتابیس نگاهی نکردم حقیقتا ، چون هم ارور راجب چیز دیگه ای بود
هم گفتم حتما از بقیه جاها خروجی گرفتید و فقط این خطتتون مشکل داره!
با حروف کوچیک اکثرا مینویسن!
خدا رو شکر که مشکل حل شد!

pasha ( 545 تجربه )
3 هفته پیش

@Alimotreb
خیلی مخلصم علی آقا
تشکر

Alimotreb ( 54862 تجربه )
2 هفته پیش

سلام
@amir.psh

زنده باشید

برای ارسال پاسخ باید وارد سایت شوید