أمثلة AJAX مع قواعد البيانات Database

تستخدم AJAX مع تبادل البيانات من خلال قواعد البيانات .


أمثلة مع قواعد البيانات Database

في المثال التالي يشرح كيف يمكن لصفحة الويب إظهار البيانات من خلال قواعد البيانات باستخدام AJAX :

شاهد المثال المباشر


شرح المثال مع الوظيفة showCustomer()

عند اختيار المستخدم “الزبون” من خلال القائمة المنسدلة في الأعلى سيتم استدعاء الكود showCustomer() . يتم استدعاء الكود من خلال الحدث onchange.

function showCustomer(str)
{
var xmlhttp;
if (str=="")
{
document.getElementById("txtHint").innerHTML="";
return;
}
if (window.XMLHttpRequest)
{
/*
يعمل على IE7+, Firefox, Chrome, Opera, Safari
*/
xmlhttp=new XMLHttpRequest();
} else {
/*
يعمل على IE5 و IE6
*/
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState==4 && xmlhttp.status==200)
{
document.getElementById("txtHint").innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","getcustomer.asp?q="+str,true);
xmlhttp.send();
}
 

تعمل الوظيفة showCustomer() كالتالي

  • يفحص اذا تم اختيار الزبون من القائمة .
  • إنشاء كائن XMLHttpRequest .
  • إنشاء function واستدعائه عندما تكون استجابة السيرفر جاهزة .
  • ارسال الطلب الى ملف على السيرفر .
  • لاحظ بأن القيمة q تم إضافتها الى الرابط URL مع محتوى القائمة المنسدلة .

صفحات السيرفر AJAX

ان الصفحة الي تم استدعائها على السيرفر من خلال الجافاسكربت JavaScript هي صفحة ASP تسمى “getcustomer.asp” .

ان الكود في الملف “getcustomer.asp” يقوم بتشغيل أوامر قواعد بيانات ثم يعيد القيمة في جدول HTML .

<%
response.expires=-1
sql="SELECT * FROM CUSTOMERS WHERE CUSTOMERID="
sql=sql & "'" & request.querystring("q") & "'"
set conn=Server.CreateObject("ADODB.Connection")
conn.Provider="Microsoft.Jet.OLEDB.4.0"
conn.Open(Server.Mappath("/db/northwind.mdb"))
set rs=Server.CreateObject("ADODB.recordset")
rs.Open sql,conn
response.write("<table>")
do until rs.EOF
for each x in rs.Fields
response.write("<tr><td><b>" & x.name & "</b></td>")
response.write("<td>" & x.value & "</td></tr>")
next
rs.MoveNext
loop
response.write("</table>")
%>