سوف نبدأ بأخذ فكرة عن البرنامج الذي سوف أشرح عنه وهو عبارة عن دليل مواقع بسيط جداً جداً يعتمد علي قواعد البيانات.
بالطبع لا يوجد فيه تقسيمات والسبب لأننا سوف نضطر إلي وضع أو خلق أكثر من جدول (Table) في قواعد البيانات وسوف نضطر إلي وضع علاقات بينهم
وهذا حالياً يعقد الموضوع فسأكتفي الآن بجدول واحد (one table) وسوف اشرح إذا اتسع لدي الوقت الكثير عن (sql) عامة وعن العلاقات (Relationstips) لأنها مثيرة أيضاً جداً
نبدأ في الخطوة الأولى وهي قاعدة البيانات الخاصة بدليل الموقع الذي لدينا , فالبيانات والمعلومات التي غالباً ما يهتم بها دليل الموقع هي عنوان الموقع واسم الموقع والبريد الخاص بالموقع
هذا هو الكود الخاص بإنشاء قاعدة البيانات الخاصة بدليل الموقع
CREATE TABLE dalal
(
id int not null auto_increment
,
sitename varchar
(
100
),
add_date date
,
email varchar
(
100
),
site_url varchar
(
100
),
description text
,
primary key
(
id
));
هنا سوف يخزن في قواعد البيانات المعلومات التالية :
id وهي المرشح الأساسي والفريد الذي يتُعرف علي الجدول بواسطته .
sitename وهي اسم الموقع وهي من نوع char
add_date تاريخ إضافة الموقع وهو من نوع date
email البريد الإلكتروني وهو من نوع char وطولها نفس طول اسم الموقع (100)
site_url وهو عنوان الموقع أيضاً من نوع char
سوف اكتفي بشرح id لأنه ربما يكون جديد علي البعض وسوف اشرح عمله وليس المهم أن تفهم علمه في هذه الخطوة إنما سوف تفهمها بالتفصيل في الخطوات القادمة بعد قليل إن شاء الله
id هو عبارة عن المرشح الأساسي لهذا الجدول (primary key)
وتلخص في آخر سطر من الجدول وجود:
primary key
(
id
)
ربما ترجمة المصطلحات العلمية وخاصةً في الكمبيوتر تضر أكثر مما تنفع وهذا سبب وجيه لي في كتابتي السكربت مهما كان بلغة إنجليزية ومن ثم تعربيها
المهم نحن الآن نريد أن نعرف ماذا يعني id سوف أعطي مثال لكي يتضح فلو أردنا مرشح أساسي أو كود فريد نميز به هذا الجدول فلن نستطيع أن نضع هذا الكود الفريد اسم الموقع لان ربما يكون لدي موقعاً بنفس الاسم والاختلاف بينهما في الوصلة وربما يكون هناك موقع بعنوانين مثل سوالف وياهوو إذاً اسم الموقع لا يكمن أن نضعه كود أساسي وأيضاً نفس الكلام ينطبق علي عنوان الموقع وأيضاً علي التاريخ وحتى البريد لا نستطيع أن نضع البريد هو المرشح الوحيد والأساسي للجدول ربما يأتي هذا لكن منطقياً لا يجوز
ربما ترى id من نوع عدد صحيح ( int ) لكن ربما يصعب عليك الذي بجانبه وهو ( not null ) وهي تعني بعدم السماح لهذا الحقل أن يكون بدون قيمة
not null تعني بكل وضوح ربما يسمح بقيمة فارغة ربما تفكر في الصفر فهذا غير صحيح .
وترى أيضاً هذه العبارة بجانب not null وهي ( auto_increment ) وهي تعني بكل وضوح الإضافة التلقائية أو الأتوماتيكية ودائماً ما يبدأ بالقيمة ( 1 )
وهذا يعني مع كل إضافة موقع سوف تزيد قيمة ( id ) وهي تبدأ من ( 1 )
config.php
وهو عبارة عن ملف التوجية الذي يحتوي معلومات الموقع وهي المعلومات التالية:
<?
//this moudel config
$dbname
=
"links"
;
$dbuname
=
"root"
;
$dbpws
=
""
;
$dbhost
=
"localhost"
;
?>
لا يحتاج إلي شرح لأنه واضح فالذي جرب أن يركب أي برنامج
php
يعتمد علي قواعد البيانات فالأكيد راح يعدل في ملف مشابه له أو نفسه
ومع ذلك سنشرحه :
الآن نبدأ في
add.php
وهذا هو :
<html>
<head>
<style type="text/css">
body {font-family:verdana,verdana; font-size:10pt}
TD {font-family:verdana,verdana; font-size:10pt}
#header {color:white; font-weight:bold; font-family:verdana,verdana}
A {color:navy; text-decoration:underline}
A:hover {color:red}
A:visit {color:navy}
</style><title>Site Insertion</title></head>
<?
if (
$action
==
'addsite'
)
{
include(
"config.php"
);
mysql_pconnect
(
$dbhost
,
$dbuname
,
$dbpw
);
@
mysql_select_db
(
"$dbname"
) or die (
"Unable to select database"
);
mysql_query
(
"insert into dalal values ('','$name','','$email','$siteurl','$des')"
);
mysql_close
();
echo
"Thank you for add site "
;
}
?>
<body bgcolor=white>
<form method="POST" action="add.php?action=addsite">
<p>SiteName <input type="text" name="name" size="40" style="border-style: double; border-color: #000080"></p>
<p>Email <input type="text" name="email" size="40" style="border-style: double; border-color: #000080"></p>
<p>SiteUrl <input type="text" name="siteurl" size="40" style="border-style: double; border-color: #000080" value="http://"></p>
<p>description<textarea rows="5" name="des" cols="33" style="border-style: double; border-color: #000080"></textarea></p>
<p align="center"><input type="submit" value="Submit" name="B1" style="border-style: double; border-color: #000080"><input type="reset" value="Reset" name="B2" style="border-style: double; border-color: #000080"></p>
</form>
<br>
<a href="show.php"><b>View</b></a>
<br>
</body>
</html>
من رؤيتك له تلاحظ أنه عبارة عن
html
و
php
لكن كود
php
أكثر
بالنسبة
html
فهي بسيطة بإمكانك فهمها وهي عبارة عن حقول تطلب من المستخدم إدخال معلومات الموقع سوف أبدأ في شرح كود
php
فتلاحظ بدايته ونهايته بهذين الوسمين <? و ?>
وبعدها يأتي شرط التحقق وهو
if (
$action
==
'addsite'
)
فهذا يعني التحقق هل من إضافة جديدة علي الحقول الخاصة بعملومات الموقع وتلاحظ أن التحقق من هذا الشرط بهذه القيمة ('
addsite
') بين وسمين اقتباس وحيدة ربما يكون هناك بعض التساؤل قليلاً عليه لكن لو تلاحظ في كود
html
في
form
وضعت الانتقال بعد إضافة المعلومات إلي (
add.php?addsite
) هنا
<
form method
=
"POST"
action
=
"add.php?action=addsite"
>
<
p
>
SiteName
<
input type
=
"text"
name
=
"name"
size
=
"40"
style
=
"border-style: double; border-color: #000080"
></
p
>
<
p
>
&
nbsp
;&
nbsp
;&
nbsp
;&
nbsp
;&
nbsp
;&
nbsp
; <
input type
=
"text"
name
=
"email"
size
=
"40"
style
=
"border-style: double; border-color: #000080"
></
p
>
<
p
>
SiteUrl
&
nbsp
;&
nbsp
;&
nbsp
; <
input type
=
"text"
name
=
"siteurl"
size
=
"40"
style
=
"border-style: double; border-color: #000080"
value
=
"http://"
></
p
>
<
p
>
description
<
textarea rows
=
"5"
name
=
"des"
cols
=
"33"
style
=
"border-style: double; border-color: #000080"
></
textarea
></
p
>
<
p align
=
"center"
><
input type
=
"submit"
value
=
"Submit"
name
=
"B1"
style
=
"border-style: double; border-color: #000080"
><
input type
=
"reset"
value
=
"Reset"
name
=
"B2"
style
=
"border-style: double; border-color: #000080"
></
p
>
</
form
>
هذا هو كود الفورم الخاص بإدخال معلومات الموقع فإذا لاحظه في بدايته هنا
<
form method
=
"POST"
action
=
"add.php?action=addsite"
>
وضعت الإرسال بالـ (
post
) وقمت بوضع قيمة (
action
) الصفحة (
add.php?addsite
)
هذا يعني أن قيمة (
action
) في حال ضغط
submit
ستكون ما هو مكتوب بعد علامة الاستفهام ( ؟ ) بعد اسم الصفحه وهي (
add.php?addsite
)
أتمنى أنك فهمت المقصود
بعد ذلك إذا تحقق الشرط ووجد من أرسل سوف ينفذ الأوامر والأولى منها
include(
"config.php"
);
وأمر
include
يعني استجلاب هذا الملف وقيم المتغيرات الموجودة به
بعد هذا الأمر طلبت الاتصال بقواعد البيانات لكي يتم تجهيز الجدول للإضافة
وهو هنا
mysql_pconnect
(
$dbhost
,
$dbuname
,
$dbpw
);
@
mysql_select_db
(
"$dbname"
) or die (
"Unable to select database"
);
الدالة
mysql_pconnect
تطلب الاتصال بخادم قاعدة البيانات علي أساس المعلومات الموجودة بها
وهنا نحن استعنا بعد الله بالمتغيرات الموجودة في ملف
config.php
وربما هذا يوضح لنا أكثر فائدة الدالة
include
ربما لاحظت في طلب الاتصال في الدالة
mysql_pconccet
في السطر الثاني بعدها هذا
@
mysql_select_db
(
"$dbname"
) or die (
"Unable to select database"
);
هنا في الدالة
mysql_select_db
وضعنا قيمة المتغير
dbname
وهو اسم قاعدة البيانات
فهذه الدالة تقوم بتحديد اسم قاعدة البيانات المراد الاتصال بها وهذا ربما يوضح استخدام علامة @
لكي يعمل كل شيء بنفس الوقت
بعد هذا نلاحظ السطر التالي :
mysql_query
(
"insert into dalal values ('','$name','','$email','$siteurl','$des')"
);
قمنا في هذا السطر بتنفيذ الدالة
mysql_query
وهذه الدالة تقوم باختصار بتنفيذ استعلامات (
sql
) وفي هذا السطر استخدمنا أمر الاستعلام المراد تنفيذه بواسطة الدالة
mysql_query
هو (
Insert
)
هذا الأمر أو الدالة في
sql
تقوم بإضافة البيانات في قاعدة البيانات والصيغة أو القاعدة الثابتة له هي
INSERT INTO tablename VALUES
(var and
values
)
INSERT INTO
هذا ثابت لدينا بعده يأتي اسم الجدول الذي نريد إضافة البيانات بداخله
وبعد ذلك تأتي كلمة
VALUES (var
وتفتح قوس وتيحط المتغيرات والقيم المراد إضافتها بأقواس اقتباس (" ") وتنهيه بفاصلة منقوطة
;
تلاحظ حين استخدمت
mysql_query
و
insert
لم أضع القيم بل وضعة المتغيرات التي تحمل القيم المراد تخزينة في جدول
dalal
ربما هذا يسهل علينا الكثير
بعد ذلك في تأتي الدالة
mysql_colse
وهي تعني طلب إغلاق الاتصال بخادم قاعدة البيانات
بهذا انتهيانا من ملف
add.php
و
config.php
هنا سوف نعرف كيف نستخرج البيانات الموجودة داخل قاعدة البيانات
وهي في غاية السهولة
بدايةً سوف أضع كود
show.php
كاملاً واشرحه مثل سابقه
<html>
<head>
<style type="text/css">
body {font-family:verdana,verdana; font-size:10pt}
TD {font-family:verdana,verdana; font-size:10pt}
#header {color:black; font-weight:bold; font-family:verdana,verdana}
A {color:navy; text-decoration:underline}
A:hover {color:red}
A:visit {color:navy}
</style>
</head><titel><center><b>view The sites</b></center><br><center><a href='add.php'>Add Your Site</a></center> <hr color="#000080"></titel>
<body>
<?php
include(
"config.php"
);
mysql_pconnect
(
$dbhost
,
$dbuname
,
$dbpw
);
@
mysql_select_db
(
"$dbname"
) or die (
"Unable to select database"
);
$query
=
"select * from dalal "
;
$result
=
mysql_query
(
$query
);
mysql_close
();
/*Display Results*/
$num
=
mysql_numrows
(
$result
);
$i
=
0
;
while (
$i
<
$num
) {
$sitename
=
mysql_result
(
$result
,
$i
,
"sitename"
);
$add_date
=
mysql_result
(
$result
,
$i
,
"add_date"
);
=
mysql_result
(
$result
,
$i
,
"email"
);
$siteurl
=
mysql_result
(
$result
,
$i
,
"site_url"
);
$description
=
mysql_result
(
$result
,
$i
,
"description"
);
$id
=
mysql_result
(
$result
,
$i
,
"id"
);
?>
<table border="0" cellspacing="0" cellpadding="0">
<tr>
<td width="100%"><b>SiteName :</b><a href='
<?
echo
$siteurl
;
?>
'><i>
<?
echo
$sitename
;
?>
</i></a>
<p><b>Date Add :</b> <i>
<?
echo
$add_date
;
?>
</i></p>
<p><b>description :</b>
<?
echo
$description
;
?>
</p>
<p><b>URL :</b><i>
<?
echo
$siteurl
;
?>
</i></p>
<p><b>Email :</b><i> <a href="mailto:
<?
echo
;
?>
">
<?
echo
;
?>
</a></i> </p>
</td>
</tr>
</table>
<a href='edit.php?id=
<?
echo
$id
;
?>
'><b><b>[Edit This Site]</b></b></a>
<hr color="#000080">
<?
++
$i
;
}
?>
</body>
</html>
كما تلاحظ تقريباً شبيه بالملف
add.php
في عملية الاتصال لكن الجديد لدينا هنا
السطر الذي يلي عملية الاتصال وهو
$query
=
"select * from dalal "
;
في هذا السطر قمنا بتعريف متغير يدعى
query
وقمنا بوضع قيمة هذا المتغير عملية الاستعلام عن المعلومات الموجودة في الجدول
dalal
أظن هذا واضح لكن دعني أشرح عمل
select
فهي تقوم بتحديد الحقول بداخل الجداول أو الجدول وهي دائماً تستخدم في إخراج البيانات من الجداول فتلاحظ وضعنا قيمة الحقل أو الحقول في استعلامنا هذا علامة الضرب( * ) وهي تعني تحديد جميع الحقول الموجودة وبعدها استعملنا
from
وهذا يعني من ودائماً يأتي بعده أسماء الجدول أو اسم الجدول الذي قمت بتحديد الحقول بداخله
ببساطة واختصاراً لهذا السطر
select * from dalal
حدد جميع الحقول من جدول الدليل
هنا سوف يحدد جميع الحقول الموجودة في جدول الدليل ويقوم بتخزينها في المتغير
query
بسيطة
لا تنس أن تضعها بين أقواس اقتباس مزدوجة (" ")
بعد ذالك يأتي هذا السطر
$result
=
mysql_query
(
$query
);
قمنا هنا أيضاً بتعريف المتغير
result
وقمنا بتخزين قيمة الدالة
mysql_qurey
وقيمة المتغير الذي استعلمت به الدالة
mysql_query
في المتغير
result
بوضوح هنا قمنا بالاستعانة بالدالة
mysql_query
وانسبنا اليها قيمة المتغير
query
الموجود به مسبقاً قيمة الاستعلام مسبقاً في السطر الذي يسبق هذا السطر وقمنا بهذا لكي يتم فرز جميع القيم الموجودة في الجدول
dalal
بواسطة الدالة
mysql_query
( هذا ابسط من اللي قبل )
بعد ذلك قمنا بإغلاق قاعدة البيانات بالدالة
mysql_colse
وبعد ذلك قمنا بتنويه بسيط وتعليق يوضح أننا سوف نعرض ونطبع القيم الموجودة في الجدول في هذا السطر
/*
Display Results
*/
بعد هذا السطر قمنا بتعريف متغير يدعى
num
وأضفنا القيمة إليه باستخدام الدالة
mysql_numrows
مسندين إليه قيمة المتغير
result
الدالة
mysql_numrows
تقوم باسترجاع ومعالجة نتيجتنا المخزنة في المتغير
result
وتقوم بتخزينها في المتغير
num
علي شكل مصفوفة
بعد ذالك قمنا بتعريف عداد يدعى
i
ووضعنا قيمته صفر لكي نستخدمه مع أمر التكرار
while
وقمنا بوضع الشرط في أمر التكرار
while
$
i < $num
هذا يعني إذا كان قيمة العداد
i
اصغر من قيمة المتغير
num
المتوجد بداخله جميع المعلومات فاستمر بطباعة التالي
وهي هذه السطور
$sitename=mysql_result($result,$i,"sitename");
$add_date=mysql_result($result,$i,"add_date");
$email=mysql_result($result,$i,"email");
$siteurl=mysql_result($result,$i,"site_url");
$description=mysql_result($result,$i,"description");
$id=mysql_result($result,$i,"id");
?>
<table border="0" cellspacing="0" cellpadding="0">
<tr>
<td width="100%"><b>SiteName :</b><a href='
<?
echo
$siteurl
;
?>
'><i>
<?
echo
$sitename
;
?>
</i></a>
<p><b>Date Add :</b> <i>
<?
echo
$add_date
;
?>
</i></p>
<p><b>description :</b>
<?
echo
$description
;
?>
</p>
<p><b>URL :</b><i>
<?
echo
$siteurl
;
?>
</i></p>
<p><b>Email :</b><i> <a href="mailto:
<?
echo
;
?>
">
<?
echo
;
?>
</a></i> </p>
</td>
</tr>
</table>
<a href='edit.php?id=
<?
echo
$id
;
?>
'><b><b>[Edit This Site]</b></b></a>
<hr color="#000080">
<?
++
$i
;
}
هنا قمنا بالكثير في أمر التكرار
WHILE
فسوف يطبع جميع القيم الموجودة في الجدول كما رمزت إليها في هذا السطر
$sitename
=
mysql_result
(
$result
,
$i
,
"sitename"
);
قمنا في هذا السطر والسطور الخمسة التي تليه بتعريف العديد من المتغيرات وقمنا بتخزين قيم المعلومات بداخله باستخدام الدالة
mysql_result
مسندين إليه المتغيرات
result
و
i
و الحقل الذي نريد إخراج القيمة منه
واستخدمنا في هذا السطر الحقل
sitename
كما استخدمنا كود
html
لكي ننسق ونرتب شكل ظهور المعلومات
وفي آخر سطر قبل أن ننهي عملية التكرار
while
بالقوس { جعلنا قيمة العداد
i
تزيد بمقدار واحد مع كل لفة أو بمعنى طباعة قيم من قاعدة البيانات لكي يتم توقفها أرجو أن تنتبه لهذه الأمور الصغيرة لأنها من مشاكل البرمجة المشهورة
هنا انتهينا من ملف
show.php
يتبقى لنا ملف
edit.php
وهو الملف الخاص بتعديل الموقع فربما يخطئ أحدهم في إدخال اسم أو عنوان موقعه فهنا يمكنك تعديلها حتى بعد تخزينها في قاعدة البيانات
هذا آخر ملف سوف اشرحه اليوم من ضمن مشروع دليل المواقع وربما اشرح عملية الحذف والبحث في وقت آخر
فقط ادعوا لي بالستر والهداية والوقت الكافي
سوف أضع كود
edit.php
كاملاً كسابقيه
<html>
<head>
<style type="text/css">
body {font-family:verdana,verdana; font-size:10pt}
TD {font-family:verdana,verdana; font-size:10pt}
TH {font-size:10pt; color:white; font-weight:bold; font-family:verdana,verdana}
A {color:navy; text-decoration:underline}
A:hover {color:red}
A:visit {color:navy}
#mySelect {font-family:verdana,arial; font-size:9pt}
</style>
</head>
<titel><center><b>Edit Site</b></center><br><center><a href='add.php'><b>Add Your Site </b></a> |
<a href='show.php'><b>View Edit database</b></center></a> <hr color="#000080"></titel>
<body>
<table border=0 cellpadding=4 cellspacing=0 width=600>
<?
echo
"<form method='post' action='$PHP_SELF'>"
;
?>
<table border="1" width="100%" bordercolor="#000080" cellspacing="1" cellpadding>
<tr>
<td width="100%">
<p align="center">Edit The Info </td>
<?
include(
"config.php"
);
mysql_pconnect
(
$dbhost
,
$dbuname
,
$dbpw
);
@
mysql_select_db
(
"$dbname"
) or die (
"Unable to select database"
);
$query1
=
"select * from dalal where id = '$id'"
;
$result1
=
mysql_db_query
(
'links'
,
$query1
);
while(
$row
=
mysql_fetch_object
(
$result1
)) {
echo
"<td align=middle>SiteNmae<br><input type=text name='name' value='$row
->
sitename'></td>"
;
echo
"<td align=middle>Add Date<br><input type=text name='add_date' value='$row
->
add_date'></td>"
;
echo
"<td align=middle>Email<br><input type=text name='email' value='$row
->
email'></td>"
;
echo
"<td align=middle>SiteUrl<br><input type=text name='siteurl' value='$row
->
site_url'></td></tr>"
;
echo
"<td align=middle>Description<br><input type=text name='desc' value='$row
->
description'></td></tr>"
;
$id
=
$row
->
id
;
}
echo
"</table><p>"
;
echo
"<br><input type=hidden name='id' value='$id'>"
;
?>
<input type=submit name="update" value="Edit The Info">
</form>
</tr>
</table>
<?
if (
$update
) {
if(
$name
==
""
||
$add_date
==
""
||
==
""
||
$siteurl
==
""
||
$desc
==
""
) {
die(
"<b>You left one or more fields blank.</b>"
);
}
$query2
=
"update dalal set sitename='$name', add_date='$add_date', email='$email', site_url='$siteurl', description='$desc'
where id='$id'"
;
mysql_db_query
(
'links'
,
$query2
);
echo
"<b>Your record has been updated</b></p>"
;
}
mysql_close
();
?>
</body>
</html>
هنا سوف يسهل علي شرح هذا الملف أكثر من سابقيه لأنه يكرر ما يفعله إخوانه لكن مع بعض التجديدات التي لا تذكر فالجديد هنا
وفي هذا السطر
$query1
=
"select * from dalal where id = '$id'"
;
هنا تلاحظ عرفنا متغير يدعى
query1
وقمنا بتخزين ناتج الاستعلام بداخله فهذا ليس بجديد الجديد ما يوجد في الاستعلام فقد استخدمنا
where
وهي تعني بالترجمة إلي العربية "بحيث" وتعني في البرمجة وخاصةً مع أوامر
sql
"بشرط" أي هنا اشترطنا في استعلامنا أن تكون قيمة المتغير
id
مساوية لنفس القيمة الموجودة في الجدول وهي
id
وربما هنا يسعني أن أوضح أكثر ما هو
id
ولماذا عرفته وجعلته
primary key
هنا إذا ضغط أحد الذين أضافوا مواقعهم بعد أن أخطأ في إضافة موقعه علي
edit
فسوف يعتمد علي الرقم المخزن في
id
وهو كما سبق وأن عرفتها في قاعدة البيانات عدد صحيح ويزداد تلقائياً فلو كان لدينا مثلاً في قاعدة البيانات أربعة مواقع فلن يجري التعرف علي الأربعة مواقع ومعلوماتهم إلا عن طريق
id
لأن كل موقع منهم رقم بمعنى الأول منهم 1 والأخير 4 أرجو أنك فهمته وأرجو أن تحاول تشغيل السكربت لكي تفهمه أكثر وأكثر
بعد ذلك يأتي هذا السطر
$result1
=
mysql_db_query
(
'links'
,
$query1
);
هنا أيضاً عرفنا المتغير
result
وخزنا بداخله قيمة استعلام الدالة
mysql_db_query
وأسندنا إليها اسم قاعدة البيانات والمتغير
query
الدالة
mysql_db_query
وهي مشابة في عملها مع
mysql_query
ما عدا الفرق بينهم أنك تستطيع تحديد اسم قاعدة البيانات الذي تريد الاستعلام عنه واستعملتها هنا لكي يتم إعطائنا النتائج بوضوح أكثر
بعد هذا السطر يأتي أمر التكرار
while
مرة أخرى في هذا الملف
while(
$row
=
mysql_fetch_object
(
$result1
))
هنا قمنا بخلق المتغير
row
ولا تنسى في
php
ليس من الضروري تعريف المتغيرات قبل استخدامها وقمنا بمساواته ( وهو الشرط الخاص بأمر التكرار
while
) بالدالة
mysql_fetch_object
مسندين إليه قيمة المتغير
result1
الدالة
mysql_fetch_object
وظيفته أو من ضمن الوظائف التي تقوم به أنها تقوم بانتزاع وعرض نتائج الاستعلام
فإذا تحقق شرط أمر التكرار
while
فستنفذ هذا الكود الطويل قليلاً
while($row = mysql_fetch_object($result1)) {
echo "<td align=middle>SiteNmae<br><input type=text name='name' value='$row->sitename'></td>";
echo "<td align=middle>Add Date<br><input type=text name='add_date' value='$row->add_date'></td>";
echo "<td align=middle>Email<br><input type=text name='email' value='$row->email'></td>";
echo "<td align=middle>SiteUrl<br><input type=text name='siteurl' value='$row->site_url'></td></tr>";
echo "<td align=middle>Description<br><input type=text name='desc' value='$row->description'></td></tr>";
$id = $row->id;
}
echo "</table><p>";
echo "<br><input type=hidden name='id' value='$id'>";
?>
<input type=submit name="update" value="Edit The Info">
</form>
</tr>
</table>
<?
if (
$update
) {
if(
$name
==
""
||
$add_date
==
""
||
==
""
||
$siteurl
==
""
||
$desc
==
""
) {
die(
"<b>You left one or more fields blank.</b>"
);
}
$query2
=
"update dalal set sitename='$name', add_date='$add_date', email='$email', site_url='$siteurl', description='$desc'
where id='$id'"
;
mysql_db_query
(
'links'
,
$query2
);
echo
"<b>Your record has been updated</b></p>"
;
}
mysql_close
();
?>
هنا قمنا بطباعة المعلومات والتحقق بواسطة شرط
IF
دعنا نأخذ عملية طباعة المعلومات :
echo
"<td align=middle>SiteNmae<br><input type=text name='name' value='$row
->
sitename'></td>"
;
echo
"<td align=middle>Add Date<br><input type=text name='add_date' value='$row
->
add_date'></td>"
;
echo
"<td align=middle>Email<br><input type=text name='email' value='$row
->
email'></td>"
;
echo
"<td align=middle>SiteUrl<br><input type=text name='siteurl' value='$row
->
site_url'></td></tr>"
;
echo
"<td align=middle>Description<br><input type=text name='desc' value='$row
->
description'></td></tr>"
;
$id
=
$row
->
id
;
هنا في أول سطر قام بطباعة كود
HTML
وبداخله أيضاً بعض الأشياء من
PHP
لا تخف فالمقصود هنا أنه قام بتخزين جميع ما يطبعه بداخل المتغير الخاص بلغة
HTML
فهنا مثلاً
echo
"<td align=middle>SiteNmae<br><input type=text
name='name' value='$row
->
sitename'></td>"
;
قام بطباعة كود
HTML
وهو عبارة عن حقل الإدخال (
INPUT
) من نوع (
TEXT
) وقام بترمز إلي الحقل الموجود بقاعدة البيانات من المتغير
row
وتخزينة في قيمة المتغير في
html (name
)
والأكثر وضوحاً ما قمنا به في السطر السابق قمنا بوضع المتغير
row
ثم يليه اسم الحقل في الجدول وهنا اسم الحقل
sitename
أظن مع تشغيلك للسكربت سوف تتضح أكثر وأكثر وهذا الذي استخدمته مع الجميع
بعد ذلك قمت بطباعة أكواد
html
وهي عبارة عن فورم للإدخال ويأتي بعده شرط
if
وهو هنا
<input type=submit name="update" value="Edit The Info">
</form>
</tr>
</table>
<?
if (
$update
) {
if(
$name
==
""
||
$add_date
==
""
||
==
""
||
$siteurl
==
""
||
$desc
==
""
) {
die(
"<b>You left one or more fields blank.</b>"
);
}
$query2
=
"update dalal set sitename='$name', add_date='$add_date', email='$email', site_url='$siteurl', description='$desc'
where id='$id'"
;
mysql_db_query
(
'links'
,
$query2
);
echo
"<b>Your record has been updated</b></p>"
;
}
mysql_close
();
?>
في الشرط نريد التأكد هل تم تعديل أحد البيانات أم لا وهو شبيه بالشرط الذي استخدمته مع ملف
add.php
بعده إذا كان هناك إدخال فسيقوم بعدة أوامر وأولها شرط أخر
if
يتأكد هل هناك من الحقول التي جعلت فارغة أم لا وهي هنا
if(
$name
==
""
||
$add_date
==
""
||
==
""
||
$siteurl
==
""
||
$desc
==
""
) {
die(
"<b>You left one or more fields blank.</b>"
);
}
إذا كان هناك حقول فارغة سوف يطبع له
You left one or more fields blank
أي أنك تركت حقل أو أكثر فارغ
بعد ذالك يأتي هذا
$query2
=
"update dalal set sitename='$name', add_date='$add_date', email='$email', site_url='$siteurl', description='$desc'
where id='$id'"
;
mysql_db_query
(
'links'
,
$query2
);
echo
"<b>Your record has been updated</b></p>"
;
}
mysql_close
();
قمنا هنا في أول سطر بتعريف المتغير
query2
بعد ذلك خزنا بداخله قيمة أمر
SQL
التحديث
update
أمر
update
يقوم بتحديث المعلومات في قواعد البيانات من تجديد وحذف
ويكتب هكذا
Update tablename Set (values
الكلمات التي تبدأ بحروف كبيتل هي الثوابت بمعنى لا يتم تغييرها والتي تبدأ بحروف سمول مثل
sitename
و
values
فهي التي يتم تغييرها
كما وضحت في الكود السابق فقد قمت بمساوات المتغيرات
name,add_date,email,site_url,description
بما يقابلها من الحقول في الجدول
dalal
ووضعت شرط
where
أن يكون المتغير
$
id=id
وفي السطر الذي يليه هذا قمت باستخدام الدالة
mysql_db_query
مسنداً إليه اسم قاعدة البيانات والمتغير الذي خزن قيمة التحديث وهو
query2
لكي يتم تحديث قاعدة البيانات
وفي السطر الذي يليهما استعملت الدالة
mysql_colse
لكي يتم إغلاق الاتصال بقاعدة البيانات
وهو آخر سطر اليوم