পিএইচপি এসকিউএল ওয়ার্ডপ্রেস জাভাস্ক্রিপ্ট জেকুয়েরি এইচটিএমএল
লগইন
×

পিএইচপি টিউটোরিয়াল

হোম-HOME ইনস্টল-Install গঠনপ্রনালী-Syntax চলক-Variable পিএইচপি Echo / Print তথ্যের ধরণ-Data Types কনস্ট্যান্ট-Constant অপারেটর-Operator ফাংশন-Function সুপারগ্লোভাল-Superglobal

কন্ট্রোল স্টেটমেন্ট

if স্টেটমেন্ট if...Else স্টেটমেন্ট Switch স্টেটমেন্ট While লুপ DO...While লুপ For লুপ

পিএইচপি এ্যারে এবং স্ট্রিং

এ্যারে-Array এ্যারে সর্টিং -Array Sorting মাল্টি এ্যারে-Multi Array স্ট্রিং-String

পিএইচপি এডভান্স

তারিখ এবং সময় পিএইচপি include ফাইল হ্যান্ডলিং-File Handling ফাইল খোলা/পড়া ফাইল তৈরি/লিখা ফাইল আপলোড কুকি-Cookie সেশন-Session ফিল্টার-Filter এডভান্স ফিল্টার-Advance Filter এঁরর হ্যান্ডলিং-Error Handling এক্সেপশন হ্যান্ডেলিং-Exception Handling

পিএইচপি ফরম

ফরম হ্যান্ডলিং ফরম ভ্যালিডেশন আবশ্যক ফরম ফিল্ড ফরম URL/E-mail সম্পূর্ণ ফরম

MySQL ডেটাবেজ

MySQL ডেটাবেজ MySQL ডেটাবেজ সংযোগ MySQL ডেটাবেজ তৈরী MySQL টেবিল তৈরী MySQL তথ্য ইনসার্ট MySQL শেষ আইডি পান MySQL একাধিক তথ্য ইনসার্ট MySQL প্রিপেয়ার্ড স্টেটমেন্ট MySQL তথ্য সিলেক্ট MySQL তথ্য ডিলিট MySQL তথ্য আপডেট MySQL সীমিত তথ্য সিলেক্ট

পিএইচপি- এক্সএমএল

PHP XML Parser PHP SimpleXML Parser PHP XML Parser PHP SimpleXML - Get PHP XML Expat PHP XML Dom

পিএইচপি - এজাক্স

পিএইচপি AJAX পরিচিতি AJAX পিএইচপি AJAX ডেটাবেজ AJAX এক্সএমএল AJAX সারাসরি সার্চ AJAX RSS রির্ডার AJAX Poll

পিএইচপি অবজেক্ট অরিয়েন্টেড প্রোগ্রামিং(OOP)

OOP পরিচিতি OOP class তৈরী OOP objects তৈরী OOP $this কিওয়ার্ড OOP মেথড এবং প্রোপার্টি চেইনিং OOP অ্যাক্সেস মোডিফায়ার OOP ম্যাজিক মেথড এবং কন্সটেন্ট OOP ইনহেরিটেন্স OOP Abstract class এবং method OOP ইন্টারফেস OOP পলিমরফিজম OOP টাইপ হিন্টিং() OOP টাইপ হিন্টিনং ইন্টারফেস OOP স্ট্যাটিক মেথোড এবং প্রোপার্টি

পিএইচপি - রেফারেন্স

Array ফাংশন Calendar ফাংশন date/time ফাংশন Directory ফাংশন Error ফাংশন Filesystem ফাংশন Filter ফাংশন FTP ফাংশন HTTP ফাংশন libxml ফাংশন Mail ফাংশন Math ফাংশন Misc. ফাংশন MySQLi ফাংশন SimpleXML ফাংশন String ফাংশন XML Parser ফাংশন Zip File ফাংশন টাইমজোন Timezones
 

পিএইচপি MySQL থেকে তথ্য সিলেক্ট


SQL SELECT স্টেটমেন্ট ব্যবহার করে এক বা একাধিক টেবিল থেকে তথ্য সিলেক্ট করা যায়।

SELECT name_of_column's
FROM name_of_table

অথবা আমরা (*) ক্যারেক্টারটি ব্যবহার করে টেবিল থেকে সকল কলাম সিলেক্ট করতে পারি।

SELECT * FROM name_of_table

SQL সম্পর্কে আরো জানতে, আমাদের SQL টিউটোরিয়াল দেখুন।

নিম্নের উদাহরনটি "testTB" টেবিল থেকে id, firstname এবং lastname কলাম গুলো সিলেক্ট করবে এবং উক্ত পেজে প্রর্দশন করবেঃ

উদাহরণঃ MySQLi প্রসিডিউরাল প্রক্রিয়ায় MySQL থেকে তথ্য সিলেক্ট করা।
<?php
// সংযোগ তৈরি
$conn = mysqli_connect("localhost", "username", "password", "testDB");

// সংযোগ পরীক্ষা
if (!$conn) {
    die("সংযোগ ব্যর্থ হয়েছেঃ " . mysqli_connect_error());
}
//ডেটাবেজ থেকে তথ্য সিলেক্ট
$sql = "SELECT id, firstname, lastname FROM testTB";

// result ভ্যারিয়েবলে প্রাপ্ত তথ্য জমা 
$result = mysqli_query($conn, $sql);

// শুন্যের চেয়ে বেশি সারি আছে কিনা যাচাই 
if (mysqli_num_rows($result) > 0) {
    // প্রতিটি সারি থেকে প্রাপ্ত আউটপুট তথ্য
    while($row = mysqli_fetch_assoc($result)) {
        echo "id: " . $row["id"]. " - Name: " . $row["firstname"]. " " . $row["lastname"]. "<br>";
    }
} else {
    echo "০ ফলাফল।";
}

// সংযোগ বিচ্ছিন্ন
mysqli_close($conn);
?>

উদাহরণঃ MySQLi অব্জেক্ট-অরিয়েন্টেড প্রক্রিয়ায় MySQL থেকে তথ্য সিলেক্ট করা।
<?php
// সংযোগ তৈরি
$conn = new mysqli($servername, $username, $password, $databasename);

// সংযোগ পরীক্ষা
if ($conn->connect_error) {
    die("সংযোগ ব্যর্থ হয়েছেঃ " . $conn->connect_error);
}

//তথ্য সিলেক্ট 
$sql = "SELECT id, firstname, lastname FROM testTB";

// result ভ্যারিয়েবলে প্রাপ্ত তথ্য জমা 
$result = $conn->query($sql);

// শুন্যের চেয়ে বেশি সারি আছে কিনা যাচাই 
if ($result->num_rows > 0) {
    // প্রতিটি সারি থেকে প্রাপ্ত আউটপুট তথ্য
    while($row = $result->fetch_assoc()) {
        echo "id: " . $row["id"]. " - Name: " . $row["firstname"]. " " . $row["lastname"]. "<br>";
    }
} else {
    echo "০ ফলাফল।";
}

// সংযোগ বিচ্ছিন্ন
$conn->close();
?>

উপরের উদাহরনের কোড লাইনগুলো নিম্নে বর্ণনা করা হলোঃ

প্রথমত আমরা একটি সংযোগ তৈরি করেছি। তারপর সংযোগটি পরীক্ষা করেছি। তারপর একটি কুয়েরি করেছি যা "testTB" টেবিল থেকে "id", "firstname" এবং "lastname" কলাম গুলোকে সিলেক্ট করে। পরবর্তী লাইনে "$result" নামে একটি ভ্যারিয়েবল নেওয়া হয়েছে যাতে কুয়েরি থেকে প্রাপ্ত সকল তথ্য জমা হয়।

তারপর num_rows() ফাংশনটি পরীক্ষা করে দেখে এতে শূণ্যের চেয়ে বেশী ফলাফল আছে কিনা। যদি শূণ্যের চেয়ে বেশী ফলাফল থাকে সে ক্ষেত্রে fetch_assoc() ফাংশনটি ফলাফল গুলোকে আসোসিয়েটিভ(associative) অ্যারেতে(array) রূপান্তর করে। এর পরবর্তীতে এই আসোসিয়েটিভ(associative) অ্যারেটি(array) থেকে While loop এর মাধ্যমে ডেটাবেজ থেকে প্রাপ্ত "id", "firstname" এবং "lastname" কলামের তথ্য গুলোর আউটপুট পাই।


আপনি প্রাপ্ত তথ্য গুলোকে এইচটিএমএল টেবিল আকারে প্রদর্শন করাতে পারেনঃ

MySQLi অব্জেক্ট-অরিয়েন্টেড প্রক্রিয়াঃ

উদাহরণঃ MySQLi অব্জেক্ট-অরিয়েন্টেড প্রক্রিয়ায় তথ্য HTML টেবিলের মাধ্যমে দেখানো।
<?php
// সংযোগ তৈর
$conn = new mysqli("localhost", "username", "password", "testDB");

// সংযোগ পরীক্ষা
if ($conn->connect_error) {
    die("সংযোগ ব্যর্থ হয়েছেঃ " . $conn->connect_error);
}

//ডেটাবেজ থেকে তথ্য সিলেক্ট
$sql = "SELECT id, firstname, lastname FROM testTB";

// result ভ্যারিয়েবলে প্রাপ্ত তথ্য জমা 
$result = $conn->query($sql);

// শুন্যের চেয়ে বেশি সারি আছে কিনা যাচাই 
if ($result->num_rows > 0) {
    
    echo "<table><tr><th>ID</th><th>Name</th></tr>";
    
    // প্রতিটি সারি থেকে প্রাপ্ত আউটপুট তথ্য
    while($row = $result->fetch_assoc()) {
        
        echo "<tr><td>".$row["id"]."</td><td>".$row["firstname"]." ".$row["lastname"]."</td></tr>";
    }
    echo "</table>";
} else {
    echo "০ ফলাফল।";
}

// সংযোগ বিচ্ছিন্ন
$conn->close();
?>