فئة للتواصل مع بنك البيانات Sybase مع PHP المستندة إلى مكتبة sqlanywhere. فئة للاتصال بقاعدة بيانات Sybase مع PHP، تم إنشاؤها لمكتبة PHP SqlAnywhere.
اعتمد التطوير على فئة PDO الأصلية.
المهام:
================
1- قم أولاً بتثبيت وحدة sqlanywhere لـ PHP انقر هنا!.
2- استخدم الملحن لتثبيت هذه الحزمة بإضافة الأسطر أدناه في القسم المطلوب require : // ... "require": { "cagartner/SQLAnywhereClient": "dev-master" }, // ...
فيما يلي بعض الأمثلة حول كيفية استخدام هذه الفئة.
SQLAnywhereClient::__construct : <?php
require ' ../vendor/autoload.php ' ;
use Cagartner SQLAnywhereClient ;
try {
$ dns = " uid={user};pwd={password};ENG={database-name};commlinks=tcpip{host={host};port={port}} " ;
$ con = new SQLAnywhereClient ( $ dns );
} catch ( Exception $ e ) {
echo $ e -> getMessage ();
}
?> يمكنك تحديد is_persistent جنبًا إلى جنب مع الاتصال، وهما تسلسلان: auto_commit وثبات . يمكنك تحديد معلمتي تكوين للأحرف الأولى من خلال الاتصال: auto_commit و is_persistent .
auto_commit تمكين الالتزام التلقائي، الافتراضي هو true ؛is_persistent تحديد الوضع المستمر، الافتراضي هو false ؛ <?php
require ' ../vendor/autoload.php ' ;
use Cagartner SQLAnywhereClient ;
try {
$ dns = " uid={uid};pwd={password};ENG={};commlinks=tcpip{host={host};port={password}} " ;
$ autocommit = false ;
$ persistent = true ;
$ con = new SQLAnywhereClient ( $ dns , $ autocommit , $ persistent );
} catch ( Exception $ e ) {
echo $ e -> getMessage ();
}
?>SQLAnywhereClient::exec() : <?php
$ sql = " SELECT * FROM users " ;
$ result = $ con -> exec ( $ sql );
echo " <pre> " ;
print_r ( $ result -> fetch ());
echo " </pre> " ;
exit ;
?>SQLAnywhereClient::query() :تقوم هذه الطريقة بإرجاع مصفوفة تحتوي على البيانات
<?php
$ sql = " SELECT name, email FROM users " ;
foreach ( $ con -> query ( $ sql ) as $ result ) {
print_r ( $ result );
}
exit ;
?>SQLAnywhereQuery::fetchالعودة الصف الأول
<?php
$ sql = " SELECT name, email FROM users " ;
$ result = $ con -> exec ( $ sql );
$ user = $ result -> fetch ();
print_r ( $ user );
exit ;
?> يمكنك اختيار كيفية استرداد التنسيق الذي يتم من خلاله بياناتك SQLAnywhereClient
<?php
// Retornar em um array com idexação por numero e coluna
SQLAnywhereClient:: FETCH_ARRAY ;
// Retornar em um array com idexação por coluna
SQLAnywhereClient:: FETCH_ASSOC ; // Formato Padrão!
// Retornar em um array com idexação por coluna
SQLAnywhereClient:: FETCH_OBJECT ;
// Retornar em um array com idexação por linha de dados
SQLAnywhereClient:: FETCH_ROW ;
// Retornar em um array com idexação por colunas
SQLAnywhereClient:: FETCH_FIELD ;
?>مثال:
<?php
$ sql = " SELECT name, email FROM users " ;
$ result = $ con -> exec ( $ sql );
$ user = $ result -> fetch ( SQLAnywhereClient:: FETCH_OBJECT );
print_r ( $ user );
exit ;
?>SQLAnywhereQuery::fetchAllإرجاع كافة الصفوف المحددة
<?php
$ sql = " SELECT name, email FROM users " ;
$ result = $ con -> exec ( $ sql );
$ user = $ result -> fetchAll ();
print_r ( $ user );
exit ;
?>في هذه الطريقة يمكنك أيضًا اختيار تنسيق الإرجاع أيضًا:
<?php
$ sql = " SELECT name, email FROM users " ;
$ result = $ con -> exec ( $ sql );
$ user = $ result -> fetchAll ( SQLAnywhereClient:: FETCH_OBJECT );
print_r ( $ user );
exit ;
?>SQLAnywhereQuery::rowCountإرجاع عدد الصفوف
<?php
$ sql = " SELECT name, email FROM users " ;
$ result = $ con -> exec ( $ sql );
echo " We find " . $ result -> rowCount () . " itens. " ;
exit ;
?> أو مع الاسم المستعار count :
<?php
$ sql = " SELECT name, email FROM user " ;
$ result = $ con -> exec ( $ sql );
echo " We find " . $ result -> count () . " itens. " ;
exit ;
?>SQLAnywhereQuery::fieldCountإرجاع إجمالي الحقول
<?php
$ sql = " SELECT name, email FROM user " ;
$ result = $ con -> exec ( $ sql );
echo " We find " . $ result -> fieldCount () . " fields. " ;
exit ;
?>SQLAnywhereClient::lastInsertId()قم بإرجاع آخر معرف تم إدراجه
<?php
$ sql = " INSERT INTO user name, email VALUES ('Carlos', '[email protected]') " ;
if ( $ con -> exec ( $ sql )) {
echo $ con -> lastInsertId ();
}
exit ;
?>SQLAnywhereClient::prepare() : بيان معد مع ? :
<?php
$ sql = " INSERT INTO users name, email VALUES (?, ?) " ;
$ stmnt = $ con -> prepare ( $ sql );
if ( $ stmnt -> execute ( array ( ' Carlos ' , ' [email protected] ' ))) {
echo $ con -> lastInsertId ();
}
exit ;
?>وهذه المعلمات أسماء:
<?php
$ sql = " INSERT INTO users name, email VALUES (:name, :email) " ;
$ stmnt = $ con -> prepare ( $ sql );
if ( $ stmnt -> execute ( array (
' :name ' => ' Carlos ' ,
' :email ' => ' [email protected] '
))) {
echo $ con -> lastInsertId ();
}
exit ;
?>SQLAnywherePrepared::bindParam() : <?php
$ sql = " INSERT INTO users name, email VALUES (:name, :email) " ;
$ stmnt = $ con -> prepare ( $ sql );
$ name = " Carlos A. " ;
$ email = " [email protected] " ;
$ stmnt -> bindParam ( ' :name ' , $ name );
$ stmnt -> bindParam ( ' :email ' , $ email );
if ( $ stmnt -> execute ()) {
echo $ con -> lastInsertId ();
}
exit ;
?>