الجمعة، 26 أغسطس 2016

تعرَّف على أشهر مكتبات الــ GUI في سي++

بسم الله الرحمن الرحيم

هل توجد مكتبات GUI لـــ C++ ؟
Microsoft Visual C++ and MFC
  • مالفرق بين C++ و VC++ ؟
  • الــ VC++ هو الوحيد في هذا المجال ؟
  • أشهر البرامج التي كُتبت بــ VC++
  • الإيجابيات و السلبيات
  • ما هي MFC ؟
  • إيجابيات و سلبيات الـــ MFC
C++ Builder and VLC
  • نبذة تاريخية
  • ما هي VCL ؟
  • البرامج التي كُتبت في بيئة C++ Builder
wxWidgets
  • ما هي wxWidgets ؟
  • نبذة تاريخية
  • الترخيص
  • السلبيات
  • المميزات
  • برامج تستخدم wxWidgets
Framework QT
  • ما هي QT ؟
  • نبذة تاريخية
  • Modules
  • إصدارات QT
  • مميزات QT
  • أشهر البرامح المكتوبة بــ QT
الخاتمةالمقدمة
لا يزال السؤال الذي يدور في أذهان الكثيرين من عشاق C++ : مالسبيل إلى برمجة الواجهات الرسومية !؟
في هذه المقالة سأحاول أن أجيب على هذا السؤال من خلال التطرق لأشهر مكتبات الــ GUI في السي++.
سؤال الموضوع :
نعم, توجد عدة مكتبات C/C++ لبناء الواجهات الرسومية, بعضها متعدد المنصات و بعضها الآخر يعمل على نظام تشغيل واحد فقط, المكتبات الأشهر هي :
Microsoft Foundation Classes (MFC)
Visual Component Library (VCL)
wxWidgets
Qt
Microsoft Visual C++ and MFC
post-219439-034975000 1346586994_thumb.j
مالفرق بين C++ و VC++ ؟
C++ هي إحدى اللغات البرمجية العالية المستوى, صُممت لتدعم بشكل مباشر أنماط برمجية متعددة :
Procedural programming, Object-oriented programming, Generic programmingالسي++ هي اللغة الأفضل لتصميم التطبيقات ذات الواجهات المعقدة، وللتعامل مع البنية الصلبة للحاسوب وذلك لسرعتها في التنفيذ والتي ورثتها عن أمها الحنون : السي.
بالإضافة إلى ما سبق, يعتبر البعض أن مشكلة السي++ هي أنها تعطي للمبرمج الخيار حتى لو كان اختياره غير صحيح (خصوصا في قضايا إدارة الذاكرة : حجز/تحرير/تسرب, ..) إلا أن أصحاب اللغة ينظرون إلى هذه الأمور باعتبارها دليل على حرية المبرمج و عدم التضييق عليه, و يقولون أنها إحدى مميزات السي++ التي تنفرد بها عن بقية اللغات ..
بالسبة لــ Microsoft Visual C++ فهو عبارة عن IDE أي بيئة تطوير متكاملة (Integrated Development Environment) و سُميت كذلك لأنها تساعد المبرمج في كل من التحرير, الترجمة و الربط, ففي السابق كانت الترجمة و الربط يتمان على شكل أوامر ! أما في الـ IDE فأصبحت عملية الربط و الترجمة تتم عن طريق الضغط على زر واحد من لوحة المفاتيح و بالتالي بيئة التطوير هي من يقوم بتنفيذ هذه الأوامر بدلا منك.
إذا, MSVC ليس لغة برمجة ..
الــ VC++ هو الوحيد في هذا المجال ؟
لا, ليس الوحيد و لكنه عملاق الساحة !, يقول الخبير Scott Meyers في سلسلة مقالاته البرمجية الشهيرة The most important ever :
إن مترجم مايكروسوفت منذ عام 92 هو أحد أسباب تطور لغة ++C, ولو جمعنا كافة مبرمجي ++C في الكرة الأرضية ثم سألناهم عن المترجمات التي يستخدمونها في إنجاز أعمالهم فستكون الإجابة لدى الغالبية الكبرى هي مترجم مايكروسوفت, لذلك يشتبه على الكثير من المبتدئين الفرق بين لغة ++C و بين ++VC كبيئة تطوير.
في إصداراته حتى عام 98 لم يكن VC يلتزم بالمعايير لأنه لم يكن هناك معايير أصلاً, المعايير ظهرت في عام 98 قبيل إصدار VC 6 بقليل, و المعايير تحتاج إلى وقت ليس بالقصير لتبنيها من قبل مصنعي المترجمات وقد حلت معظم مشاكل التوافق مع المعايير منذ عام 2003.
أشهر البرامج التي كُتبت بــ VC++
  • حزمة الأوفيس (Microsoft Office) بجميع إصداراتها.
  • النسخة التي تعمل على الويندوز من برنامج MathType (كُتبت بلغة C).
  • معظم برامج Windows الناجحة كُتبت بــ VC++.
السلبيات و الإيجابيات
سلبياته : يعمل على الـ Windows فقط !, كبير الحجم و بطئي شيئا ما !!, غير مجاني أيضا.
إيجابياته : يوفر العديد من الأدوات التي تُسهل عمل المبرمج (مثل برمجة الشبكات, الاتصال بقواعد البيانات, ...) كما يحتوي على Debugger قوي جدا !
ما هي MFC ؟
مكتبة MFC هى اختصار لـــ The Microsoft Foundation Class وهى مكتبة تتكون من مجموعة من أنواع البيانات (data types) والدوال (functions) والفئات (classes) والثوابت (constants), تُستخدم عادة في إنشاء التطبيقات التي تعمل على عائلة نظام التشغيل ويندوز .
إيجابيات و سلبيات الـــ MFC
الإيجابيات : الـ MFC قريبة جدا من نظام التشغيل, قوية, سريعة, خفيفة, تستهلك ذاكرة أقل.
السلبيات:
  • مشاكل في دعم و تسيير اليونيكود (management unicode).
  • التوثيق ضخم لكن غير منظم (bloated, but not structured).
  • استخدام الــ event loop (messages) بدلا من Callback /Listener.
  • وجود طبقة كائنية التوجه (object-oriented wrapper) تسمح بالوصول إلى API Windows المكتوبة بــ C.
C++ Builder and VLC
post-219439-064180600 1346586988_thumb.p
ما هو C++ Builder ؟
C++ Builder عبارة عن RAD قامت بتصميمه شركة Borland حيث يعتمد على نفس المفاهيم, الواجهة و المكتبة الـمُستخدمة مع Delphi. يسمح CB بإنشاء تطبيقات Win32 سريعة كما يُوفر واجهة رسومية أنيقة و سهلة أيضا وهو مُتوافق مع ISO C++.
نبذة تاريخية
بدأ C++ Builder حربه الشرسة مع الــ VC في تسعينيات القرن الماضي, حيث أطلقت شركة Borland أول نسخة من CB في عام 1997. بالرغم من أن تلك النسخة لم تُشكل خطرا يُذكر على MSVC إلا أن ذلك لم يقف عائقا دون إصدار نسخ جديدة من الـــ Builder حيث توالت النسخ تباعا .. وصولا إلى C++ Builder 6.
عندما أعلنت ميكو عن Microsoft Visual Studio قامت شركة بورلاند أيضا بحركة مماثلة حيث أعلنت عن المنافس الجديد Borland Developer Studio, في عام 2007 تولى فرع Code Gear (التابع لشركة بورلاند) برمجة و تطوير BDS. شهد عام 2008 بيع فرع كود جير إلى شركة Embarcadero قبل أن يتم إصدار نسخة CB9 التي تعتبر من أقوى نسخ C++ Builder و أكثرها أمنا, سرعة و ثباتا.
الجدول التالي يحتوي على أرقام نسخ CB منذ بدايته و حتى الآن :
post-219439-099235900 1346586990_thumb.p
ما هي VCL ؟
الـــ VCL اختصار لـــ Visual Components Library وتعني مكتبة المكونات المرئية, عبارة عن إطار كائني التوجه مكتوب بلغة الـــ Object Pascal, من ضمن المكتبات الرسومية الموجهة إلى سي++, نجد أن VCL هي الوحيدة الغير مكتوبة بــ C++), تتميز VCL بسهولة VB و قوة VC. الشيء الذي جعلها تخطو خطوات إلى الأمام لتأخذ مكانا متقدما في لائحة البكتبات الرسومية. ابتداء من 2009, أصبحت VCL تدعم اليونيكود بشكل ممتاز حيث يمكن التعامل مع ملفات ذات أسماء non-ANSI لذا تجد أنه تمت إضافة فئات جديدة من أجل حل مشكلة ترميز Unicode.
المبرمجون الذين انتقلوا من MFC إلى VCL يُدركون جيدا أن إنشاء الواجهات في C++ Builder سهل جدا لأنه يستخدم VCL وهي أسهل بكثير من MFC.
المكتبة المكافئة لــ VCL في Linux هي LCL و التي تعرف اختصارا بــ Lazarus Component Library, هذه الأخيرة متعددة المنصات وهي متوافقة 100% مع VCL.
البرامج التي كُتبت في بيئة C++ Builder
كُتب بها البرنامج الشهير WinRAR و المنقح المعروفIDA Pro وOllyDbg أيضا, بالإضافة إلى برنامج Magic ISO الذي يُستخدم للتعامل مع ملفات ISO لنسخ أقراص CDROM وحرقها دون أن ننسى العملاق Panda Titanium Antivirus و اللائحة تطول:
  • ImgBurn
  • Audiograbber
  • GoldWave
  • Clone CD
  • Norton PartitionMagic
  • Easy CD-DA Extractor
  • AVS Video Tools
  • ...
wxWidgets
post-219439-016039300 1346587007_thumb.j
ما هي wxWidgets ؟
wxWidgets كانت تُسمى wxWindows و لكن تم تغيير الاسم بعد أن تقدمت Microsoft بشكوى ضد الإسم القديم, wxWidgets عبارة عن مكتبة رسومية حرة و متعددة المنصات, تتكون من مجموعة أدوات لإنشاء واجهات رسومية يتغير شكلها تبعا لنظام التشغيل و هذا ما يُميزها عن بقية المكتبات المنافسة.
تملك wxWidgets دعم صناعي عريض, حيث تضم قائمة المستخدمين AOL و AMD و CALTECH و Lockheed Martin و NASA و مؤسسة تطبيقات المصادر المفتوحة و Xerox و آخرون كُثر.
المكتبة الأصلية مكتوبة بــ C++ لكن هذا لم يمنع من وجودة مجموعة Bindings للغات برمجية أخرى, مثل :
Python - wxPython
Perl - wxPerl
BASIC - wxBasic
Lua - wxLua
OCaml - wxCaml
JavaScript - wxJavaScript
Java - wxJava ou wx4j
Ruby - wxRuby
Eiffel - wxEiffel
Haskell - wxHaskell
C#/.NET - wx.NET
Euphoria - wxEuphoria
D – wxD
بعض هذه المكتبات أكثر تطورا من غيرها, لكن تبقى المكتبات الأكثر شعبية هي wxPython, wxPerl and wxBasic.
نبذة تاريخية
بدأت مكتبة wxWidgets و التي كانت تسمى wxWindows في 1992 في معهد تطبيقات الذكاء الاصطناعي بجامعة إدنبرغ بواسطة جوليان سمارت عندما كان يعمل على أداة رسم بياني أطلق عليها Hardy ، لم يرغب في الاختيار بين نشرها على منصات صن أو الحواسيب الشخصية ، فلذا قرر أن يختار أطار عمل متعدد المنصات . كانت الأدوات التجارية متعددة المنصات قليلة جدا ، فضلا على أن المعهد لا يملك الميزانية الكافية لها على أية حال ، لذا كان الخيار الوحيد هو بناء أداة متعددة المنصات، و في سبتمبر 1992 سمح الجامعة لجوليان أن يرفع الإصدار الأول من مكتبته على موقع ال FTP للجامعة. مكتبة wxWidgets (حرف w من Windows و x من X خادم النوافذ في اليونكس ) بدأت بدعم Xview و MFC 1.0 . بعدما أصبح واضحا أن XView قد بدأ عصره بالذهاب، كتبت نسخة wxWidgets لمنصة Motif . بدأ مستخدمو ++ Borland C بطلب نسخة لا تعتمد على MFC ، لذا نسخة الويندوز أعيدت كتابتها لتستخدم دوال API الويندوز الأصلية. [المصدر : وادي التقنية]
مع الوقت، بدأ بالظهور مجتمع صغير لـ wxWidgets ولكن متحمس، و أعدت القوائم البريدية. المشاركات و الإصلاحات بدأت بالإرسال إلى المشروع الجديد، كانت أكبر المشاركات هي نسخة Mac و Xt. بدأت مكتبة wxWidgets بشكل تدريجي باستقطاب المزيد والمزيد من المستخدمين من شتى أنحاء العالم: التجاري ، و الحكومي و مستخدمين الشركات – معظمهم راضين – الذين وجدوا أن wxWidgets توفر منتج أفضل و دعم أفضل من المنتجات التجارية التي نظروا إليها أو استخدموها.
خلال 1995 ، أصدر ماركوس هولزم نسخته من wxWidgets إلى منصة Xt وهي مجموعة أدوات X . هذا عنى أن البرمجيات يمكن أن تكتب و تعمل على أنظمة X من دون الحاجة إلى تثبيت Motif التي هي منتج تجاري.
في 1996 ، ركد مشروع wxWidgets قليلا. غادر جوليان معهد تطبيقات الذكاء الاصطناعي ليتفرغ إلى أعمال الاستشارة الحرة، وكانت هناك القليل من الإصدارات. على ما يبدو أن تقدم جافا غير المتوقف ألقى بعض الشك على مميزات مكتبات ++C . بعد عدة مشاركات ، أصبح كود wxWidgets بالأحرى متعب وبحاجة إلى إعادة تفكير جدية. في بداية عام 1997 ، بدأ التفكير جديا بإعادة هندسة wxWidgets مع دوال API مرنة بما فيه الكفاية لواجهات المستخدم الحالية والمستقبلية، مع المزيد من الأدوات و استخدام أفضل لـ ++C. بعد تداول الحوارات بين جوليان سمارت و ماركوس هولزم ( مؤلف نسخة Xt) كان هناك القرار الجدير بالاهتمام. جوليان سيكتب نسخة الويندوز و ماركوس سيجمع نسخة Motif و Xt ، وسيتشارك كلاهما في الأجزاء العامة. أفكار دوال wxWidgets 2 بدأت بالتشكل و بدأ العمل على كتابتها.
خلال 1997 بدأت في الظهور فكرة إنتاج بيئة سطح مكتب قياسي للينكس (GNOME) . هذه البيئة تعتمد على +GTK التي بنيت فوق X11، و بالرغم ذلك فإن التطبيقات المبنية على +GTK ستصبح قياسية لعالم اللينكس. كانت هناك مشكلة واحدة رئيسية، +GTK مبنية على لغة السي، ويوجد لها تغليف بسيط لـ ++C ( وغير قابل للنقل). في أغسطس 1997 ، قدم والفرام جلوجر اقتراح بأن wxWidgets2 يجب أن تنقل إلى +GTK. كان لروبرت روبلينج تحفظات أولية على الفكرة، ولكن في العموم هو داعم للفكرة. أصبح المحرك الرئيسي لـ wxGTK ، ونسخة اﻷلفا أصبحت متوفرة في بداية 1998. في مارس 1998 دمجت نسخة الويندوز و +GTK و وضعت في مستودع CVS وأصبحت متوفرة لجميع المساهمين لـ wxWidgets. في تلك الأثناء، أصبح فاديم زيتلين مطور نشطا في wxWidgets، وأعد معظم نشاط المطورين.
في بداية 1998 ، انقطع ماركوس هولزم عن wxWidgets2 و لكن جوليان سمارت بدأ نسخة wxMotif جديدة. فكرة نسخة Xt أبعدت، بعد أن توفر احتمالين للبرمجة اليونكس مجانية مع wxWidgets: أولا مكتبة wxGTK و wxMotif مع نسخة Motif المجانية Lesstif.
في سبتمبر 1998 ، بدأ ستيفن سومور نسخة جديدة من wxMac 2 مبنية في جزء منها على عمل جريج وايتهد المبدئي.
ظهرت wxWidgets 2.1.11 مصحوبة بصفوف wxHTML الرائعة من عمل فاكلاف سلافيك ، مع تحسينات لاحقة تشمل القدرة على الطباعة ومعاينة ، و تطبيق helpview و صف متحكم المساعدة لنظام المساعدة HTML متعدد المنصات. أعطى wxHTML التطبيقات وصول سهل إلى عرض النص المنسق و قابلية التقارير.
شهد منتصف 2000 إطلاق wxDesigner ، محرر الحوارات و أداة التطوير السريع من عمل روبرت روبلينج التي امتلكت انتشار واسعا. أيضا شهدت عام 2000 بداية wxUniversal وهي عبارة عن مجموعة من الأدوات للمنصات التي لا تمتلكها، لأن بعض المنصات تمتلك أدوات لا تمتلكها المنصات الأخرى. كتب wxUniversal بشكل أساسي فادم زيتلين و موله شركة تطبيقات SciTech ، وهي أيضا التي قامت بتمويل فاكلاف سلافيك لكتابة نسخة إلى منصتهم MGL .
في يوليو 2000 انضم جوليان سمارت إلى إدارة ردهات كامبردج في بريطانيا، وغادرها في فبراير 2002 ليتابع منتجاته عندما قررت ردهات إيقاف مشروع eCos الهادف إلى إنشاء نظام تشغيلي مضمن.
من أواخر 2001 إلى منتصف 2002 ، قام جوليان سمارت و روبرت روبلينج بإضافة نسخة wxX11 باستخدام أدوات wxUniversal ، وهذه النسخة تتطلب فقط نظام اللينكس و خادم X11، وهي مناسبة لأي بيئة لينكس تستخدم مواصفات بسيطة من المساحة. في أكتوبر 2002 نجح روبرت روبلينج ببناء نسخة wxX11 لنسخ اللينكس المألوفة التي تعمل على iPAQ. روبرت نجح أيضا في امتلاك wxGTK تعمل بـ +GTK مع دعم اليونيكود ، فاتحا بذلك إلى wxWidgets أسواقا جديدة.
في يوليو 2003 بدأت wxWidgets بالعمل على Windows CE ، و أثبت روبرت روبلينج أن تطبيقات wxGTK تعمل على GPE منصة اللينكس المضمنة.
نسخة OS/2 بواسطة دايفد ويبستار و ستيفان نيس تطور بشكل بطيء ولكن ثابت خلال سنوات الماضية.
في فبراير 2004 ، أعلن جوليان سمارت أن اسم المشروع سيغير اسمه إلى wxWidgets بدلا من wxWindows ، كنتيجة لضغط شركة مايكروسوفت عليه لاحترام العلامة التجارية " Windows “ المسجلة لدى مايكروسوفت في فرع المملكة المتحدة.
ويخطط لإصدار wxWidgets 3 مع بداية 2008 حيث تركز أكثر شيء على دعم اليونيكود بشكل واسع مع تطوير الدوال و تسهيل استخدامها.
ترخيص wxWidgets
توزع مكتبة wxWidgets تحت ترخيص مخصص ، مشابه إلى GNU Lesser General Public License - الذي يسمح باستغلالها لكتابة برامج حرة وتجارية معا - مع استثناء أن وضع العمل المشتق منها في صغيته الثنائية يمكن أن ينشر تحت شروط المستخدم الخاصة. هذا الترخيص هو ترخيص برامج الحرة ، ويجعل wxWidgets برنامجا حرا.
سلبيات wxWidgets
لكل مكتبة سلبيات و مكتبة wxWidgets لا تخلو منها ، وهذه أهمها:
  • ضعف في المكونات الرسومية التجارية لصنع شبكات رسومية جميلة و لصنع الرسوم البيانية، ولكن يمكن إلقاء نظرة على wxCode .
  • لا يوجد دعم لثيمات ، ما لم تستخدم wxUniversal أو wxSkin.
  • منصة wxX11 لا تقارن بالمكتبات الآخرى و غير مستقرة. يجب عليك استخدام wxGTK بدلا منها، وتبني تطبيقاتك على GTK بدلا عن X11 مباشرة. منصة wxX11 غالبا تستهدف إلى الأجهزة المضمنة والتي لا تملك GTK.
  • تحاول wxWidgets أن تدعم طاقم المميزات مكلفة ، وكنتيجة بعض المكونات قليلة الاستخدام ليست مستقرة أو لا يعتمد عليها بالمقارنة بالمكونات العامة. ومثلما مع كل مكتبة أدوات مفتوحة المصدر ، الاختبارات المعمقة أفضل حل هنا.
  • بالنسبة للغة العربية فإنها لا تدعم تغيير اتجاه البرنامج من اليمين إلى اليسار بشكل جيد ، بالرغم أن المكتبات الأصلية تدعم هذه الخاصية.
  • تطورها بطيء نوعا ما وهذا ما يعيقها عن الإنتشار الكامل.
مميزات wxWidgets
  • مكتبة wxWidgets لا فقط على ++C ، ولكنها أيضا تملك جسورا إلى بايثون و بيرل و جافا و إيفيل و سي شارب (الدوت نت ) و البيسك و روبي و lua و حتى جافا سكربت. مما يسهل عملية البرمجة بها لمن لا يعرفون لغة ++C
  • تعتبر أحد المكتبات أدوات GUI المكتملة، وتملك العديد من الصفوف الخدمية.
  • تمتلك توثيقا جيدا .
  • مجانية للاستخدام الشخصي و التجاري معا.
  • كلما أمكن تستخدم مكتبة wxWidgets منصة التطوير الأصلية. وهذا يعني أن البرنامج إذا بني على الويندوز سيأخذ مظهر و سمة برامج الويندوز و عندما يبنى على منصة اللينكس سيأخذ مظهر وسمة برامج اللينكس.
برامج تستخدم wxWidgets
  • Poedit: برنامج لترجمة ملفات PO التي تستعمل في برامج اللينكس بكثرة.
  • Xara Xtreme : برنامج لرسوميات المتجهة وهو نسخة خاصة باللينكس.
  • AOL Communicator : برنامج عميل الانترنت المشهور
  • Audacity : برنامج تحرير الصوتيات و المقاطع الصوتية
  • Kirix Strata : برنامج قواعد بيانات دينامكي
  • Chandler : برنامج الجدولة والمواعيد مشابه جدا لبرنامج أوتلوك.
  • Code::Blocks : بيئة التطوير المعروفة.
  • مشغل الملتيمديا المشهور VLC قبل أن ينتقل إلى QT في عام 2008.
Framework QT
post-219439-044117900 1346587001_thumb.p
ما هي QT ؟
QT عبارة عن بيئة رسومية جميلة و التعامل معها سهل جدا, تمت كتابتها بــ C++ من طرف Qt Development Frameworks. تتميز هذه المكتبة بالسرعة و تعدد المنصات. لكي تعمل على بيئة QT يجب أن تكون ملما بأساسيات الـــ OOP و هذا طبيعي جدا لأن QT عبارة عن Object-Oriented Framework.
Qt متوفرة تحت نوعين من الرخص: رخصة خاصة (مدفوعة الثمن) للبرامج المغلقة ورخصة الـ LGPL من أجل معظم أنظمة التشغيل (Windows, Unix with X11, Linux MacOS,...)
صُممت QT أساسا لـ C++ لكن لم يمنعها هذا من التوسع إلى لغات أخرى مثل Python, PHP, Ruby, C, Perl, C#, Java.
نبذة تاريخية
منصة العمل Qt أصبحت متوفرة للعامة في مايو 1995. لقد طورت مبدئيا من قبل هافارد نورد (المدير التنفيذي لشركة Trolltech) و إيريك شامبنج ( رئيس شركة Trolltech ) . هافارد و إيريك اجتمعا في معهد النرويجي للتكنولوجيا في تروندهايم ، حيث تخرج كلاهما بشهادة الماجستير في علوم الحاسوب. [المصدر : وادي التقنية]
يعود اهتمام هافارد في تطوير واجهة المستخدم الرسومية GUI باستخدام ++C لعام 1988 عندما كلف بواسطة شركة سويدية بتطوير منصة عمل GUI متوافقة مع ++C. بعد سنتين وفي صيف 1990 عمل هافارد وإيريك معا في تطبيق قاعدة بيانات ++C لصور الأشعة فوق السمعية. النظام تطلب أن يكون قادرا أن يعمل بواجهة رسومية للمستخدم ويعمل على منصات اليونكس والماكنتوش و الويندوز. في أحد أيام ذلك الصيف ذهب هافارد وإيريك للخارج للاستمتاع بشروق الشمس و لما كانا جالسين مقعد الحديقة ، قال هافارد : " نحن بحاجة إلى نظام عرض كائني المنحى." نتيجة النقاش خلصت إلى قاعدة عقلانية لمنصة عمل رسومية متعددة الأنظمة وكائنية المنحى يجب أن يبدؤوا حالا في بناءها.
في عام 1991 ، بدأ هافارد بكتابة الصفوف التي في النهاية أصبحت Qt ،بالتعاون مع إيريك في التصميم. في السنة اللاحقة، أتي إيريك بفكرة " signals and slots" بالعربي " الإشارات والمستقبلات" ، بسيطة و لكن نموذج برمجة واجهة رسومية GUI قوية ، والتي تبنتها عدة أدوات برمجية أخرى. أخذ هافارد الفكرة و أنتج تطبيق مكتوب. في عام 1993 هافارد وإيريك طوروا أول نواة رسومية و استطاعوا إعداد مكوناتهم الخاصة. مع نهاية السنة ، اقترح هافارد بأن يدخلوا في العمل معا لبناء " أفضل منصة عمل رسومية مكتوبة باستخدام ++C في العالم".
بدأ عام 1994 بشكل عاثر مع مبرمجين صغار يريدون دخول سوق راسخ ، من دون زبائن ومنتج غير مكتمل و بدون أموال. لحسن الحظ ، كانتا زوجاتهما تعملان ، ولذا استطاعن أن يدعمن أزواجهن للسنتين التي توقعهما إيريك وهافارد بأنهما بحاجة لهما لتطوير المنتج و البدء باكتساب عائدات.
حرف " Q" اختير كبادئة للصف بسبب أن الحرف يظهر جميلا في خط إيماكس هافارد. وحرف "t" أضيف لاختصار " toolkit" اشتقاقا من Xt والتي تعني X Toolkit . أعلن عن الشركة في 4 مارس من عام 1994، في الأصل كـ Quasar Technologies ثم كـ Troll Tech و اليوم كـ Trolltech.
في أبريل 1995 ، يعود الفضل إلى أحد أساتذة هافارد الجامعيين إلى حدوث تواصل بالشركة النرويجية Metis التي أعطتهم عقد لتطوير برمجيات معتمدة على Qt. في ذلك الوقت ، استأجرت ترولتك أرنت جولبراندسن الذي خلال ست سنواته في ترولتك أبدع و أعد نظام توثيق مبتكر ، بالإضافة إلى المشاركة في كود Qt.
في 20 مايو 1995 رفعت Qt 0.90 إلى سيرفر sunsite.unc.edu. بعد ستة أيام ، أعلن عن اﻹصدارة على comp.os.linux.announce. كانت هذه أول إصدارة عام من Qt. كيوتي يمكن أن تستخدم لتطوير كلا النظامين الويندوز واليونكس و تقدم نفس الدوال API في كلا المنصتين. Qt توفرت تحت ترخيصين من اليوم الأول: الترخيص التجاري والذي يستخدم للتطوير التجاري و نسخة البرنامج المجانية تحت ترخيص FreeQt للتطوير البرمجيات مفتوحة المصدر. العقد مع شركة Metis ترك ترولتك عائمة ، خلال عشرة أشهر طوال لا أحد اشترى الترخيص التجاري لـ Qt.
في مارس 1996 ، أصبحت وكالة الفضاء الأوربية الزبون الثاني لدى Qt بشراء عشرة تراخيص تجارية. مع رباطة الجأش ، استأجر إيريك وهافارد مطور آخر. أطلقت اﻹصدارة Qt 0.97 بنهاية مايو وفي 24 سبتمبر 1996 ظهرت Qt 1.0 إلى النور. مع نهاية السنة ، وصلت Qt إلى اﻹصدارة 1.1 و ثمانية زبائن جدد ، كل من بلاد مختلفة اشتروا 18 ترخيصا تجاريا فيما بينهم. وفي هذه السنة ظهر تأسيس مشروع KDE بقيادة ماتثياس إيتراك.
أصدرت Qt 1.2 في أبريل 1997. كان قرار ماتثياس إيتراك باستخدام Qt لبناء KDE ساعد Qt لأن تصبح معيار واقعي لتطوير الواجهات الرسومية باستخدام ++C في اللينكس. اﻹصدارة 1.3 ظهرت في سبتمبر 1997.
في عام 1998 انفجر خلاف بعدما أصبح واضحا أن KDE ستكون المسيطرة على أسطح المكتب في اللينكس ﻷن رخصة FreeQt لم تكن تتوافق مع فلسفة المصادر الحرة مع أنها كانت مفتوحة المصدر ، وبما أن KDE مبنية على Qt ، فإن الكثير من الناس في حركة المصادر الحرة قلقوا بأن الجزء اﻷساسي من نظامهم التشغيلي يمكن أن يكون مملوكة وليست حرة.
وهذا أعطى دافعا ﻷمرين : مشروع مكتبة Harmony toolkit والتي هدفت إلى إنتاج نسخة مطابقة لمكتبة Qt تحت ترخيص البرمجيات الحرة، و الأمر الثاني و اﻷكثر أهمية مشروع سطح مكتب GNOME والذي هدف أساسا ﻹنتزاع مكانة KDE. سطح مكتب جنوم استخدم مكتبة أدوات GTK+ والتي في اﻷصل كتبت لبرنامج GIMP و تستخدم بشكل أساسي لغة السي للبرمجة.
في هذه اللحظة ارتكبت شركة ترولتك خطأ بعدم تعديل رخصة FreeQT لتكون متوافقة مع رخصة غنو العمومية ، وهي غلطة تمنى رؤساء ترولتك لو لم يقعوا فيها، ﻷنهم ضيعوا فرصة السيطرة على سطح المكتب في اللينكس و ظهر جنوم الذي دعمته شركة ردهات في اﻷساس ثم انتشر بشكل واسع حتى أصبح سطح المكتب المفضل لجمهور واسع من مستخدمي اللينكس وخاصة بعد صدور توزيعة أوبنتو الشهيرة.
انضم ماتثياس إلى ترولتك في عام 1998، وآخر إصدارة رئيسية من Qt 1 ، الاصدارة 1.40 صنعت في سبتمبر من ذلك العام. أطلقت Qt 2.0 في يونيو 1999. Qt 2 امتلكت ترخيص مفتوح المصدر جديد ، ترخيص Q العام QPL ، والذي يتوافق مع تعريف المصادر المفتوحة، بعد إصدار QPL اختفى مشروع مكتبة Harmony toolkit ﻷنه لم يكن له داعي. في أغسطس 1999 ، فازت Qt بجائزة عالم اللينكس لأفضل مكتبة أو أداءة. و في ذلك الوقت ، أسست Trolltech Pty Ltd فرع أستراليا.
أطلقت ترولتك نواة Qtopia ( ثم أطلق عليها Qt المضمنة ) في عام 2000. لقد صممت للعمل في أجهزة اللينكس المضمنة ولتقدم نظام النوافذ الخاص بها كبديل خفيف عن X11 . كلا المنتجان Qt/X11 و نواة Qtopia قدّما تحت استخدام رخصة غنو العمومية ( GPL) بالإضافة مع الترخيص التجاري. مع نهاية 2000 ، أسست ترولتك فرعها في الولايات المتحدة الأمريكية و أطلقت أول إصدارة من Qtopia منصة التطبيق إلى الهواتف النقالة و المساعدات الشخصية PDA. فازت نواة Qtopia بجائزة عالم اللينكس كـ"أفضل حل لينكس مضمن" في عام 2001 و 2002 و حقق هاتف Qtopia نفس النتيجة في 2004.
في عام 2001 أطلقت Qt 3.0. توفرت Qt لمنصة الويندوز و الماكنتوش Mac OS X و اليونكس واللينكس ( سطح المكتب و المضمن ). قدمت Qt 3 24 صفا جديدا و تجاوز كودها 500000 سطر. كانتQt 3 خطوة كبيرة للأمام من Qt2 ، احتوت بشكل كبير تحسين التوطين و دعم اليونيكود، وأداة جديدة بالكامل لعرض النصوص وتحريرها، و صف للتعابير الاعتيادية المماثلة لبيرل. فازت Qt3 بجائزة " جولت الإنتاجية" لتطوير البرمجيات في عام 2002.
في صيف 2005 أطلقت Qt 4.0. بحوالي 500 صف و أكثر من 9000 دالة وظيفية ، Qt4 أكبر و أغنى من أي إصدارة سابقة، وقد قسمت إلى عدة مكتبات لذا المطورين يحتاجون ربط برامجهم بالأجزاء التي يحتاجونها من Qt فقط. Qt4 متقدمة جدا على الإصدارات السابقة بتحسينات اشتملت على مجموعة جديدة فاعلة وسهلة الاستخدام من حاويات القوالب، و أدوات عرض ووحدات متقدمة ، و منصة رسم 2D سريعة ومرنة ، و صفوف تحرير وعرض النصوص اليونيكود قوية، وبدون ذكر الالآف من التحسينات الصغيرة في كل نطاق صفوف Qt. كانت اﻹصدارة Qt 4 أول إصدارة من Qt تتوفر بترخيصين التجاري ومفتوح المصدر لكل المنصات التي تدعمها.
أيضا في 2005 ترولتك فتحت مكتب ممثل لها في بكين لتقديم خدمات البيع و التدريب و الدعم الفني لـ Qtopia للزبائن في الصين و تلك المنطقة.
في هذه السنة وصلت أرباح الشركة ولأول مرة 6.7 مليون دولار. وبعدها في السنوات التالية أصبحت نسبة النمو في إيرادات الشركة 40 % وبشكل متوالي في سنوات 2006 و 2007 .
تملك ترولتك اﻻن أكثر 5000 زبون و تملك علاقات تجارية مع أكثر من 2000 شركة عالمية من بينها IBM و Adobe و Skype و Google و Shell وغيرها من الشركات.
في عام 2007 وصل عدد موظفي شركة ترولتك إلى 250 موظف في جميع أفرع الشركة في النرويج و ألمانيا و أمريكيا و الصين و أستراليا.
منذ انطلاق ترولتك، نمت شهرت Qt بدون انقطاع واستمرت في النمو لهذا اليوم. هذا النجاح انعكاس لكل من جودة Qt ومدى الاستمتاع أثناء استخدامها. في العقد الأخير ، نمت Qt من منتج يستخدم بواسطة فئة محددة تعرفه إلى منتج يستخدم بشكل يومي بواسطة الآلاف من الزبائن و عشرات اﻵﻵف من مطوري البرامج الحرة في كل أنحاء العالم.
في عام 2010, أطلقت شركة نوكيا الإصدارة 4.7 من منصة التطوير Qt متعددة المنصات لتصميم التطبيقات. هذه الإصدارة قدمت تقنية جديدة وهي Qt UI Creation Kit وهي تتيح إنشاء واجهات رسومية دينامكية بشكل أسهل وأكثر احترافية عن الطرق التقليدية.
هذه التقنية تتكون من ثلاثة أشياء:
- لغة QML وهي لغة مبنية مشابهه لجافا سكربت تستغل قدرات مكونات Qt لتمكين المطورين والمصممين للتعاون معا لإنشاء تجربة للمستخدم في التحريك والانسيابية.
- مكتبة QtDeclarative وهي تقدم كمحرك داخلي يقوم بترجمة QML إلى QGraphicsScene.
- تحسين Qt Creator لدعم وتحرير ملفات QML.
في التاسع من أغسطس 2012, وقعت شركة Digia اتفاقية مع شركة Nokia لنقل ملكية Qt مقابل 4,9 مليون دولار. في نفس الوقت, أعلنت Digia أنها تريد توسيع نطاق دعم QT ليشمل Windows 8 و Android و iOS.
Modules
تنقسم مكتبات Qt إلى عدة موديلات (Modules ), مثل :
  • QtGui : و هو موديل خاص بالتعامل مع الواجهة, تستطيع من خلاله إضافة نوافذ, أزرار, رسائل, صور و ما إلى ذلك.
  • QtOpenGL : و هو موديل خاص برسومات الثلاثية الأبعاد, يُستعمل في الألعاب, المحاكات و غيرها.
  • QtSql : و هو موديل خاص بالتعامل مع قواعد بيانات SQL و تسييرها.
  • QtNetwork : موديل خاص ببرمجة الشبكات و التعامل مع الإنترنت كتحميل الملفات, و رفعها
توجد موديلات أخرى للتعامل مع XML و غيرها الكثير ..
إصدارات QT
توجد أربعة أنواع من إصدارات QT :
  • Qt Console نسخة التطوير الغير رسومي non-GUI.
  • GUI Framework وهي موجهة لبناء واجهات التطبيقات الرسومية والشبكات وقواعد البيانات، يطلق عليها أيضا اسم Desktop Light.
  • Full Framework وهي نسخة تجارية كاملة تحتوي على كل شيء.
  • إصدار مفتوح المصدر بالكامل (Qt Open Source Edition)
.
كما توجد نسخ تجارية توقف تطويرها ولها دعم تجاري فقط مثل Qt Jambi الموجهة للجافا.
مميزات QT
  • توفر أكثر من 500 فئة و أكثر من 9000 دالة تغطى كافة متطلبات السوق البرمجي.
  • التوثيق الممتاز, لكافة الدوال والفئات, وسهل الاستخدام والبحث معا.
  • الدعم الفني الرائع الذي يركز على الجودة المنتج.
  • تعمل على جميع المنصات من دون الحاجة إلى تعديل الكود لكل منصة.
  • كلا الترخيصين يوفر سورس مكتبة Qt بالكامل مما يسمح لك بالتعديل فيها لتتناسب احتياجاتك البرمجية المختلفة.
  • وفرة البرامج مفتوحة المصدر المكتوبة بها مما يوفر لك مادة برمجية هائلة للتعلم والاستفادة منها.
أشهر البرامح المكتوبة بــ QT
هناك الكثير من التطبيقات التي بنيت بواسطة مكتبة Qt ، و هذه بعض أشهر الأمثلة :
  • Adobe Photoshop Album برنامج لإدارة وترتيب الصور
  • Doxygen منتج توثيق API
  • Google Earth برنامج ثلاثي الأبعاد للخرائط العالم
  • KDE سطح المكتب المشهور في عالم اللينكس
  • KDELibs المكتبة التي بنيت عليها الآلاف من تطبيقات KDE مثل Amarok و K3b و KDevelop و KOffice
  • Last.fm Player عميل سطح المكتب لإذاعة الإنترنت و موقع مجتمع الموسيقى
  • Motorola A760 يستخدم Qtالمضمنة في واجهته الرسومية
  • Opera متصفح الإنترنت
  • Psi عميل الرسائل اللحظية لـ XMPP
  • Scribus برنامج للنشر المكتبي
  • Skype برنامج المحادثة الشهير, يُستخدم للتحدث عبر الويب P2P VOIP
  • TOra أداة للتحكم بقواعد البيانات وخاصة أوراكل.
  • VirtualBox برنامج لمحاكة اﻷجهزة يستخدم في العمليات التخيلية
  • Xconfig أداة إعداد نواة اللينكس.
إلى هنا أصل بك أخي القارئ إلى نهاية هذه الجولة السريعة, كنت أود وضع روابط فرنسية تحتوي على دورات و دروس مفصلة في كل مكتبة لكن تراجعتُ عن الأمر نظرا لأن أغلب أعضاء المنتدى يدرسون البرمجة بالإنجليزية فقط.
نظرا لطول المقالة, اكتفيتُ بأربع مكتبات رسومية. أعتذر للآنسة GTK التي لم نتطرق لها في هذه المقالة.

قواعد البيانات وبنوك المعلومات وأمنهما

بسم الله الرحمن الرحيم

البيانات هي مجموعة الحقائق والأحداث الغير منظمة والتي ليس لها معنى صريح و مستقاة من مصادرها في الحياة و التي يمكن تسجيلها و قياسها . أما المعلومات فهي البيانات بعد معالجتها بحيث تصبح منظمة ولها معنى واضح و محدد ، و يمكن الاستفادة منها بشكل أو بأخر , يمكن وصف العلاقة بين البيانات والمعلومات كما يلي : فالمعلومات هي عبارة عن بيانات تمت معالجتها , قواعد البيانات هي عبارة عن مجموعة بيانات ذات علاقة عادتاً ما تصف نشاطات مؤسسة ما لكن ليس كل مجموعة من البيانات المترابطة يمكن تسميتها قاعدة بيانات , فقاعدة البيانات هي مصدر مركزي للبيانات مجمع ومنظم بطريقة يمكن ان تخدم تطبيقات مختلفة ..
الفرق بين قاعدة البيانات وبنوك المعلومات
الفرق بسيط جداً ، قاعدة البيانات هي جزء من بنوك المعلومات ، فقواعد البيانات يطبع عليها طابع التخصص ، أما بنوك المعلومات فهي عامة ومصطلح بنوك المعلومات أشمل من مصطلح قواعد البيانات ..
نظام معالجة البيانات :
تعرف عملية تحويل البيانات إلى معلومات باسم نظام معالجة البيانات Data Processing System ويتكون نظام معالجة البيانات من ثلاثة مراحل هي :
المدخلات ( INPUT)
وهي عبارة عن ملف البيانات المطلوب معالجتها ، مثلاً ملف الطلاب الذي يحتوي على ( اسم الطالب - رقم الطالب - درجة الامتحان .
المعالجة (PROCESSING )
هي العمليات المختلفة التي ستنفذ على البيانات للحصول على المعلومات مثل ( العمليات الحسابية أو المنطقية – عمليات التصنيف والترتيب … ) وتتم عملية المعالجة بإتباع تعليمات معينة توجه جهاز الحاسب لأداء عمل ما على البيانات وتسمى مجموعة التعليمات هذه باسم البرنامج .
المخرجات (OUTPUT )
وهي ناتج عملية معالجة البيانات وتسمى المعلومات .
فمثال .. عند حساب رواتب الموظفين في إحدى المؤسسات فإن نظام معالجة البيانات يكون كالتالي :
المدخلات : هي ملف بيانات الموظفين الذي يحتوي على ( رقم الموظف , الاسم , عدد ساعات العمل , معدل أجر الساعة)
المعالجة :
1- قراءة رقم الموظف ، اسمه ، عدد ساعات العمل ، معدل أجر الساعة .
2- حساب الدخل = عدد ساعات العمل × معدل أجر الساعة .
3- طباعة رقم الموظف واسمه ومرتبه .
4- تكرار عملية المعالجة للموظف التالي حتى نهاية الملف .
المخرجات :
عبارة عن ملف ( تقرير ) يحتوي على المعلومات التالية لكل موظف ( الرقم , الاسم , الدخل )
مخرجـــات: معالجة مدخلاً
ما هي قاعدة البيانات ؟
قاعدة البيانات هي أداه لتجميع المعلومات وتنظيمها , يمكن لقواعد البيانات تخزين معلومات عن الأشخاص والمنتجات والطلبات وغيرها , تبدأ العديد من قواعد البيانات كقائمة في برنامج معالجة الكلمات أو جدول البيانات , وكلما زاد حجم القائمة ، كلما بدأ ظهور التكرار وعدم التناسق فيما بين البيانات , فيصبح من الصعب فهم البيانات من خلال هذه القائمة ، كما تكون طرق البحث أو سحب مجموعات فرعية من البيانات لمراجعتها محدودة , وبمجرد ظهور تلك المشاكل ، يكون من الأفضل نقل البيانات إلى قاعدة بيانات منشئة بواسطة نظام إدارة قاعدة البيانات ( DBMS ) .
تعتبر قاعدة البيانات الإلكترونية هي حاوية من الكائنات , يمكن لقاعدة بيانات واحدة أن تحتوي على أكثر من جدول واحد , على سبيل المثال ، لا يعتبر نظام تعقب المخزون الذي يستخدم ثلاثة جداول ثلاث قواعد بيانات ، ولكن قاعدة بيانات واحدة تحتوي على ثلاثة جداول ويمكن تنفيذ ما يلي :
• إضافة بيانات جديدة إلى قاعدة بيانات، مثل عنصر جديد في مخزون .
• تحرير البيانات الموجودة في قاعدة البيانات، كتغيير الموقع الجديد للعنصر .
• حذف المعلومات، ربما إذا تم بيع عنصر أو إهماله .
• تنظيم البيانات وعرضها بطرق مختلفة .
من أجزاء قاعدة بيانات
1- الجداول
من ناحية المظهر يشبه جدول قاعدة البيانات جدول البيانات حيث يتم تخزين البيانات في صفوف وأعمدة , لذلك في معظم الأحوال يكون من السهل استيراد جدول بيانات إلى جدول قاعدة البيانات , أما نقطة الاختلاف الرئيسية بين تخزين البيانات في جدول بيانات أو تخزينها في جدول قاعدة بيانات فتكمن في كيفية تنظيم البيانات.
للحصول على أعلى معدل من المرونة في قاعدة بيانات ، يجب تنظيم البيانات في جداول بحيث لا يحدث تكرار , على سبيل المثال ، إذا كنت تخزن معلومات عن الموظفين ، يجب أن يتم إدخال كل موظف مرة واحدة فقط في جدول تم تعيينه ليتضمن بيانات الموظفين , يتم تخزين بيانات المنتجات في الجدول الخاص بها ، ويتم تخزين البيانات الخاصة بالمكاتب الفرعية في جدول آخر , تسمى هذه العملية التسوية.
تتم الإشارة إلى كل صف في الجدول كسجل , السجلات هي أماكن تخزين قطع المعلومات الفردية , يحتوي كل سجل على حقل واحد أو أكثر , تقابل الحقول الأعمدة الموجودة في الجدول , على سبيل المثال ، قد تمتلك جدولاً يسمى "الموظفون" حيث يحتوي كل سجل ( صف ) على معلومات عن موظف مختلف ، ويحتوي كل حقل ( عمود ) على نوع آخر من المعلومات ، كالاسم الأول واسم العائلة والعنوان وهكذا , يجب تعيين نوع بيانات محدد لكل حقل ، سواء أكان نص أو تاريخ أو وقت أو عدد أو نوع آخر.
يمكن وصف السجلات والحقول بطريقة أخرى عن طريق تصور كتالوج بطاقات ذو نمط قديم خاص بالمكتبة. تتقابل كل بطاقة في الخزانة مع سجل في قاعدة البيانات. وتتقابل كل قطعة من المعلومات في بطاقة مفردة ( الكاتب والعنوان وما إلى ذلك ) مع حقل في قاعدة البيانات.
2- النماذج
تتم الإشارة إلى النماذج في بعض الأحيان كـ "شاشات إدخال بيانات" فهي الواجهات المستخدمة للعمل باستخدام البيانات، وغالبًا ما تحتوي على أزرار أوامر تنفذ أوامر مختلفة , يمكنك إنشاء قاعدة بيانات دون استخدام نماذج في خطوة بسيطة عن طريق تحرير البيانات في جداول بيانات الجدول , غير أن معظم مستخدمي قواعد البيانات يفضلون استخدام النماذج لعرض البيانات وإدخالها وتحريرها في الجداول.
توفر النماذج تنسيق سهل الاستخدام للتعامل مع البيانات، كما يمكنك إضافة عناصر وظيفية إليهم، مثل أزرار الأوامر , يمكنك برمجة الأزرار لتحديد البيانات التي تظهر في النموذج ، أو فتح نماذج أو تقارير أخرى، أو تنفيذ مهام أخرى متنوعة , على سبيل المثال ، قد تمتلك نموذجًا يسمى "نموذج العميل" يحتوي على بيانات العميل , قد يحتوي هذا النموذج على زر يفتح طلب بحيث يمكنك إدخال طلب جديد فيه لهذا العميل.
تسمح لك النماذج أيضًا بالتحكم في كيفية تفاعل المستخدمين الآخرين مع البيانات الموجودة في قاعدة البيانات , على سبيل المثال، يمكنك إنشاء نموذج يعرض فقط حقول معيّنة ويسمح فقط بتنفيذ عمليات معيّنة. وهو ما يساعد على حماية البيانات وضمان إدخال البيانات بشكل صحيح.
3- التقارير
التقارير هي ما تستخدمه لتلخيص البيانات وعرضها في الجداول , غالبًا ما يجاوب التقرير على سؤال محدد، مثل "كم من الأموال تلقينا من كل عميل هذا العام؟" أو "ما هي المدن التي ينتمي إليها عملاؤنا؟" يمكن تنسيق كل تقرير لعرض المعلومات بأكثر طريقة ممكنة قابلة للقراءة.
يمكن تشغيل التقرير في أي وقت ، وسيعكس دائمًا البيانات الحالية في قاعدة البيانات , يتم تنسيق التقارير بشكل عام لتتم طباعتها ، ولكن يمكن أيضًا عرضها على الشاشة أو تصديرها إلى برنامج آخر أو إرسالها كرسائل بريد إلكتروني.
4- الاستعلامات
تعتبر الاستعلامات هي الجزء الأساسي في قاعدة البيانات، حيث يمكنها القيام بعدة وظائف , غير أن وظيفتها الأساسية هي استرداد بيانات معيّنة من الجداول , غالبًا ما تكون البيانات التي ترغب في رؤيتها منتشرة في عدة جداول ، فتمكنك الاستعلامات من عرضها في ورقة بيانات واحدة , وكذلك ، بما أنك لا ترغب دائمًا في رؤية كافة السجلات مرة واحدة، تسمح لك الاستعلامات بإضافة معايير لـ "تصفية" البيانات لتقتصر على السجلات التي تريدها فقط , كما تعتبر الاستعلامات غالبًا هي مصدر السجل للنماذج والتقارير.
تعد بعض الاستعلامات "قابلة للتحديث" ، بمعنى أنه يمكنك تحرير البيانات في الجداول الأساسية من خلال ورقة بيانات الاستعلام. إذا كنت تعمل في استعلام قابل للتحديث، تذكر أن التغييرات التي تقوم بها تطبق بالفعل على الجداول، وليس فقط على ورقة بيانات الاستعلام.
تنقسم الاستعلامات إلى نوعين أساسيين : استعلامات التحديد والاستعلامات الإجرائية , يقوم استعلام التحديد ببساطة باسترداد البيانات وجعلها متوفرة للاستخدام. يمكنك عرض نتائج الاستعلام على الشاشة ، أو طباعتها ، أو نسخها إلى الحافظة , أو يمكنك استخدام إخراج الاستعلام كمصدر السجل لنموذج أو تقرير.
أما الاستعلام الإجرائي ، كما يتضح من الاسم ، فيقوم بتنفيذ مهمة باستخدام البيانات , يمكن استخدام الاستعلامات الإجرائية لإنشاء جداول جديدة، أو إضافة بيانات إلى الجداول الموجودة ، أو تحديث البيانات ، أو حذف البيانات.
نظم إدارة قواعد البيانات
لأن قواعد البيانات مهمة ومؤثرة جداً في جميع المجالات والأنشطة الرئيسية , لذلك يلزم وجود نظم معينة لتنظيم وإدارة البيانات المخزنة , وهو ما يطلق عليه نظم إدارة قواعد البيانات (DBMS) Database Management Systems.
وتعرف نظم إدارة قواعد البيانات :
بأنها هي البرامج التي تساعد على إنشاء قواعد البيانات والتعامل معها وتشغيل البيانات المخزنة بها , فمثلاً بعد إضافة عملاء جدد لدليل التليفون فإنك تحتاج إلى ترتيب الأسماء من جديد أبجديا أو ترتيب عناوينهم , بمعنى آخر تتيح للمستخدم إضافة بيانات جديدة وتحديث البيانات وطباعة التقارير على الشكل التي تريده مثل القوائم و الجداول و النماذج و الفواتير .. الخ
وقد تكون قاعدة البيانات كبيرة جدا وتحتوي علي آلاف من البلايين من الكلمات وهي اكبر من الذاكرة الموجودة ونتيجة لذلك كانت لـ DBMS أن تعالج وتدير البيانات في الذاكرة الثانوية ومن البرامج التي صممت لهذه الشأن كثيرة منها التي تعمل على الحاسبات الكبيرة Mainframes أو التي تعمل علي الحاسبات الشخصية PCs
ومثل هذه البرامج : أوراكل و MY sql والأكسس
ويتكون نظام إدارة البيانات من مجموعة من الملفات بالإضافة إلى البرنامج أو مجموعة البرامج التي تتضافر لحل مشكلة أو لتحويل نظام يدوي إلى نظام يعمل بالحاسب مثل تحويل نظام حسابات العملاء أو حسابات المخازن من نظام الدفاتر اليدوية إلى نظام وملفات تستخدم بواسطة الحاسب فإن هذه البرامج مع ملفات النظام يطلق عليه نظام إدارة قاعدة البيانات أو قد يشتمل على مجموعه من البرامج بالإضافة إلى ملفات النظام وفي هذه الحالة فإن البرامج مجتمعه يطلق عليها نظام إدارة قاعدة البيانات ..
وبعيداً عن التعقيدات ودون الدخول في تفاصيل وفرت نظم إدارة قواعد البيانات المرونة المطلوبة عن نظم إدارة الملفات التي كانت تستخدم من قبل , ولكن كل ما نود أن نعرفه أن الملفات المسلسلة و الملفات الثنائية و العشوائية لها الدور الأكبر في الانتقال من نظام الملفات إلى نظام قواعد البيانات .
أنواع نظم إدارة قواعد البيانات :
ولهذا فأن نماذج البيانات هي تمثيل بيانات العالم الحقيقي بصورة يسهل استخدامها بواسطة الحاسب وهناك أنواع من نماذج البيانات تتوقف على نظام إدارة قواعد البيانات المستخدم وكذلك على طبيعية البيانات , وتبعاً لأنواع نماذج البيانات فهناك ثلاثة أنواع شائعة من نظم إدارة قواعد البيانات وهي ..
- نظم إدارة قواعد البيانات الهرمية Hierarchical DBMS
- نظم إدارة قواعد البيانات الشبكية Network DBMS
- نظم إدارة قواعد البيانات العلائقية Relational DBMS
مميزات قواعد البيانات :
- إمكانية إضافة ملفات جديدة.
- إضافة بيانات جديدة على الملفات الموجودة في القاعدة.
- استرجاع بيانات من الملفات المكونة لقاعدة البيانات.
- تحديث البيانات.
- حذف البيانات من الملفات.
- يمكن تعديل البرامج دون تعديل البيانات والعكس صحيح.
- يمكن للمستخدم النظر إليها على أنها ملفات متكاملة.
- تلبي حاجات كافة المستخدمين للبيانات.
- يمكن فرض قيود التأمين والسرية على بعض البيانات الهامة.
ما هو التصميم الجيد لقاعدة البيانات ؟
هناك بعض المبادئ الخاصة بعملية تصميم قاعدة بيانات. يتمثل المبدأ الأول في أن المعلومات المتكررة ( تسمى أيضاً البيانات المكررة) غير صحيحة ، لأنها تؤدي إلى إهدار المساحة وزيادة احتمال ظهور أخطاء عدم التوافق. ويتمثل المبدأ الثاني في أهمية تصحيح المعلومات وإكمالها. إذا كانت قاعدة البيانات تحتوي على معلومات غير صحيحة، سيتضمن أي تقرير يحتوي على معلومات من قاعدة البيانات هذه على معلومات غير صحيحة أيضاً , وعلى ذلك ، سيحدث خطأ في أي قرار تتخذه يستند إلى هذه التقارير.

سلسلة ألعاب سيارات جديدة من مسلسل Top Gear

بسم الله الرحمن الرحيم




Top Gear سلسلة المسلسلات التليفزيونية البريطانية الشهيرة عن السيارات، تقترب الآن من الحصول على سلسلة من الألعاب للهواتف المحمولة، حيث قررت هيئة الإذاعة البريطانية BBC في جميع أنحاء العالم تقديم رخصة "توب جير" للمطور الفنلندية Motorious Entertainment لتحويلها للعبة.

والشركة المطورة الفنلندية هي ستوديو متخصص في الألعاب المحمولة ويتألف من قدامى مطوري في صناعة الألعاب، والأشخاص الذين عملوا لمشاريع المحمول، مع أجهزة كمبيوتر معروفة مثل سلسلة FLATOUT، سيجا، ريدج وغيرها.

وبعد حصول الشركة المطورة على الرخصة فإن الشركة بدأت في الاستعداد لإطلاق ألعاب الهاتف الذكية وهي ثلاث نسخ من اللعبة سيتم إتاحتها على منصات Android وiOS.

واللعبة الأولى تسمى Top Gear the Road Trip ومن المفترض أن تنطلق في نهاية عام 2016، والنسختان الأخريان من اللعبة ستطلقان في عام 2017.

وفي Top Gear سيكون على اللاعبين القيام برحلة عبر الطريقة بالسيارات ومكوك فضاء متكل روبن في الفضاء، سيارات برمائية، وسيارات لشركة تويوتا هايلكس.

وفقا للمطورين، فإن ملامح اللعبات الثلاث غير واضحة إلا أن اللاعبين سيقدمون خريطة للسماح لهم لزيارة دول مثل إنجلترا وفرنسا وإيطاليا خلال الرحلة.

16 % ارتفاعا بعدد الهجمات المالية الخبيثة بالربع الثاني في 2016

بسم الله الرحمن الرحيم




تشهد البرمجيات الخبيثة المستهدفة للمؤسسات المالية تطورًا متزايدًا نتيجة التعاون المتبادل بين صانعي هذه البرمجيات، وفقًا لنتائج تقرير كاسبرسكي لاب حول تطور تهديدات تكنولوجيا المعلومات للربع الثاني. وخلال الأشهر الثلاثة الماضية، تمكنت منتجات كاسبرسكي لاب من منع عدد 1،132،031 من الهجمات المالية الخبيثة على المستخدمين، بزيادة بنسبة 15.6% مقارنة بالربع السابق. 

ويعود السبب في هذا الارتفاع الملحوظ إلى التعاون المتبادل بين مصنعي اثنين من أشهر برمجياتحصان طروادة المصرفية الخبيثة وهما: Gozi Trojan وNymaim Trojan، مما جعلهما على قائمة أكثر 10 هجمات مالية خبيثة انتشارًا. 

لاتزال برمجيات حصان طروادة المصرفية الخبيثة تشكل بعضًا من أخطر التهديدات الإلكترونية الماثلة. وغالبًا ما يتم دس ونشر هذه البرمجيات عن طريق مواقع إلكترونية مخترقة أو احتيالية أو رسائل البريد غير المرغوب فيها. وتقوم هذه الأخيرة، بعد أن تتمكن من إصابة المستخدمين، بمحاكاة صفحات الخدمات المصرفية الرسمية في محاولة للسطو على معلومات المستخدم الشخصية، مثل بيانات الحسابات المصرفية أو كلمات المرور أو بيانات بطاقة الدفع. 

وفقًا لإحصاءات كاسبرسكي لاب خلال هذا الربع السنوي، جاءت تركيا ضمن قائمة الدول الأكثر تعرضًا لهجمات هذا النوع من البرمجية الخبيثة: تعرضت نسبة 3.45% من مستخدمي منتجات كاسبرسكي لاب في الدولة لهذه التهديدات عبر الإنترنت خلال هذا الربع السنوي. 

وجاءت روسيا في المركز الثاني من حيث التعرض للهجمات عبر الإنترنت بنسبة 2.9%، تلتها البرازيل بنسبة 2.6%. ومن المرجح أن تتعرض البرازيل لعدد أكبر من الهجمات نتيجة استضافتها لدورة الألعاب الأوليمبية خلال الربع الثالث لهذه السنة.

تحديث لـ Google Drive ينهي دعم «أندرويد آيس كريم»

بسم الله الرحمن الرحيم


أطلقت شركة جوجل تحديثا جديدا لتطبيق Google Drive للحوسبة السحابية، ومن خلاله أنهت دعم إصدار أندرويد 4.0 أو "آيس كريم ساندوتش"، ليتوقف تحديث التطبيق على هذا الإصدار.

وجلب التحديث الجديد لـ Google Drive مجموعة من التغييرات أخرى، والآن يمكن الوصول إليها بسهولة ومنها ترقية خطة التخزين للتطبيق، إضافة اختصارات الشاشة الرئيسية إلى الملفات المفضلة، وتعليق تلقى الإخطارات. 

وأخيرا، يتضمن التحديث أيضا بعض التحسينات المتعلقة بالأداء وإصلاح الأخطاء العامة.