downloads | documentation | faq | getting help | mailing lists | licenses | wiki | reporting bugs | php.net sites | links | conferences | my php.net

search for in the

sqlite_close> <sqlite_busy_timeout
Last updated: Fri, 13 Nov 2009

view this page in

sqlite_changes

SQLiteDatabase->changes

(PHP 5, PECL sqlite >= 1.0.0)

sqlite_changes -- SQLiteDatabase->changes 直近のSQLステートメントにより変更されたレコード数を返す

説明

int sqlite_changes ( resource $dbhandle )

オブジェクト指向言語型スタイル (メソッド):

SQLiteDatabase
int changes ( void )

データベースハンドル dbhandle に対して実行された 直近のSQLステートメントによって変更されたレコード数を返します。

パラメータ

dbhandle

SQLite データベースリソース。手続きに従って、 sqlite_open() から返されます。 このパラメータは、 オブジェクト指向言語型メソッドを使用する場合は不要です。

返り値

変更された行数を返します。

例1 手続き言語型スタイル

<?php
$dbhandle 
sqlite_open('mysqlitedb');
$query sqlite_query($dbhandle"UPDATE users SET email='jDoe@example.com' WHERE username='jDoe'");
if (!
$query) {
    exit(
'Error in query.');
} else {
    echo 
'Number of rows modified: 'sqlite_changes($dbhandle);
}
?>

例2 オブジェクト指向言語型スタイル

<?php
$dbhandle 
= new SQLiteDatabase('mysqlitedb');
$query $dbhandle->query("UPDATE users SET email='jDoe@example.com' WHERE username='jDoe'");
if (!
$query) {
    exit(
'Error in query.');
} else {
    echo 
'Number of rows modified: '$dbhandle->changes();
}
?>

参考

  • sqlite_open() - SQLiteデータベースをオープンする。データベースが存在しない場合は作 成する



add a note add a note User Contributed Notes
sqlite_changes
bermi ferrer:at-akelos dotCom
28-Sep-2005 01:02
When counting deleted records from the database, I realized that sqlite_changes() will return 0 if you are deleting all the records without including a WHERE clause.

So after "DELETE FROM users" sqlite_open() will print 0 even if rows where deleted, but if you use "DELETE FROM users WHERE 1" you will get the right result.

I had this problem on versions 5.0.4 and 4.4.0 under Windows servers.

sqlite_close> <sqlite_busy_timeout
Last updated: Fri, 13 Nov 2009
 
 
show source | credits | stats | sitemap | contact | advertising | mirror sites