0
我在设备上有一个带有SQL Server CE 3.5的Windows Mobile 6.0应用程序。该程序从发行商 - SQL Server 2008获取最新数据。复制工作正常,但我想向用户显示上次从服务器复制的时间。从SQL服务器获取上次复制日期/时间CE
有没有人知道我可以从设备上执行SQL以获取SQL Server CE中的这些信息?
所有帮助非常感谢。
迈克
我在设备上有一个带有SQL Server CE 3.5的Windows Mobile 6.0应用程序。该程序从发行商 - SQL Server 2008获取最新数据。复制工作正常,但我想向用户显示上次从服务器复制的时间。从SQL服务器获取上次复制日期/时间CE
有没有人知道我可以从设备上执行SQL以获取SQL Server CE中的这些信息?
所有帮助非常感谢。
迈克
/// <summary>
/// Get the local Datetime for last succesful synchronization
/// If no Synchronization has happened, will return DateTime.MinValue
/// </summary>
/// <param name="connection">An open connection to the local database</param>
/// <returns>The date and time for the last succesful sync</returns>
public DateTime GetLastSuccessfulSyncTime(SqlCeConnection connection)
{
if (!System.IO.File.Exists(connection.Database))
return DateTime.MinValue;
if (connection.State != System.Data.ConnectionState.Open)
{
connection.Open();
}
var props = GetPropertiesFromSettings();
using (SqlCeCommand cmd = connection.CreateCommand())
{
cmd.Connection = connection;
cmd.CommandText = "SELECT table_name FROM information_schema.tables WHERE TABLE_NAME = @table";
cmd.Parameters.Add("@table", SqlDbType.NVarChar, 4000);
cmd.Parameters["@table"].Value = "__sysMergeSubscriptions";
object obj = cmd.ExecuteScalar();
if (obj == null)
return DateTime.MinValue;
cmd.Parameters.Clear();
cmd.CommandText = "SELECT LastSuccessfulSync FROM __sysMergeSubscriptions " +
"WHERE [email protected] AND [email protected] AND [email protected]";
cmd.Parameters.Add("@publisher", SqlDbType.NVarChar, 4000);
cmd.Parameters["@publisher"].Value = props.Publisher;
cmd.Parameters.Add("@database", SqlDbType.NVarChar, 4000);
cmd.Parameters["@database"].Value = props.PublisherDatabase;
cmd.Parameters.Add("@publication", SqlDbType.NVarChar, 4000);
cmd.Parameters["@publication"].Value = props.Publication;
obj = cmd.ExecuteScalar();
if (obj == null)
return DateTime.MinValue;
else
return ((DateTime)obj);
}
}
完美!感谢您的帮助。 – hydev 2012-03-30 14:23:38