ObjectDataSource.CacheDuration Свойство
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Возвращает или задает длину промежутка времени (в секундах), в течение которого элемент управления источником данных кэширует данные, полученные с помощью свойства SelectMethod.
public:
virtual property int CacheDuration { int get(); void set(int value); };
[System.ComponentModel.TypeConverter(typeof(System.Web.UI.DataSourceCacheDurationConverter))]
public virtual int CacheDuration { get; set; }
[<System.ComponentModel.TypeConverter(typeof(System.Web.UI.DataSourceCacheDurationConverter))>]
member this.CacheDuration : int with get, set
Public Overridable Property CacheDuration As Integer
Значение свойства
Количество секунд, на протяжении которых объект ObjectDataSource кэширует результаты вызова свойства SelectMethod. Значение по умолчанию — 0. Значение не может быть отрицательным.
- Атрибуты
Примеры
Этот раздел содержит два примера кода. В первом примере кода показано, как ObjectDataSource объект поддерживает кэширование. Во втором примере кода показано, как реализовать метод-оболочку, который возвращает DataSet объект для включения кэширования с помощью ObjectDataSource объекта .
В следующем примере кода показано, как ObjectDataSource элемент управления поддерживает кэширование. Чтобы включить кэширование, необходимо реализовать метод , который извлекает данные, которые идентифицируются свойством SelectMethod , для возврата данных в DataSet виде объекта . В этом примере свойству EnableCaching присваивается значение true
, а CacheDuration также свойства и CacheExpirationPolicy . Кэширует ObjectDataSource данные, возвращаемые свойством, в SelectMethod течение 30 секунд.
<%@ Register TagPrefix="aspSample" Namespace="Samples.AspNet.CS" Assembly="Samples.AspNet.CS" %>
<%@ Page language="c#" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
<title>ObjectDataSource - C# Example</title>
</head>
<body>
<form id="Form1" method="post" runat="server">
<asp:gridview
id="GridView1"
runat="server"
datasourceid="ObjectDataSource1" />
<asp:objectdatasource
id="ObjectDataSource1"
runat="server"
typename="Samples.AspNet.CS.EmployeeLogic"
selectmethod="GetAllEmployeesAsDataSet"
enablecaching="True"
cacheduration="30"
cacheexpirationpolicy="Absolute" />
</form>
</body>
</html>
<%@ Register TagPrefix="aspSample" Namespace="Samples.AspNet.VB" Assembly="Samples.AspNet.VB" %>
<%@ Page language="vb" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
<title>ObjectDataSource - VB Example</title>
</head>
<body>
<form id="Form1" method="post" runat="server">
<asp:gridview
id="GridView1"
runat="server"
datasourceid="ObjectDataSource1" />
<asp:objectdatasource
id="ObjectDataSource1"
runat="server"
typename="Samples.AspNet.VB.EmployeeLogic"
selectmethod="GetAllEmployeesAsDataSet"
enablecaching="True"
cacheduration="30"
cacheexpirationpolicy="Absolute" />
</form>
</body>
</html>
В следующем примере кода показано, как реализовать метод-оболочку, который возвращает DataSet объект для включения кэширования с помощью ObjectDataSource элемента управления . В базовой EmployeeLogic
реализации класса GetAllEmployees
метод возвращает ArrayList объект . Вместо полного рефакторинга объекта для работы с ObjectDataSource на странице Веб-форм добавляется метод-оболочка с именем GetAllEmployeesAsDataSet
, который возвращает набор данных в NorthwindEmployee
виде DataSet.
Этот пример входит в состав более крупного примера использования класса ObjectDataSource.
//
// To support basic filtering, the employees cannot
// be returned as an array of objects, rather as a
// DataSet of the raw data values.
public static DataSet GetAllEmployeesAsDataSet () {
ICollection employees = GetAllEmployees();
DataSet ds = new DataSet("Table");
// Create the schema of the DataTable.
DataTable dt = new DataTable();
DataColumn dc;
dc = new DataColumn("FirstName", typeof(string)); dt.Columns.Add(dc);
dc = new DataColumn("LastName", typeof(string)); dt.Columns.Add(dc);
dc = new DataColumn("Title", typeof(string)); dt.Columns.Add(dc);
dc = new DataColumn("Courtesy", typeof(string)); dt.Columns.Add(dc);
dc = new DataColumn("Supervisor",typeof(Int32)); dt.Columns.Add(dc);
// Add rows to the DataTable.
IEnumerator emplEnum = employees.GetEnumerator();
DataRow row;
NorthwindEmployee ne;
while (emplEnum.MoveNext()) {
ne = emplEnum.Current as NorthwindEmployee;
row = dt.NewRow();
row["FirstName"] = ne.FirstName;
row["LastName"] = ne.LastName;
row["Title"] = ne.Title;
row["Courtesy"] = ne.Courtesy;
row["Supervisor"] = ne.Supervisor;
dt.Rows.Add(row);
}
// Add the complete DataTable to the DataSet.
ds.Tables.Add(dt);
return ds;
}
' To support basic filtering, the employees cannot
' be returned as an array of objects, rather as a
' DataSet of the raw data values.
Public Shared Function GetAllEmployeesAsDataSet() As DataSet
Dim employees As ICollection = GetAllEmployees()
Dim ds As New DataSet("Table")
' Create the schema of the DataTable.
Dim dt As New DataTable()
Dim dc As DataColumn
dc = New DataColumn("FirstName", GetType(String))
dt.Columns.Add(dc)
dc = New DataColumn("LastName", GetType(String))
dt.Columns.Add(dc)
dc = New DataColumn("Title", GetType(String))
dt.Columns.Add(dc)
dc = New DataColumn("Courtesy", GetType(String))
dt.Columns.Add(dc)
dc = New DataColumn("Supervisor", GetType(Int32))
dt.Columns.Add(dc)
' Add rows to the DataTable.
Dim emplEnum As IEnumerator = employees.GetEnumerator()
Dim row As DataRow
Dim ne As NorthwindEmployee
While emplEnum.MoveNext()
ne = CType(emplEnum.Current, NorthwindEmployee)
row = dt.NewRow()
row("FirstName") = ne.FirstName
row("LastName") = ne.LastName
row("Title") = ne.Title
row("Courtesy") = ne.Courtesy
row("Supervisor") = ne.Supervisor
dt.Rows.Add(row)
End While
' Add the complete DataTable to the DataSet.
ds.Tables.Add(dt)
Return ds
End Function 'GetAllEmployeesAsDataSet
Комментарии
Элемент ObjectDataSource управления поддерживает кэширование данных. Пока данные кэшируются, вызовы Select метода извлекают данные из кэша, а не из бизнес-объекта, с которым ObjectDataSource работает . По истечении срока действия кэша Select метод извлекает данные из бизнес-объекта, а затем снова кэширует данные.
Элемент ObjectDataSource управления автоматически кэширует данные, если свойству EnableCaching присвоено значение true
, а CacheDuration свойству присваивается значение больше 0, указывающее время в секундах, в течение которого кэш хранит данные до удаления записи кэша. Значение 0 указывает на бесконечно длинный кэш.
Кэш регулируется сочетанием длительности и CacheExpirationPolicy параметра. Если свойству присвоено Absolute значение , ObjectDataSource данные при первом вызове метода кэшируются Select и хранятся в памяти в течение не более времени, указанного свойством CacheDuration .CacheExpirationPolicy Данные могут быть освобождены до истечения длительности, если требуется память. Затем кэш обновляется во время следующего вызова Select метода . Если свойству CacheExpirationPolicy присвоено Sliding значение , элемент управления источником данных кэширует данные при первом вызове Select метода, но сбрасывает временное окно, в течение которого он хранит кэш при каждом последующем вызове Select метода. Срок действия кэша истекает, если не было действий в течение времени, равного свойству CacheDuration с момента последнего вызова Select метода.