با عرض سلام و وقت به خیر خدمت کاربران سایت پی وی لرن و کاربرانی که دوره ی آموزش php 7 را دنبال می کنند.
در جلسه گذشته به آموزش کار با دستور Prepared پرداختیم و آموختیم که یک دستور prepared در واقع ویژگی ای است که برای یک دستور SQL را با کارایی بالایی مکرراً اجرا می کند و ویژگی های خوبی دارد که اجرای SQL را تسهیل می نماید.
در ادامه آموزش انتخاب داده از MySQL در php 7 را ارائه می نماییم.
دستور SELECT برای انتخاب داده ها از یک یا چند جدول استفاده می شود:
1 | SELECT column_name(s) FROM table_name |
یا ما می توانیم کاراکتر * برای انتخاب تمام ستون ها از جدول استفاده کنیم:
1 | SELECT * FROM table_name |
اگر هنوز با SQL آشنایی ندارید می توانید به دوره آموزش کامل SQL پی وی لرن سری بزنید!
مثال زیر، ستون ID، نام و نام خانوادگی را از جدول MyGuests انتخاب می کند و آن را در صفحه نمایش می دهد:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | <?php $servername = "localhost"; $username = "username"; $password = "password"; $dbname = "myDB"; // Create connection $conn = new mysqli($servername, $username, $password, $dbname); // Check connection if ($conn->connect_error) { die("Connection failed: " . $conn->connect_error); } $sql = "SELECT id, firstname, lastname FROM MyGuests"; $result = $conn->query($sql); if ($result->num_rows > 0) { // output data of each row while($row = $result->fetch_assoc()) { echo "id: " . $row["id"]. " - Name: " . $row["firstname"]. " " . $row["lastname"]. "<br>"; } } else { echo "0 results"; } $conn->close(); ?> |
توضیح کدهای مثال بالا:
ابتدا، ما یک کوئری SQL ایجاد می کنیم که ستون ID، نام و نام خانوادگی را از جدول MyGuests انتخاب می کند.
خط بعدی کد، کوئری را اجرا می کند و داده های حاصل را به یک متغیر به نام result$ می دهد.
سپس، تابع ()num_rows بررسی می کند که آیا بیش از صفر ردیف بازگشتی وجود دارد یا خیر.
اگر بیش از یک ردیف صفر بازگردانی شود، تابع ()fetch_assoc تمام نتایج را به یک آرایه انجمنی می رساند که ما می توانیم آن را حلقه کنیم.
حلقه ()while در طول نتیجه و خروجی داده از id را از ستون نام و نام خانوادگی حلقه می کند.
مثال زیر نحوه استفاده از MySQLi را نشان می دهد:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | <?php $servername = "localhost"; $username = "username"; $password = "password"; $dbname = "myDB"; // Create connection $conn = mysqli_connect($servername, $username, $password, $dbname); // Check connection if (!$conn) { die("Connection failed: " . mysqli_connect_error()); } $sql = "SELECT id, firstname, lastname FROM MyGuests"; $result = mysqli_query($conn, $sql); if (mysqli_num_rows($result) > 0) { // output data of each row while($row = mysqli_fetch_assoc($result)) { echo "id: " . $row["id"]. " - Name: " . $row["firstname"]. " " . $row["lastname"]. "<br>"; } } else { echo "0 results"; } mysqli_close($conn); ?> |
علاوه بر این می توانید نتیجه را در یک جدول HTML قرار دهید:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | <?php $servername = "localhost"; $username = "username"; $password = "password"; $dbname = "myDB"; // Create connection $conn = new mysqli($servername, $username, $password, $dbname); // Check connection if ($conn->connect_error) { die("Connection failed: " . $conn->connect_error); } $sql = "SELECT id, firstname, lastname FROM MyGuests"; $result = $conn->query($sql); if ($result->num_rows > 0) { echo "<table><tr><th>ID</th><th>Name</th></tr>"; // output data of each row while($row = $result->fetch_assoc()) { echo "<tr><td>".$row["id"]."</td><td>".$row["firstname"]." ".$row["lastname"]."</td></tr>"; } echo "</table>"; } else { echo "0 results"; } $conn->close(); ?> |
در مثال زیر از دستور prepared استفاده شده است.
این ستون ID، نام خانوادگی و نام خانوادگی را از جدول MyGuests انتخاب می کند و آن را در یک جدول HTML نمایش می دهد:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 | <?php echo "<table style='border: solid 1px black;'>"; echo "<tr><th>Id</th><th>Firstname</th><th>Lastname</th></tr>"; class TableRows extends RecursiveIteratorIterator { function __construct($it) { parent::__construct($it, self::LEAVES_ONLY); } function current() { return "<td style='width:150px;border:1px solid black;'>" . parent::current(). "</td>"; } function beginChildren() { echo "<tr>"; } function endChildren() { echo "</tr>" . "\n"; } } $servername = "localhost"; $username = "username"; $password = "password"; $dbname = "myDBPDO"; try { $conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password); $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $stmt = $conn->prepare("SELECT id, firstname, lastname FROM MyGuests"); $stmt->execute(); // set the resulting array to associative $result = $stmt->setFetchMode(PDO::FETCH_ASSOC); foreach(new TableRows(new RecursiveArrayIterator($stmt->fetchAll())) as $k=>$v) { echo $v; } } catch(PDOException $e) { echo "Error: " . $e->getMessage(); } $conn = null; echo "</table>"; ?> |
در این جلسه آموزش انتخاب داده از MySQL در php 7 را به علاقمندان این دوره ارائه کردیم.
در جلسه بعدی به آموزش حذف داده از MySQL در php 7 می پردازیم.
با پی وی لرن همراه باشید.