You are on page 1of 25

‫ﻣﺘﺮﺟﻢ ﻣﻦ ﺍﻹﻧﺠﻠﻴﺰﻳﺔ ﺇﻟﻰ ﺍﻟﻌﺮﺑﻴﺔ ‪www.onlinedoctranslator.

com -‬‬

‫ﺗﻘﻨﻴﺎﺕﺍﻟﻮﻳﺐ ‪2‬‬
‫ﻗﺎﻋﺪﺓﺍﻟﺒﻴﺎﻧﺎﺕ ﻓﻲ ‪php‬‬
‫‪Lec7‬‬

‫‪1‬‬
‫ﻣﺤﻤﺪ‬
‫ﺑﻲﺃﺗﺶ ﺑﻲ‬

‫• ﻳﻤﻜﻨﻚ ﺍﻻﺗﺼﺎﻝ ﺑﻘﻮﺍﻋﺪ ﺍﻟﺒﻴﺎﻧﺎﺕ ﻭﻣﻌﺎﻟﺠﺘﻬﺎ‪.‬‬

‫‪• MySQL‬ﻫﻮ ﺃﻛﺜﺮ ﺃﻧﻈﻤﺔ ﻗﻮﺍﻋﺪ ﺍﻟﺒﻴﺎﻧﺎﺕ ﺷﻴﻮﻋﺎً‬


‫ﺍﻟﻤﺴﺘﺨﺪﻣﺔﻣﻊ ‪.PHP‬‬

‫‪2‬‬
‫ﻣﺎﻫﻲ ‪MySQL‬؟‬
‫ﻫﻮﻧﻈﺎﻡ ﻗﺎﻋﺪﺓ ﺑﻴﺎﻧﺎﺕ ﻳﺴﺘﺨﺪﻡ ﻋﻠﻰ ﺍﻟﻮﻳﺐ ‪• MySQL‬‬

‫ﻫﻮﻧﻈﺎﻡ ﻗﺎﻋﺪﺓ ﺑﻴﺎﻧﺎﺕ ﻳﻌﻤﻞ ﻋﻠﻰ ﺍﻟﺨﺎﺩﻡ ‪• MySQL‬‬

‫• ﺗﻌﺪ ‪ MySQL‬ﻣﺜﺎﻟﻴﺔ ﻟﻜﻞ ﻣﻦ ﺍﻟﺘﻄﺒﻴﻘﺎﺕ ﺍﻟﺼﻐﻴﺮﺓ‬


‫ﻭﺍﻟﻜﺒﻴﺮﺓ‬
‫ﺳﺮﻳﻊﺟﺪﺍً ﻭﻣﻮﺛﻮﻕ ﺑﻪ ﻭﺳﻬﻞ ﺍﻻﺳﺘﺨﺪﺍﻡ ‪• MySQL‬‬
‫• ﻳﺴﺘﺨﺪﻡ ‪ MySQL‬ﻣﻌﻴﺎﺭ ‪SQL‬‬
‫ﻳﺠﻤﻊﻋﻠﻰ ﻋﺪﺩ ﻣﻦ ﺍﻟﻤﻨﺼﺎﺕ ‪• MySQL‬‬
‫ﻣﺠﺎﻧﻲﻟﻠﺘﻨﺰﻳﻞ ﻭﺍﻻﺳﺘﺨﺪﺍﻡ ‪• MySQL‬‬
‫‪3‬‬
‫ﻣﺎﻫﻲ ‪MySQL‬؟‬
‫• ﻳﺘﻢ ﺗﺨﺰﻳﻦ ﺍﻟﺒﻴﺎﻧﺎﺕ ﺍﻟﻤﻮﺟﻮﺩﺓ ﻓﻲ ﻗﺎﻋﺪﺓ ﺑﻴﺎﻧﺎﺕ ‪MySQL‬‬
‫ﺑﺘﻨﺴﻴﻖ ﺍﻟﺠﺪﺍﻭﻝ‪ .‬ﺍﻟﺠﺪﻭﻝ ﻫﻮﺟﻤﻊ ﺍﻟﺒﻴﺎﻧﺎﺕ ﺫﺍﺕ ﺍﻟﺼﻠﺔ‬
‫‪،‬ﻭﺗﺘﻜﻮﻥ ﻣﻦﺍﻷﻋﻤﺪﺓﻭﺻﻔﻮﻑ‪.‬‬

‫• ﻗﻮﺍﻋﺪ ﺍﻟﺒﻴﺎﻧﺎﺕ ﻣﻔﻴﺪﺓ ﻟﺘﺨﺰﻳﻦ ﺍﻟﻤﻌﻠﻮﻣﺎﺕ ﺑﺸﻜﻞ ﻗﺎﻃﻊ‪.‬‬

‫‪-‬ﺍﻟﻤﻮﻇﻔﻴﻦ‬
‫‪-‬ﻣﻨﺘﺠﺎﺕ‬
‫‪-‬ﻋﻤﻼء‬
‫‪-‬ﺍﻟﻄﻠﺐ ‪s ٪#‬‬

‫‪4‬‬
‫‪ MySQL‬ﻧﻈﺎﻡ ﻗﺎﻋﺪﺓ ﺑﻴﺎﻧﺎﺕ ‪PHP +‬‬
‫‪ MySQL‬ﻣﺠﺘﻤﻌﺔ ﻣﻊ ‪• PHP‬ﻛﺮﻭﺱ ﺑﻼﺗﻔﻮﺭﻡ‪.‬‬

‫• ﻳﻤﻜﻦ ﺃﻥ ﺗﻌﻤﻞ ‪ PHP 5‬ﻭﺍﻹﺻﺪﺍﺭﺍﺕ ﺍﻷﺣﺪﺙ ﻣﻊ ﻗﺎﻋﺪﺓ ﺑﻴﺎﻧﺎﺕ‬


‫‪ MySQL‬ﺑﺎﺳﺘﺨﺪﺍﻡ‪:‬‬
‫‪- MySQLi‬ﺍﻟﺘﻤﺪﻳﺪ )ﺍﻟﺤﺮﻑ "‪ "i‬ﻳﺸﻴﺮ ﺇﻟﻰ ﺍﻟﻤﺤﺴﻦ(‬
‫‪)- PDO‬ﻛﺎﺉﻨﺎﺕ ﺑﻴﺎﻧﺎﺕ ‪(PHP‬‬

‫‪5‬‬
‫ﻫﻞﻳﺠﺐ ﻋﻠﻲ ﺍﺳﺘﺨﺪﺍﻡ ‪ MySQLi‬ﺃﻭ ‪PDO‬؟‬

‫• ﺳﺘﻌﻤﻞ ‪ PDO‬ﻋﻠﻰ ‪ 12‬ﻧﻈﺎﻡ ﻗﺎﻋﺪﺓ ﺑﻴﺎﻧﺎﺕ‬


‫ﻣﺨﺘﻠﻒ ‪،‬ﺑﻴﻨﻤﺎ ‪ MySQLi‬ﺳﺘﻌﻤﻞ ﻓﻘﻂ ﻣﻊ ﻗﻮﺍﻋﺪ‬
‫ﺑﻴﺎﻧﺎﺕ‪ ، MySQL‬ﻟﺬﻟﻚ ﺇﺫﺍ ﻛﺎﻥ ﻋﻠﻴﻚ ﺗﺒﺪﻳﻞ‬
‫ﻣﺸﺮﻭﻋﻚﻻﺳﺘﺨﺪﺍﻡ ﻗﺎﻋﺪﺓ ﺑﻴﺎﻧﺎﺕ ﺃﺧﺮﻯ ‪ ،‬ﻓﺈﻥ ‪PDO‬‬
‫ﺗﺠﻌﻞﺍﻟﻌﻤﻠﻴﺔ ﺳﻬﻠﺔ‪.‬‬

‫‪6‬‬
‫ﺍﺳﺘﻌﻼﻣﺎﺕﻗﺎﻋﺪﺓ ﺍﻟﺒﻴﺎﻧﺎﺕ‬

‫• ﺍﻻﺳﺘﻌﻼﻡ ﻫﻮﺳﺆﺍﻝ ﺃﻭ ﻃﻠﺐ‪.‬‬


‫• ﻳﻤﻜﻨﻨﺎ ﺍﻻﺳﺘﻌﻼﻡ ﻋﻦ ﻗﺎﻋﺪﺓ ﺑﻴﺎﻧﺎﺕ ﻟﻠﺤﺼﻮﻝ ﻋﻠﻰ‬
‫ﻣﻌﻠﻮﻣﺎﺕﻣﺤﺪﺩﺓ ﻭﺇﺭﺟﺎﻉ ﻣﺠﻤﻮﻋﺔ ﺳﺠﻼﺕ‪.‬‬
‫‪-‬ﺍﺧﺘﺮ * ﻣﻦ ﺍﻟﻄﻼﺏ‪.‬‬

‫‪7‬‬
‫ﺍﻟﺘﻌﺎﻣﻞﻣﻊ ﺍﻟﻨﻤﺎﺫﺝ‬
(POST ‫ ﻭ‬GET) HTML ‫• ﻧﻤﺎﺫﺝ‬
PHP ‫• ﻳﺘﻢ ﺇﺭﺳﺎﻝ ﺍﻟﻨﻤﻮﺫﺝ ﺇﻟﻰ ﺑﺮﻧﺎﻣﺞ ﻧﺼﻲ‬
‫• ﻳﺘﻢ ﺗﻮﻓﻴﺮ ﺍﻟﻤﻌﻠﻮﻣﺎﺕ ﻣﻦ ﻫﺬﺍ ﺍﻟﻨﻤﻮﺫﺝ ﺗﻠﻘﺎﺉﻴﺎً ﻟﻠﻨﺺ‬

php .‫ﺃﺷﻜﺎﻝ‬-

>form action = "foo.php" method = "POST"<


‫< ﺍﻟﺒﺮﻳﺪ‬input type = "text" name = "username"< >br>:‫ﺍﻻﺳﻢ‬
>input type = "submit" name = "submit" value>:‫ﺍﻹﻟﻜﺘﺮﻭﻧﻲ‬
<"!‫ = "ﺃﺭﺳﻞ ﻟﻲ‬input type = "text" name = "email"< >br<
>/form<

8
PHP ‫ﻟﻠﻮﺻﻮﻝﺇﻟﻰ ﻗﺎﻋﺪﺓ ﺍﻟﺒﻴﺎﻧﺎﺕ‬

MySQL ‫• ﺍﻻﺗﺼﺎﻝ ﺑﺨﺎﺩﻡ‬


، $ username، $ password( = $ ‫ﺍﺗﺼﺎﻝ‬-
‫؛‬mysql_connect )"localhost"
‫• ﺍﻟﻮﺻﻮﻝ ﺇﻟﻰ ﻗﺎﻋﺪﺓ ﺍﻟﺒﻴﺎﻧﺎﺕ‬
- mysql_select_db )"moh"، $ connection( ‫؛‬
SQL ‫• ﺇﺟﺮﺍء ﻋﻤﻠﻴﺎﺕ‬
‫• ﻗﻄﻊ ﺍﻻﺗﺼﺎﻝ ﺑﺎﻟﺨﺎﺩﻡ‬
- mysql_close )$ connection( ‫؛‬

9
‫ﻟﻠﻮﺻﻮﻝﺇﻟﻰ ﻗﺎﻋﺪﺓ ﺍﻟﺒﻴﺎﻧﺎﺕ ‪PHP‬‬
‫>؟ ‪php‬‬
‫؛ﺍﺳﻢ ﺍﻟﻤﺴﺘﺨﺪﻡ ‪" = $‬ﺍﺳﻢ‬
‫ﺍﻟﻤﺴﺘﺨﺪﻡ" ؛ ﻛﻠﻤﺔ ﺍﻟﻤﺮﻭﺭ ‪" = $‬‬
‫ﻛﻠﻤﺔﺍﻟﻤﺮﻭﺭ" ؛ ‪ //‬ﺇﻧﺸﺎء ﺍﺗﺼﺎﻝ‬
‫"‪$ servername = "localhost‬‬
‫؛ (‪ $‬ﺍﺳﻢ ﺍﻟﺨﺎﺩﻡ ‪ ، $‬ﺍﺳﻢ ﺍﻟﻤﺴﺘﺨﺪﻡ ‪ ، $‬ﻛﻠﻤﺔ ﺍﻟﻤﺮﻭﺭ‬
‫) ‪$ conn = mysqli_connect‬‬
‫‪ //‬ﺗﻔﻘﺪ ﺍﻹﺗﺼﺎﻝ‬
‫ﺇﺫﺍ)! ‪} (conn $‬‬
‫ﻳﻤﻮﺕ)"ﻓﺸﻞ ﺍﻻﺗﺼﺎﻝ‪ (() mysqli_connect_error .":‬؛‬
‫{‬
‫ﺻﺪﻯ"ﻣﺘﺼﻞ ﺑﻨﺠﺎﺡ" ؛ ؟<‬
‫‪10‬‬
‫ﻣﻌﺎﻟﺠﺔﺍﻷﺧﻄﺎء‬
‫• ﺟﻤﻴﻊ ﺩﻭﺍﻝ ‪ _mysql‬ﺗﺮﺟﻊ ‪) NULL‬ﺃﻭ ‪ (false‬ﺇﺫﺍ‬
‫ﻓﺸﻠﺖ‪.‬‬

‫• ﻋﺪﺓ ﻭﻇﺎﺉﻒ ﻣﻔﻴﺪﺓ ﻓﻲ ﻓﺸﻞ ﺭﺷﻴﻖ‬

‫‪-‬ﻣﻮﺕ)ﺳﻠﺴﻠﺔ( ‪ -‬ﺗﻮﻗﻒ ﻭﻋﺮﺽ ﺍﻟﺴﻠﺴﻠﺔ‬


‫() ‪ -- mysql_errno‬ﺇﺭﺟﺎﻉ ﺭﻗﻢ ﺍﻟﺨﻄﺄ‬
‫‪-‬ﺍﻟﺨﻠﻴﺔ ﺧﻄﺄ)(‪ -‬ﺇﺭﺟﺎﻉ ﻧﺺ ﺍﻟﺨﻄﺄ‬

‫‪11‬‬
‫ﺃﻣﺜﻠﺔﻋﻠﻰ ﻣﻌﺎﻟﺠﺔ ﺍﻷﺧﻄﺎء‬

، $ name، $ passwd( $) !)‫ﺇﺫﺍ‬


((connection = mysql_connect )"localhost"
‫ﻳﻤﻮﺕ)"ﺗﻌﺬﺭ ﺍﻻﺗﺼﺎﻝ"( ؛‬
() ‫ﻭﻇﻴﻔﺔﺍﻟﺪﺵ‬
}
(() mysql_errno )(. ":". mysql_error ."‫ﻳﻤﻮﺕ)"ﺧﻄﺄ‬
‫؛‬
{
((mysql_select_db )"winestor"، $ connection() !)‫ﺇﺫﺍ‬
‫ﺩﺵﺭﻋﺐ )( ؛‬
12
‫ﺑﻨﺎءﺍﺳﺘﻌﻼﻡ‬
‫• ﻣﺒﺎﺷﺮﺓ‬
‫‪-‬ﺍﺳﺘﻌﻼﻡ ‪' = $‬ﺍﺧﺘﺮ * ﻣﻦ ﺍﻟﻨﺒﻴﺬ' ؛‬
‫• ﺍﺳﺘﺨﺪﺍﻡ ﻣﻌﻠﻮﻣﺎﺕ ﺍﻹﺩﺧﺎﻝ‬
‫‪-‬ﻣﺼﻨﻊ ﺍﻟﺨﻤﺮﺓ ﺑﺎﻟﺪﻭﻻﺭ = ‪'] POST_ $‬ﺍﻟﺨﻤﺮﺓ'[ ؛‬

‫‪-‬ﺍﻻﺳﺘﻌﻼﻡ ‪" = $‬ﺍﺧﺘﺮ * ﻣﻦ ﺍﻟﺨﻤﻮﺭ ﺣﻴﺚ ﺍﻟﺨﻤﺮﺓ =‬


‫ﻣﺼﻨﻊﺍﻟﺨﻤﺮﺓ ﺑﺎﻟﺪﻭﻻﺭ" ؛‬

‫‪13‬‬
‫ﺣﺪﺩﺍﻟﺒﻴﺎﻧﺎﺕ ‪PHP MySQL‬‬
‫• ﻳﺘﻢ ﺍﺳﺘﺨﺪﺍﻡ ﻋﺒﺎﺭﺓ ‪ SELECT‬ﻟﺘﺤﺪﻳﺪ ﺍﻟﺒﻴﺎﻧﺎﺕ ﻣﻦ‬
‫ﺟﺪﻭﻝﻭﺍﺣﺪ ﺃﻭ ﺃﻛﺜﺮ‬

‫• ﺣﺪﺩ ﺍﺳﻢ )ﺃﺳﻤﺎء( ﺍﻟﻌﻤﻮﺩ ﻣﻦ ﺍﺳﻢ_‬


‫ﺍﻟﺠﺪﻭﻝ‬

‫‪14‬‬
‫ ﺍﻻﺳﻢ ﺍﻷﺧﻴﺮ‬، ‫ ﺍﻻﺳﻢ ﺍﻷﻭﻝ‬، ‫ ﻣﻌﺮﻑ ﺍﻟﺘﺤﺪﻳﺪ‬MyGuests"‫؛‬
$ sql = "‫ﻣﻦ‬
‫ ؛‬mysqli_query )$ conn، $ sql( = $‫ﻧﺘﻴﺠﺔ‬
} (mysqli_num_rows )$ result(< 0)‫ﺇﺫﺍ‬
‫ ﺑﻴﺎﻧﺎﺕ ﺍﻹﺧﺮﺍﺝ ﻟﻜﻞ ﺻﻒ‬//
while )$ row = mysqli_fetch_assoc )$ result(( }
$ ."" .["‫ ]"ﺍﻻﺳﻢ ﺍﻷﻭﻝ‬row $ . " :‫ ﺍﺳﻢ‬- " .row ]"id"[ $ .":‫ﺻﺪﻯ"ﻣﻌﺮﻑ‬
‫<" ؛‬row ]"lastname"[. ">br
{
} ‫{ ﺁﺧﺮ‬
‫ ﻧﺘﺎﺉﺞ" ؛‬0"‫ﺻﺪﻯ‬
{
mysqli_close )$ conn( ‫؛‬
15 <‫؟‬
‫ﺣﺪﺩﺍﻟﺒﻴﺎﻧﺎﺕ ‪PHP MySQL‬‬
‫• ﺍﻟﻮﻇﻴﻔﺔﻋﺪﺩ_ﺍﻟﺼﻔﻮﻑ )(ﻳﺘﺤﻘﻖ ﻣﻤﺎ ﺇﺫﺍ ﻛﺎﻥ ﻫﻨﺎﻙ‬
‫ﺃﻛﺜﺮﻣﻦ ﺻﻔﺮ ﺻﻔﻮﻑ ﺗﻢ ﺇﺭﺟﺎﻋﻬﺎ‪.‬‬

‫• ﺇﺫﺍ ﻛﺎﻥ ﻫﻨﺎﻙ ﺃﻛﺜﺮ ﻣﻦ ﺻﻔﺮ ﻣﻦ ﺍﻟﺼﻔﻮﻑ ‪ ،‬ﻳﺘﻢ ﺇﺭﺟﺎﻉ‬


‫ﺍﻟﻮﻇﻴﻔﺔ() ‪fetch_assoc‬ﻳﻀﻊ ﺟﻤﻴﻊ ﺍﻟﻨﺘﺎﺉﺞ ﻓﻲ‬
‫ﻣﺼﻔﻮﻓﺔﺗﺮﺍﺑﻄﻴﺔ ﻳﻤﻜﻨﻨﺎ ﺗﻜﺮﺍﺭﻫﺎ‪ .‬ﺍﻝﻓﻲ ﺣﻴﻦ)(ﺣﻠﻘﺎﺕ‬
‫ﺣﻠﻘﺔﻣﻦ ﺧﻼﻝ ﻣﺠﻤﻮﻋﺔ ﺍﻟﻨﺘﺎﺉﺞ‬

‫‪16‬‬
‫ﺗﺸﻐﻴﻞﺍﺳﺘﻌﻼﻡ‬
‫• ﺇﺭﺟﺎﻉ ‪ mysql_query‬ﻣﻌﺎﻟﺠﺔ ﺍﻟﻨﺘﻴﺠﺔ‬
‫‪-‬ﺍﻟﻨﺘﻴﺠﺔ ‪)mysql_query= $‬ﺍﺳﺘﻌﻼﻡ ﺩﻭﻻﺭ ‪ ،‬ﺍﺗﺼﺎﻝ ﺩﻭﻻﺭ(‬

‫• ﻳﺸﻴﺮ ‪ mysql_num_rows‬ﺇﻟﻰ ﻋﺪﺩ ﺍﻟﺼﻔﻮﻑ ﺍﻟﺘﻲ‬


‫ﺗﻢﺇﺭﺟﺎﻋﻬﺎ‬
‫= ﺩﻭﻻﺭ ‪)mysql_num_rows- num_rows‬ﻧﺘﻴﺠﺔ ‪($‬‬

‫• ﻳﻨﺸﺊ ‪ mysql_fetch_array‬ﻣﺼﻔﻮﻓﺔ ‪ /‬ﺗﺠﺰﺉﺔ‬


‫ﻟﻠﻨﺘﻴﺠﺔ‬
‫ﻟـ)‪n = 0 $‬؛ ‪n >$ num_rows $‬؛ ‪(++ n $‬‬
‫ﺻﻒﺩﻭﻻﺭ =‪)mysql_fetch_array‬ﻧﺘﻴﺠﺔ ‪($‬‬
‫‪17‬‬
‫ﻃﺒﺎﻋﺔﺍﻟﺼﻒ ﺍﻟﻜﺎﻣﻞ‬
‫• ﺑﺎﻟﻌﺪﺩ‬
‫ﻟـ)‪ i = 0 $‬؛ ‪)mysql_num_fields> i $‬ﻧﺘﻴﺠﺔ ‪ ($‬؛ ‪(++ i $‬‬
‫ﺻﺪﻯ‪ "" .row ]$ i[ $‬؛‬
‫• ﺣﺴﺐ ﺍﻟﻤﺠﺎﻝ‬

‫ﺻﺪﻯ‪"] row $‬ﺍﻟﻠﻘﺐ"[‪row ]'city'[ $ ." .‬؛‬

‫‪18‬‬
‫‪ MySQL‬ﺇﻧﺸﺎء ﻗﺎﻋﺪﺓ ﺑﻴﺎﻧﺎﺕ ‪PHP‬‬
‫• ﻣﻨﺢ ﺇﻧﺸﺎء ﺧﺎﺹﺍﻻﻣﺘﻴﺎﺯﺍﺕﻹﻧﺸﺎء ﺃﻭ ﺣﺬﻑ ﻗﺎﻋﺪﺓ ﺑﻴﺎﻧﺎﺕ ‪.MySQL‬‬

‫• ﻳﺘﻢ ﺍﺳﺘﺨﺪﺍﻡ ﻋﺒﺎﺭﺓ ﺇﻧﺸﺎء ﻗﺎﻋﺪﺓ ﺑﻴﺎﻧﺎﺕ ﻹﻧﺸﺎء ﻗﺎﻋﺪﺓ ﺑﻴﺎﻧﺎﺕ ﻓﻲ‬
‫‪.MySQL‬‬
‫‪ //‬ﺇﻧﺸﺎء ﻗﺎﻋﺪﺓ ﺑﻴﺎﻧﺎﺕ‬
‫} ((‪ )mysqli_query )$ conn، $ sql‬؛ ﺇﺫﺍ‬
‫"‪ myDB‬ﺇﻧﺸﺎء ﻗﺎﻋﺪﺓ ﺑﻴﺎﻧﺎﺕ" = ‪$ sql‬‬
‫ﺻﺪﻯ"ﺗﻢ ﺇﻧﺸﺎء ﻗﺎﻋﺪﺓ ﺍﻟﺒﻴﺎﻧﺎﺕ ﺑﻨﺠﺎﺡ" ؛ { ﺁﺧﺮ }‬

‫ﺻﺪﻯ"ﺧﻄﺄ ﻓﻲ ﺇﻧﺸﺎء ﻗﺎﻋﺪﺓ ﺍﻟﺒﻴﺎﻧﺎﺕ‪ mysqli_error )$ conn( .":‬؛‬


‫{‬
‫؛ (‪mysqli_close )$ conn‬‬
‫‪19‬‬
‫؟<‬
PHP MySQL ‫ﺇﻧﺸﺎءﺟﺪﻭﻝ‬
.MySQL ‫• ﺍﻝﺍﺻﻨﻊ ﺟﺪﻭﻝﺍﻟﺒﻴﺎﻥ ﻳﺴﺘﺨﺪﻡ ﻹﻧﺸﺎء ﺟﺪﻭﻝ ﻓﻲ‬

) ‫ ﺍﻟﺠﺪﻭﻝ‬MyGuests‫ﺇﻧﺸﺎء‬
، INT )6( UNSIGNED AUTO_INCREMENT PRIMARY KEY‫ﻣﻌﺮﻑ‬
، VARCHAR )30( NOT NULL ‫ﺍﻻﺳﻢﺍﻷﻭﻝ‬
‫ ﺍﻟﺒﺮﻳﺪ‬، VARCHAR )30( NOT NULL ‫ﺍﺳﻢﺍﻟﻌﺎﺉﻠﺔ‬
، VARCHAR )50( ‫ﺍﻹﻟﻜﺘﺮﻭﻧﻲ‬
CURRENT_TIMESTAMP ‫ ﻓﻲ ﺍﻟﺘﺤﺪﻳﺚ‬CURRENT_TIMESTAMP
reg_date TIMESTAMP‫ﺍﻻﻓﺘﺮﺍﺿﻲ‬
(

20
// sql ‫ﻹﻧﺸﺎءﺍﻟﺠﺪﻭﻝ‬
$ sql = "‫ ﺇﻧﺸﺎء ﺟﺪﻭﻝ‬MyGuests )
، INT )6( UNSIGNED AUTO_INCREMENT PRIMARY KEY‫ﻣﻌﺮﻑ‬
، VARCHAR )30( NOT NULL ‫ﺍﻻﺳﻢﺍﻷﻭﻝ‬
‫ ﺍﻟﺒﺮﻳﺪ‬، VARCHAR )30( NOT NULL ‫ﺍﺳﻢﺍﻟﻌﺎﺉﻠﺔ‬
، VARCHAR )50( ‫ﺍﻹﻟﻜﺘﺮﻭﻧﻲ‬
CURRENT_TIMESTAMP ‫ ﻓﻲ ﺍﻟﺘﺤﺪﻳﺚ‬CURRENT_TIMESTAMP
reg_date TIMESTAMP‫ﺍﻻﻓﺘﺮﺍﺿﻲ‬
‫( "؛‬
} (mysqli_query )$ conn، $ sql()‫ﺇﺫﺍ‬
} ‫ ﺑﻨﺠﺎﺡ" ؛ { ﺁﺧﺮ‬MyGuests ‫ﺻﺪﻯ"ﺗﻢ ﺇﻧﺸﺎء ﺟﺪﻭﻝ‬

‫ ؛‬mysqli_error )$ conn( .":‫ﺻﺪﻯ"ﺧﻄﺄ ﻓﻲ ﺇﻧﺸﺎء ﺍﻟﺠﺪﻭﻝ‬


{
mysqli_close )$ conn( ‫؛‬
<‫؟‬
21
‫ﺍﻹﺩﺭﺍﺝﻓﻲ ﻗﺎﻋﺪﺓ ﺍﻟﺒﻴﺎﻧﺎﺕ‬
‫• ﺟﻤﻊ ﺍﻟﺒﻴﺎﻧﺎﺕ ﻣﻦ ﻧﻤﻮﺫﺝ‬
‫• ﺍﻟﺘﺤﻘﻖ ﻣﻦ ﺻﺤﺔ ﺍﻟﺒﻴﺎﻧﺎﺕ )‪ JavaScript‬ﺃﻭ ‪ PHP‬ﺃﻭ ﻛﻠﻴﻬﻤﺎ(‬
‫• ﺇﻧﺸﺎء ﺍﺳﺘﻌﻼﻡ‬
‫• ﻗﻢ ﺑﺘﺸﻐﻴﻞ ﺍﻻﺳﺘﻌﻼﻡ‬
‫؛(‪- mysql_query )$ query، $ db‬‬

‫‪22‬‬
‫ﺍﻹﺩﺭﺍﺝﻓﻲ ﻗﺎﻋﺪﺓ ﺍﻟﺒﻴﺎﻧﺎﺕ‬
MyGuests )‫ ﺍﻟﺒﺮﻳﺪ ﺍﻹﻟﻜﺘﺮﻭﻧﻲ‬، ‫ ﺍﺳﻢ ﺍﻟﻌﺎﺉﻠﺔ‬، ‫(ﺍﻻﺳﻢ ﺍﻷﻭﻝ‬
$ sql = "INSERT INTO
'( "‫) ؛ ﺇﺫﺍ‬mysqli_query )$ conn، $ sql(( }
VALUES )'John'، 'Doe'، ' john@example.com
} ‫ﺻﺪﻯ"ﺗﻢ ﺇﻧﺸﺎء ﺳﺠﻞ ﺟﺪﻳﺪ ﺑﻨﺠﺎﺡ" ؛ { ﺁﺧﺮ‬

$ conn( $ .":‫ﺻﺪﻯ"ﺧﻄﺄ‬
‫ ؛‬sql. ">br<". mysqli_error )
{
mysqli_close )$ conn( ‫؛‬
<‫؟‬
23
‫ﺍﻹﺩﺭﺍﺝﻓﻲ ﻗﺎﻋﺪﺓ ﺍﻟﺒﻴﺎﻧﺎﺕ‬
‫• ﻳﺠﺐ ﺗﻨﻔﻴﺬ ﺟﻤﻞ ‪ SQL‬ﺍﻟﻤﺘﻌﺪﺩﺓ ﺑﺎﺳﺘﺨﺪﺍﻡ(‬
‫) ‪ mysqli_multi_query‬ﻭﻇﻴﻔﺔ‪.‬‬

‫‪24‬‬
‫ﺃﻱﺃﺳﺉﻠﺔ؟‬

‫‪25‬‬

You might also like