{"id":397,"date":"2021-06-10T14:14:34","date_gmt":"2021-06-10T13:14:34","guid":{"rendered":"https:\/\/blogs.glowscotland.org.uk\/sh\/ahscomputinghtml\/?page_id=397"},"modified":"2021-06-10T15:50:51","modified_gmt":"2021-06-10T14:50:51","slug":"php-and-sql","status":"publish","type":"page","link":"https:\/\/blogs.glowscotland.org.uk\/sh\/ahscomputinghtml\/php\/php-and-sql\/","title":{"rendered":"PHP and SQL"},"content":{"rendered":"<p><img loading=\"lazy\" decoding=\"async\" class=\"alignright wp-image-196\" src=\"https:\/\/blogs.glowscotland.org.uk\/sh\/public\/ahscomputinghtml\/uploads\/sites\/3275\/2021\/06\/05211152\/sqa-ah.png\" alt=\"\" width=\"100\" height=\"97\" \/><a href=\"https:\/\/www.w3schools.com\/pHp\/php_mysql_intro.asp\" target=\"_blank\" rel=\"noopener noreferrer\"><img loading=\"lazy\" decoding=\"async\" class=\"image-59 alignright\" src=\"https:\/\/glow-prod-sh.s3.eu-west-1.amazonaws.com\/sh\/public\/ahscomputinghtml\/uploads\/sites\/3275\/2021\/06\/03210120\/w3schools-150x150.png?X-Amz-Content-Sha256=UNSIGNED-PAYLOAD&#038;X-Amz-Security-Token=IQoJb3JpZ2luX2VjEBMaCWV1LXdlc3QtMSJHMEUCIQD0Vr8hQ1iupr6Sk7YDAvIdWXmQU9yImHlfQRVEAhRhOwIgM3NyfAWM%2Fpvru%2BqytcC6hd4q5vsDJIJctB%2FLMh7%2FanQqwgUI2%2F%2F%2F%2F%2F%2F%2F%2F%2F%2F%2FARAFGgwyNzM1NzAxOTU0MzMiDMxkR4gri0JFQP3BoCqWBfmRX3yda3m7K5UcIxV%2B35hoBLvEOaOIuy89R1o8kILVXX8CO%2FgJ2MhdNLSrf8O7HT21Y5WD2p67qQVhnQwk3sOKoGB4lQAP00MR3R0Om8qr%2BkzJrpsIpbi%2BnizxyhHcAXpCmo0oAEVkY5Y8e%2B37eZqYm2k%2Fp6uEFQe%2BLEgYTcilNZWSdIO9jGMIhUNGB%2FN9fidOLDDR9ByyHTLVvHMsO1Smwd3JCBZS237w%2BQcw2GJQ%2BjsOwd0mP4KxJR3gluAalr6TMqqccIXJR%2FZ876yx3HcVsn2B71m6d3GyG5%2BL3kFRLyLAYYz54xas1PHD7298Cmri6sxpg04a%2F60bJm0KeEJ9RIxBslYo2xhMnQK1va%2Fyo9yzhKasiBTNY7lwO%2BgFcfYbDOZ3mjlrvGmyuTbPuSrgUBMxugmmBTtXvpVi0Zc796Os1Ao6zpjCqajt3dyyCmTENT5AWDUcXdGqdvFzw3%2FIvF9bSatk7rZk%2FA8VIS5KuS6NK7j1z6azLO6%2B%2BDSwY8zBCtb53WnY4yl4KhLxpGXBHnJWh%2FT8h%2BcaFFY%2Bl0na4GvBi%2FtYoIkaR1Sn4BwvamH8q1kOLQwJ35Z0nhqOcCef0DseY51XTmrOyctG1SLC14i3AE%2BD0wdVxWqPdylIAVhOwEmPjFubOnv2UkK1bzPTAzUMoTNzahwSozAP54VlP2F1gV3vtIOIROs%2F7LhlDIuXHfew8BtyGrpEkAPosxRHZBYEixUfw7nOhrB5DA1JayVqZySmbPOJQNHJVyhdxWfY2UlKqTeWa%2F3QQibwYcZHSLRnlkmxWGOz0pklE7B3uyevwuLM9KIyc4j%2F1sH83hEQOJjPSDMGaYKRaZyuMxVlNdrMsEKSPmJ5MIdfiS7SmSoO5hZyMLfQk9IGOrEBNZJal6sSUwwUJ6WKlQNPgh5p%2Fyf04xrXBTWg3D3cY9FuHUqUfJwwFXy4IqoM9LL57YbvFU9LgBy2MQ7CovIdQtg8hFmm8ueIP1KMZyzi5tpOKE%2BYimoNS4yUaBKwu%2FrhaZ58ynTrxGjRHQcnbHzrV7nC24xmCPoFJ89Cs1es9JeIMangJcigrAVTCAxbBbv0aQBhJX3wA1nYSiJ9Y865ufYwlrhSKqCPr1QUdpdGvIxl&#038;X-Amz-Algorithm=AWS4-HMAC-SHA256&#038;X-Amz-Credential=ASIAT7MQN47UU6UKAH6R%2F20260701%2Feu-west-1%2Fs3%2Faws4_request&#038;X-Amz-Date=20260701T103449Z&#038;X-Amz-SignedHeaders=host&#038;X-Amz-Expires=900&#038;X-Amz-Signature=10d08ff072a357597f51cd5fc0fe3e6dc0126f1375af819ba569575517e8bfab\" alt=\"\" width=\"50\" height=\"47\" \/><\/a>PHP is often to use form data to read from, or update, SQL databases.<\/p>\n<h1>Database Connection<\/h1>\n<p>Remember the order of parameters &#8211; you connect to the <strong>server<\/strong> with your <strong>name<\/strong> and <strong>password.<\/strong> Then you select the <strong>database<\/strong> to be used.<\/p>\n<p>In this example, three possible responses are given to a connection failure &#8211; it would be unlikely to use all three.<\/p>\n<pre class=\"brush: php; title: PHP; notranslate\" title=\"PHP\">\r\n$servername = &quot;localhost&quot;;\r\n$username = &quot;root&quot;;\r\n$password = &quot;&quot;;\r\n$dbname = &quot;studentlist&quot;;\r\n\r\n$conn = mysqli_connect($servername, $username, $password, $dbname);\r\n\r\nif (!$conn) {\r\n    echo '&lt;img src=&quot;data:image\/gif;base64,R0lGODlhAQABAIAAAAAAAP\/\/\/yH5BAEAAAAALAAAAAABAAEAAAIBRAA7&quot; data-wp-preserve=&quot;%3Cscript%3Ealert(%22Error%20inserting%20data%22)%3B%3C%2Fscript%3E&quot; data-mce-resize=&quot;false&quot; data-mce-placeholder=&quot;1&quot; class=&quot;mce-object&quot; width=&quot;20&quot; height=&quot;20&quot; alt=&quot;&amp;lt;script&amp;gt;&quot; title=&quot;&amp;lt;script&amp;gt;&quot; \/&gt;'; \/\/ pop-up message\r\n    &lt;p&gt;Error inserting data&lt;\/p&gt; die(&quot;Error adding data&quot;);   \/\/ error on page\r\n    die(&quot;Connection to database failed&quot;);                   \/\/ halt script\r\n}\r\n<\/pre>\n<p>At the end of the script, the database connection should be closed:<\/p>\n<pre class=\"brush: php; title: PHP; notranslate\" title=\"PHP\">\r\nmysqli_close($conn);\r\n<\/pre>\n<h1>SQL Insert\/Update\/Delete<\/h1>\n<p>These SQL queries retrun a Boolean True\/False result that can be used to check for success:<\/p>\n<pre class=\"brush: php; title: PHP; notranslate\" title=\"PHP\">\r\n$sql = &quot;INSERT INTO students VALUES ($forename, $surname);\r\n$result = mysqli_query($conn, $sql);\r\nif (!result) { \r\n    echo '&lt;img src=&quot;data:image\/gif;base64,R0lGODlhAQABAIAAAAAAAP\/\/\/yH5BAEAAAAALAAAAAABAAEAAAIBRAA7&quot; data-wp-preserve=&quot;%3Cscript%3Ealert(%22Error%20inserting%20data%22)%3B%3C%2Fscript%3E&quot; data-mce-resize=&quot;false&quot; data-mce-placeholder=&quot;1&quot; class=&quot;mce-object&quot; width=&quot;20&quot; height=&quot;20&quot; alt=&quot;&amp;lt;script&amp;gt;&quot; title=&quot;&amp;lt;script&amp;gt;&quot; \/&gt;';\r\n}\r\n<\/pre>\n<h1>SQL Select<\/h1>\n<p>Select queries return will 0, 1 or more records:<\/p>\n<pre class=\"brush: php; title: PHP; notranslate\" title=\"PHP\">\r\n$sql = &quot;SELECT forename, surname FROM students&quot;;\r\n$result = mysqli_query($conn, $sql);\r\n \r\n$studentsFound = mysqli_num_rows($result);\r\nif ($studentsFound &gt;= 0) {\r\n    echo &quot;&lt;table&gt;&quot;;\r\n    while($row = mysqli_fetch_array($result)) {\r\n        echo &quot;&lt;tr&gt;&lt;td&quot; . $row&#x5B;&quot;forename&quot;] . &quot;&lt;\/td&gt;&lt;td&gt;&quot; . $row&#x5B;&quot;surname&quot;] . &quot;&lt;\/td&gt;&lt;\/tr&gt;&quot;;\r\n    echo &quot;\/table&gt;&quot;;\r\n} else {\r\n    echo &quot;&lt;p&gt;No results found&lt;\/p&gt;&quot;\r\n}\r\n\r\n<\/pre>\n","protected":false},"excerpt":{"rendered":"<p>PHP is often to use form data to read from, or update, SQL databases. Database Connection Remember the order of parameters &#8211; you connect to the server with your name and password. Then you select the database to be used. In this example, three possible responses are given to a connection failure &#8211; it would be unlikely to use all three. $servername = &quot;localhost&quot;; $username = &quot;root&quot;; $password = &quot;&quot;;<\/p>\n<p><a class=\"more-link\" href=\"https:\/\/blogs.glowscotland.org.uk\/sh\/ahscomputinghtml\/php\/php-and-sql\/\">Read More<\/a><\/p>\n","protected":false},"author":7,"featured_media":0,"parent":343,"menu_order":0,"comment_status":"closed","ping_status":"closed","template":"","meta":{"footnotes":""},"class_list":["post-397","page","type-page","status-publish","hentry"],"_links":{"self":[{"href":"https:\/\/blogs.glowscotland.org.uk\/sh\/ahscomputinghtml\/wp-json\/wp\/v2\/pages\/397","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/blogs.glowscotland.org.uk\/sh\/ahscomputinghtml\/wp-json\/wp\/v2\/pages"}],"about":[{"href":"https:\/\/blogs.glowscotland.org.uk\/sh\/ahscomputinghtml\/wp-json\/wp\/v2\/types\/page"}],"author":[{"embeddable":true,"href":"https:\/\/blogs.glowscotland.org.uk\/sh\/ahscomputinghtml\/wp-json\/wp\/v2\/users\/7"}],"replies":[{"embeddable":true,"href":"https:\/\/blogs.glowscotland.org.uk\/sh\/ahscomputinghtml\/wp-json\/wp\/v2\/comments?post=397"}],"version-history":[{"count":9,"href":"https:\/\/blogs.glowscotland.org.uk\/sh\/ahscomputinghtml\/wp-json\/wp\/v2\/pages\/397\/revisions"}],"predecessor-version":[{"id":424,"href":"https:\/\/blogs.glowscotland.org.uk\/sh\/ahscomputinghtml\/wp-json\/wp\/v2\/pages\/397\/revisions\/424"}],"up":[{"embeddable":true,"href":"https:\/\/blogs.glowscotland.org.uk\/sh\/ahscomputinghtml\/wp-json\/wp\/v2\/pages\/343"}],"wp:attachment":[{"href":"https:\/\/blogs.glowscotland.org.uk\/sh\/ahscomputinghtml\/wp-json\/wp\/v2\/media?parent=397"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}