本文整理汇总了C#中sqlite3.xRollbackCallback方法的典型用法代码示例。如果您正苦于以下问题:C# sqlite3.xRollbackCallback方法的具体用法?C# sqlite3.xRollbackCallback怎么用?C# sqlite3.xRollbackCallback使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类sqlite3
的用法示例。
在下文中一共展示了sqlite3.xRollbackCallback方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: sqlite3RollbackAll
/*
** Rollback all database files.
*/
static void sqlite3RollbackAll( sqlite3 db )
{
int i;
int inTrans = 0;
Debug.Assert( sqlite3_mutex_held( db.mutex ) );
sqlite3BeginBenignMalloc();
for ( i = 0; i < db.nDb; i++ )
{
if ( db.aDb[i].pBt != null )
{
if ( sqlite3BtreeIsInTrans( db.aDb[i].pBt ) )
{
inTrans = 1;
}
sqlite3BtreeRollback( db.aDb[i].pBt );
db.aDb[i].inTrans = 0;
}
}
sqlite3VtabRollback( db );
sqlite3EndBenignMalloc();
if ( ( db.flags & SQLITE_InternChanges ) != 0 )
{
sqlite3ExpirePreparedStatements( db );
sqlite3ResetInternalSchema( db, -1 );
}
/* Any deferred constraint violations have now been resolved. */
db.nDeferredCons = 0;
/* If one has been configured, invoke the rollback-hook callback */
if ( db.xRollbackCallback != null && ( inTrans != 0 || 0 == db.autoCommit ) )
{
db.xRollbackCallback( db.pRollbackArg );
}
}