f3e3aab35a
Former-commit-id: 9c2cb47f45fa221e661ab616387c9cda183f283d
917 lines
30 KiB
C#
917 lines
30 KiB
C#
//
|
|
// System.Web.UI.WebControls.SqlDataSourceView
|
|
//
|
|
// Authors:
|
|
// Ben Maurer (bmaurer@users.sourceforge.net)
|
|
// Sanjay Gupta (gsanjay@novell.com)
|
|
//
|
|
// (C) 2003 Ben Maurer
|
|
// (C) Novell, Inc. (http://www.novell.com)
|
|
//
|
|
|
|
//
|
|
// Permission is hereby granted, free of charge, to any person obtaining
|
|
// a copy of this software and associated documentation files (the
|
|
// "Software"), to deal in the Software without restriction, including
|
|
// without limitation the rights to use, copy, modify, merge, publish,
|
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
|
// permit persons to whom the Software is furnished to do so, subject to
|
|
// the following conditions:
|
|
//
|
|
// The above copyright notice and this permission notice shall be
|
|
// included in all copies or substantial portions of the Software.
|
|
//
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
//
|
|
|
|
using System.Collections;
|
|
using System.Collections.Specialized;
|
|
using System.Text;
|
|
using System.Data;
|
|
using System.ComponentModel;
|
|
using System.Data.Common;
|
|
|
|
namespace System.Web.UI.WebControls {
|
|
public class SqlDataSourceView : DataSourceView, IStateManager {
|
|
|
|
HttpContext context;
|
|
DbProviderFactory factory;
|
|
DbConnection connection;
|
|
|
|
public SqlDataSourceView (SqlDataSource owner, string name, HttpContext context)
|
|
: base (owner, name)
|
|
{
|
|
this.owner = owner;
|
|
this.name = name;
|
|
this.context = context;
|
|
}
|
|
|
|
void InitConnection ()
|
|
{
|
|
if (factory == null) factory = owner.GetDbProviderFactoryInternal ();
|
|
if (connection == null) {
|
|
connection = factory.CreateConnection ();
|
|
connection.ConnectionString = owner.ConnectionString;
|
|
}
|
|
}
|
|
|
|
public int Delete (IDictionary keys, IDictionary oldValues)
|
|
{
|
|
return ExecuteDelete (keys, oldValues);
|
|
}
|
|
|
|
protected override int ExecuteDelete (IDictionary keys, IDictionary oldValues)
|
|
{
|
|
if (!CanDelete)
|
|
throw new NotSupportedException("Delete operation is not supported");
|
|
if (oldValues == null && ConflictDetection == ConflictOptions.CompareAllValues)
|
|
throw new InvalidOperationException ("oldValues parameters should be specified when ConflictOptions is set to CompareAllValues");
|
|
|
|
InitConnection ();
|
|
|
|
DbCommand command = factory.CreateCommand ();
|
|
command.CommandText = DeleteCommand;
|
|
command.Connection = connection;
|
|
if (DeleteCommandType == SqlDataSourceCommandType.Text)
|
|
command.CommandType = CommandType.Text;
|
|
else
|
|
command.CommandType = CommandType.StoredProcedure;
|
|
|
|
IDictionary oldDataValues;
|
|
if (ConflictDetection == ConflictOptions.CompareAllValues) {
|
|
oldDataValues = new Hashtable ();
|
|
if (keys != null) {
|
|
foreach (DictionaryEntry de in keys)
|
|
oldDataValues [de.Key] = de.Value;
|
|
}
|
|
if (oldValues != null) {
|
|
foreach (DictionaryEntry de in oldValues)
|
|
oldDataValues [de.Key] = de.Value;
|
|
}
|
|
}
|
|
else
|
|
oldDataValues = keys;
|
|
|
|
InitializeParameters (command, DeleteParameters, null, oldDataValues, true);
|
|
|
|
SqlDataSourceCommandEventArgs args = new SqlDataSourceCommandEventArgs (command);
|
|
OnDeleting (args);
|
|
if (args.Cancel)
|
|
return -1;
|
|
|
|
bool closed = connection.State == ConnectionState.Closed;
|
|
|
|
if (closed)
|
|
connection.Open();
|
|
Exception exception = null;
|
|
int result = -1;;
|
|
try {
|
|
result = command.ExecuteNonQuery();
|
|
} catch (Exception e) {
|
|
exception = e;
|
|
}
|
|
|
|
if (closed)
|
|
connection.Close ();
|
|
|
|
OnDataSourceViewChanged (EventArgs.Empty);
|
|
|
|
SqlDataSourceStatusEventArgs deletedArgs =
|
|
new SqlDataSourceStatusEventArgs (command, result, exception);
|
|
OnDeleted (deletedArgs);
|
|
|
|
if (exception != null && !deletedArgs.ExceptionHandled)
|
|
throw exception;
|
|
|
|
return result;
|
|
}
|
|
|
|
public int Insert (IDictionary values)
|
|
{
|
|
return ExecuteInsert (values);
|
|
}
|
|
|
|
protected override int ExecuteInsert (IDictionary values)
|
|
{
|
|
if (!CanInsert)
|
|
throw new NotSupportedException ("Insert operation is not supported");
|
|
|
|
InitConnection ();
|
|
|
|
DbCommand command = factory.CreateCommand ();
|
|
command.CommandText = InsertCommand;
|
|
command.Connection = connection;
|
|
if (InsertCommandType == SqlDataSourceCommandType.Text)
|
|
command.CommandType = CommandType.Text;
|
|
else
|
|
command.CommandType = CommandType.StoredProcedure;
|
|
|
|
InitializeParameters (command, InsertParameters, values, null, false);
|
|
|
|
SqlDataSourceCommandEventArgs args = new SqlDataSourceCommandEventArgs (command);
|
|
OnInserting (args);
|
|
if (args.Cancel)
|
|
return -1;
|
|
|
|
bool closed = connection.State == ConnectionState.Closed;
|
|
if (closed)
|
|
connection.Open ();
|
|
Exception exception = null;
|
|
int result = -1;
|
|
try {
|
|
result = command.ExecuteNonQuery ();
|
|
}
|
|
catch (Exception e) {
|
|
exception = e;
|
|
}
|
|
|
|
if (closed)
|
|
connection.Close ();
|
|
|
|
OnDataSourceViewChanged (EventArgs.Empty);
|
|
|
|
OnInserted (new SqlDataSourceStatusEventArgs (command, result, exception));
|
|
|
|
if (exception != null)
|
|
throw exception;
|
|
return result;
|
|
}
|
|
|
|
public IEnumerable Select (DataSourceSelectArguments arguments)
|
|
{
|
|
return ExecuteSelect (arguments);
|
|
}
|
|
|
|
protected internal override IEnumerable ExecuteSelect (DataSourceSelectArguments arguments)
|
|
{
|
|
if (SortParameterName.Length > 0 && SelectCommandType == SqlDataSourceCommandType.Text)
|
|
throw new NotSupportedException ("The SortParameterName property is only supported with stored procedure commands in SqlDataSource");
|
|
|
|
if (arguments.SortExpression.Length > 0 && owner.DataSourceMode == SqlDataSourceMode.DataReader)
|
|
throw new NotSupportedException ("SqlDataSource cannot sort. Set DataSourceMode to DataSet to enable sorting.");
|
|
|
|
if (arguments.StartRowIndex > 0 || arguments.MaximumRows > 0)
|
|
throw new NotSupportedException ("SqlDataSource does not have paging enabled. Set the DataSourceMode to DataSet to enable paging.");
|
|
|
|
if (FilterExpression.Length > 0 && owner.DataSourceMode == SqlDataSourceMode.DataReader)
|
|
throw new NotSupportedException ("SqlDataSource only supports filtering when the data source's DataSourceMode is set to DataSet.");
|
|
|
|
InitConnection ();
|
|
|
|
DbCommand command = factory.CreateCommand ();
|
|
command.CommandText = SelectCommand;
|
|
command.Connection = connection;
|
|
if (SelectCommandType == SqlDataSourceCommandType.Text)
|
|
command.CommandType = CommandType.Text;
|
|
else {
|
|
command.CommandType = CommandType.StoredProcedure;
|
|
if (SortParameterName.Length > 0 && arguments.SortExpression.Length > 0)
|
|
command.Parameters.Add (CreateDbParameter (SortParameterName, arguments.SortExpression));
|
|
}
|
|
|
|
if (SelectParameters.Count > 0)
|
|
InitializeParameters (command, SelectParameters, null, null, false);
|
|
|
|
Exception exception = null;
|
|
if (owner.DataSourceMode == SqlDataSourceMode.DataSet) {
|
|
DataView dataView = null;
|
|
|
|
if (owner.EnableCaching)
|
|
dataView = (DataView) owner.Cache.GetCachedObject (SelectCommand, SelectParameters);
|
|
|
|
if (dataView == null) {
|
|
SqlDataSourceSelectingEventArgs selectingArgs = new SqlDataSourceSelectingEventArgs (command, arguments);
|
|
OnSelecting (selectingArgs);
|
|
if (selectingArgs.Cancel || !PrepareNullParameters (command, CancelSelectOnNullParameter)) {
|
|
return null;
|
|
}
|
|
try {
|
|
DbDataAdapter adapter = factory.CreateDataAdapter ();
|
|
DataSet dataset = new DataSet ();
|
|
|
|
adapter.SelectCommand = command;
|
|
adapter.Fill (dataset, name);
|
|
|
|
dataView = dataset.Tables [0].DefaultView;
|
|
if (dataView == null)
|
|
throw new InvalidOperationException ();
|
|
}
|
|
catch (Exception e) {
|
|
exception = e;
|
|
}
|
|
int rowsAffected = (dataView == null) ? 0 : dataView.Count;
|
|
SqlDataSourceStatusEventArgs selectedArgs = new SqlDataSourceStatusEventArgs (command, rowsAffected, exception);
|
|
OnSelected (selectedArgs);
|
|
|
|
if (exception != null && !selectedArgs.ExceptionHandled)
|
|
throw exception;
|
|
|
|
if (owner.EnableCaching)
|
|
owner.Cache.SetCachedObject (SelectCommand, selectParameters, dataView);
|
|
}
|
|
|
|
if (SortParameterName.Length == 0 || SelectCommandType == SqlDataSourceCommandType.Text)
|
|
dataView.Sort = arguments.SortExpression;
|
|
|
|
if (FilterExpression.Length > 0) {
|
|
IOrderedDictionary fparams = FilterParameters.GetValues (context, owner);
|
|
SqlDataSourceFilteringEventArgs fargs = new SqlDataSourceFilteringEventArgs (fparams);
|
|
OnFiltering (fargs);
|
|
if (!fargs.Cancel) {
|
|
object [] formatValues = new object [fparams.Count];
|
|
for (int n = 0; n < formatValues.Length; n++) {
|
|
formatValues [n] = fparams [n];
|
|
if (formatValues [n] == null) return dataView;
|
|
}
|
|
dataView.RowFilter = string.Format (FilterExpression, formatValues);
|
|
}
|
|
}
|
|
|
|
return dataView;
|
|
}
|
|
else {
|
|
SqlDataSourceSelectingEventArgs selectingArgs = new SqlDataSourceSelectingEventArgs (command, arguments);
|
|
OnSelecting (selectingArgs);
|
|
if (selectingArgs.Cancel || !PrepareNullParameters (command, CancelSelectOnNullParameter)) {
|
|
return null;
|
|
}
|
|
|
|
DbDataReader reader = null;
|
|
bool closed = connection.State == ConnectionState.Closed;
|
|
|
|
if (closed)
|
|
connection.Open ();
|
|
try {
|
|
reader = command.ExecuteReader (closed ? CommandBehavior.CloseConnection : CommandBehavior.Default);
|
|
}
|
|
catch (Exception e) {
|
|
exception = e;
|
|
}
|
|
int rows = reader == null ? 0 : reader.RecordsAffected;
|
|
SqlDataSourceStatusEventArgs selectedArgs = new SqlDataSourceStatusEventArgs (command, rows, exception);
|
|
OnSelected (selectedArgs);
|
|
if (exception != null && !selectedArgs.ExceptionHandled)
|
|
throw exception;
|
|
|
|
return reader;
|
|
}
|
|
}
|
|
|
|
static bool PrepareNullParameters (DbCommand command, bool cancelIfHas)
|
|
{
|
|
for (int i = 0; i < command.Parameters.Count; i++) {
|
|
DbParameter param = command.Parameters [i];
|
|
if (param.Value == null && ((param.Direction & ParameterDirection.Input) != 0)) {
|
|
if (cancelIfHas)
|
|
return false;
|
|
else
|
|
param.Value = DBNull.Value;
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
public int Update (IDictionary keys, IDictionary values, IDictionary oldValues)
|
|
{
|
|
return ExecuteUpdate (keys, values, oldValues);
|
|
}
|
|
|
|
protected override int ExecuteUpdate (IDictionary keys, IDictionary values, IDictionary oldValues)
|
|
{
|
|
if (!CanUpdate)
|
|
throw new NotSupportedException ("Update operation is not supported");
|
|
if (oldValues == null && ConflictDetection == ConflictOptions.CompareAllValues)
|
|
throw new InvalidOperationException ("oldValues parameters should be specified when ConflictOptions is set to CompareAllValues");
|
|
|
|
InitConnection ();
|
|
|
|
DbCommand command = factory.CreateCommand ();
|
|
command.CommandText = UpdateCommand;
|
|
command.Connection = connection;
|
|
if (UpdateCommandType == SqlDataSourceCommandType.Text)
|
|
command.CommandType = CommandType.Text;
|
|
else
|
|
command.CommandType = CommandType.StoredProcedure;
|
|
|
|
IDictionary oldDataValues;
|
|
if (ConflictDetection == ConflictOptions.CompareAllValues) {
|
|
oldDataValues = new OrderedDictionary ();
|
|
if (keys != null) {
|
|
foreach (DictionaryEntry de in keys)
|
|
oldDataValues [de.Key] = de.Value;
|
|
}
|
|
if (oldValues != null) {
|
|
foreach (DictionaryEntry de in oldValues)
|
|
oldDataValues [de.Key] = de.Value;
|
|
}
|
|
}
|
|
else {
|
|
oldDataValues = keys;
|
|
}
|
|
|
|
IDictionary dataValues = values;
|
|
|
|
InitializeParameters (command, UpdateParameters, dataValues, oldDataValues, ConflictDetection == ConflictOptions.OverwriteChanges);
|
|
|
|
SqlDataSourceCommandEventArgs args = new SqlDataSourceCommandEventArgs (command);
|
|
OnUpdating (args);
|
|
if (args.Cancel)
|
|
return -1;
|
|
|
|
bool closed = connection.State == ConnectionState.Closed;
|
|
if (closed)
|
|
connection.Open ();
|
|
Exception exception = null;
|
|
int result = -1;
|
|
try {
|
|
result = command.ExecuteNonQuery ();
|
|
}
|
|
catch (Exception e) {
|
|
exception = e;
|
|
}
|
|
|
|
if (closed)
|
|
connection.Close ();
|
|
|
|
OnDataSourceViewChanged (EventArgs.Empty);
|
|
|
|
SqlDataSourceStatusEventArgs updatedArgs =
|
|
new SqlDataSourceStatusEventArgs (command, result, exception);
|
|
OnUpdated (updatedArgs);
|
|
|
|
if (exception != null && !updatedArgs.ExceptionHandled)
|
|
throw exception;
|
|
|
|
return result;
|
|
}
|
|
|
|
string FormatOldParameter (string name)
|
|
{
|
|
string f = OldValuesParameterFormatString;
|
|
if (f.Length > 0)
|
|
return String.Format (f, name);
|
|
else
|
|
return name;
|
|
}
|
|
|
|
object FindValueByName (string parameterName, IDictionary values, bool format)
|
|
{
|
|
if (values == null)
|
|
return null;
|
|
|
|
foreach (DictionaryEntry de in values) {
|
|
string valueName = format == true ? FormatOldParameter (de.Key.ToString ()) : de.Key.ToString ();
|
|
if (String.Compare(parameterName, valueName, StringComparison.InvariantCultureIgnoreCase) == 0)
|
|
return values [de.Key];
|
|
}
|
|
return null;
|
|
}
|
|
|
|
void InitializeParameters (DbCommand command, ParameterCollection parameters, IDictionary values, IDictionary oldValues, bool parametersMayMatchOldValues)
|
|
{
|
|
IOrderedDictionary parameterValues = parameters.GetValues (context, owner);
|
|
|
|
foreach (string parameterName in parameterValues.Keys) {
|
|
Parameter p = parameters [parameterName];
|
|
object value = FindValueByName (parameterName, values, false);
|
|
string valueName = parameterName;
|
|
if (value == null)
|
|
value = FindValueByName (parameterName, oldValues, true);
|
|
|
|
if (value == null && parametersMayMatchOldValues) {
|
|
value = FindValueByName (parameterName, oldValues, false);
|
|
valueName = FormatOldParameter (parameterName);
|
|
}
|
|
|
|
if (value != null) {
|
|
object dbValue = p.ConvertValue (value);
|
|
DbParameter newParameter = CreateDbParameter (valueName, dbValue, p.Direction, p.Size);
|
|
if (!command.Parameters.Contains (newParameter.ParameterName)) {
|
|
command.Parameters.Add (newParameter);
|
|
}
|
|
}
|
|
else {
|
|
command.Parameters.Add (CreateDbParameter (p.Name, parameterValues [parameterName], p.Direction, p.Size));
|
|
}
|
|
}
|
|
|
|
if (values != null) {
|
|
foreach (DictionaryEntry de in values)
|
|
if (!command.Parameters.Contains (ParameterPrefix + (string) de.Key))
|
|
command.Parameters.Add (CreateDbParameter ((string) de.Key, de.Value));
|
|
}
|
|
|
|
if (oldValues != null) {
|
|
foreach (DictionaryEntry de in oldValues)
|
|
if (!command.Parameters.Contains (ParameterPrefix + FormatOldParameter ((string) de.Key)))
|
|
command.Parameters.Add (CreateDbParameter (FormatOldParameter ((string) de.Key), de.Value));
|
|
}
|
|
}
|
|
|
|
DbParameter CreateDbParameter (string name, object value)
|
|
{
|
|
return CreateDbParameter (name, value, ParameterDirection.Input, -1);
|
|
}
|
|
|
|
DbParameter CreateDbParameter (string name, object value, ParameterDirection dir, int size)
|
|
{
|
|
DbParameter dbp = factory.CreateParameter ();
|
|
dbp.ParameterName = ParameterPrefix + name;
|
|
dbp.Value = value;
|
|
dbp.Direction = dir;
|
|
if (size != -1)
|
|
dbp.Size = size;
|
|
|
|
return dbp;
|
|
}
|
|
|
|
void IStateManager.LoadViewState (object savedState)
|
|
{
|
|
LoadViewState (savedState);
|
|
}
|
|
|
|
object IStateManager.SaveViewState ()
|
|
{
|
|
return SaveViewState ();
|
|
}
|
|
|
|
void IStateManager.TrackViewState ()
|
|
{
|
|
TrackViewState ();
|
|
}
|
|
|
|
NotSupportedException CreateNotSupportedException (string capabilityName)
|
|
{
|
|
return new NotSupportedException ("Data source does not have the '" + capabilityName + "' capability enabled.");
|
|
}
|
|
|
|
protected internal override void RaiseUnsupportedCapabilityError (DataSourceCapabilities capability)
|
|
{
|
|
if ((capability & DataSourceCapabilities.Sort) != 0 && !CanSort)
|
|
throw CreateNotSupportedException ("Sort");
|
|
|
|
if ((capability & DataSourceCapabilities.Page) != 0 && !CanPage)
|
|
throw CreateNotSupportedException ("Page");
|
|
|
|
if ((capability & DataSourceCapabilities.RetrieveTotalRowCount) != 0 && !CanRetrieveTotalRowCount)
|
|
throw CreateNotSupportedException ("RetrieveTotalRowCount");
|
|
}
|
|
|
|
protected virtual void LoadViewState (object savedState)
|
|
{
|
|
object [] vs = savedState as object [];
|
|
if (vs == null)
|
|
return;
|
|
|
|
if (vs [0] != null) ((IStateManager) deleteParameters).LoadViewState (vs [0]);
|
|
if (vs [1] != null) ((IStateManager) filterParameters).LoadViewState (vs [1]);
|
|
if (vs [2] != null) ((IStateManager) insertParameters).LoadViewState (vs [2]);
|
|
if (vs [3] != null) ((IStateManager) selectParameters).LoadViewState (vs [3]);
|
|
if (vs [4] != null) ((IStateManager) updateParameters).LoadViewState (vs [4]);
|
|
}
|
|
|
|
protected virtual object SaveViewState ()
|
|
{
|
|
object [] vs = new object [5];
|
|
|
|
if (deleteParameters != null) vs [0] = ((IStateManager) deleteParameters).SaveViewState ();
|
|
if (filterParameters != null) vs [1] = ((IStateManager) filterParameters).SaveViewState ();
|
|
if (insertParameters != null) vs [2] = ((IStateManager) insertParameters).SaveViewState ();
|
|
if (selectParameters != null) vs [3] = ((IStateManager) selectParameters).SaveViewState ();
|
|
if (updateParameters != null) vs [4] = ((IStateManager) updateParameters).SaveViewState ();
|
|
|
|
foreach (object o in vs)
|
|
if (o != null) return vs;
|
|
return null;
|
|
}
|
|
|
|
protected virtual void TrackViewState ()
|
|
{
|
|
tracking = true;
|
|
|
|
if (filterParameters != null) ((IStateManager) filterParameters).TrackViewState ();
|
|
if (selectParameters != null) ((IStateManager) selectParameters).TrackViewState ();
|
|
}
|
|
|
|
bool IStateManager.IsTrackingViewState {
|
|
get { return IsTrackingViewState; }
|
|
}
|
|
|
|
// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
|
|
bool cancelSelectOnNullParameter = true;
|
|
public bool CancelSelectOnNullParameter {
|
|
get { return cancelSelectOnNullParameter; }
|
|
set {
|
|
if (CancelSelectOnNullParameter == value)
|
|
return;
|
|
cancelSelectOnNullParameter = value;
|
|
OnDataSourceViewChanged (EventArgs.Empty);
|
|
}
|
|
}
|
|
|
|
public override bool CanDelete {
|
|
get { return DeleteCommand != null && DeleteCommand != ""; }
|
|
}
|
|
|
|
public override bool CanInsert {
|
|
get { return InsertCommand != null && InsertCommand != ""; }
|
|
}
|
|
|
|
public override bool CanPage {
|
|
/* according to MS, this is false in all cases */
|
|
get { return false; }
|
|
}
|
|
|
|
public override bool CanRetrieveTotalRowCount {
|
|
/* according to MS, this is false in all cases */
|
|
get { return false; }
|
|
}
|
|
|
|
public override bool CanSort {
|
|
get {
|
|
/* we can sort if we're a DataSet, regardless of sort parameter name.
|
|
we can sort if we're a DataReader, if the sort parameter name is not null/"".
|
|
*/
|
|
return (owner.DataSourceMode == SqlDataSourceMode.DataSet
|
|
|| (SortParameterName != null && SortParameterName != ""));
|
|
}
|
|
}
|
|
|
|
public override bool CanUpdate {
|
|
get { return UpdateCommand != null && UpdateCommand != ""; }
|
|
}
|
|
|
|
// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
|
|
ConflictOptions conflictDetection = ConflictOptions.OverwriteChanges;
|
|
public ConflictOptions ConflictDetection {
|
|
get { return conflictDetection; }
|
|
set {
|
|
if (ConflictDetection == value)
|
|
return;
|
|
conflictDetection = value;
|
|
OnDataSourceViewChanged (EventArgs.Empty);
|
|
}
|
|
}
|
|
|
|
// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
|
|
string deleteCommand = String.Empty;
|
|
public string DeleteCommand {
|
|
get { return deleteCommand; }
|
|
set { deleteCommand = value; }
|
|
}
|
|
|
|
// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
|
|
SqlDataSourceCommandType deleteCommandType = SqlDataSourceCommandType.Text;
|
|
public SqlDataSourceCommandType DeleteCommandType {
|
|
get { return deleteCommandType; }
|
|
set { deleteCommandType = value; }
|
|
}
|
|
|
|
[DefaultValueAttribute (null)]
|
|
[PersistenceModeAttribute (PersistenceMode.InnerProperty)]
|
|
[EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
|
|
public ParameterCollection DeleteParameters {
|
|
get { return GetParameterCollection (ref deleteParameters, false, false); }
|
|
}
|
|
|
|
// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
|
|
string filterExpression;
|
|
public string FilterExpression {
|
|
get { return filterExpression ?? string.Empty; }
|
|
set {
|
|
if (FilterExpression == value)
|
|
return;
|
|
filterExpression = value;
|
|
OnDataSourceViewChanged (EventArgs.Empty);
|
|
}
|
|
}
|
|
|
|
[EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
|
|
[PersistenceModeAttribute (PersistenceMode.InnerProperty)]
|
|
[DefaultValueAttribute (null)]
|
|
public ParameterCollection FilterParameters {
|
|
get { return GetParameterCollection (ref filterParameters, true, true); }
|
|
}
|
|
|
|
// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
|
|
string insertCommand = String.Empty;
|
|
public string InsertCommand {
|
|
get { return insertCommand; }
|
|
set { insertCommand = value; }
|
|
}
|
|
|
|
// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
|
|
SqlDataSourceCommandType insertCommandType = SqlDataSourceCommandType.Text;
|
|
public SqlDataSourceCommandType InsertCommandType {
|
|
get { return insertCommandType; }
|
|
set { insertCommandType = value; }
|
|
}
|
|
|
|
[EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
|
|
[PersistenceModeAttribute (PersistenceMode.InnerProperty)]
|
|
[DefaultValueAttribute (null)]
|
|
public ParameterCollection InsertParameters {
|
|
get { return GetParameterCollection (ref insertParameters, false, false); }
|
|
}
|
|
|
|
protected bool IsTrackingViewState {
|
|
get { return tracking; }
|
|
}
|
|
|
|
// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
|
|
string oldValuesParameterFormatString = "{0}";
|
|
[DefaultValue ("{0}")]
|
|
public string OldValuesParameterFormatString {
|
|
get { return oldValuesParameterFormatString; }
|
|
set {
|
|
if (OldValuesParameterFormatString == value)
|
|
return;
|
|
oldValuesParameterFormatString = value;
|
|
OnDataSourceViewChanged (EventArgs.Empty);
|
|
}
|
|
}
|
|
|
|
// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
|
|
string selectCommand;
|
|
public string SelectCommand {
|
|
get { return selectCommand != null ? selectCommand : string.Empty; }
|
|
set {
|
|
if (SelectCommand == value)
|
|
return;
|
|
selectCommand = value;
|
|
OnDataSourceViewChanged (EventArgs.Empty);
|
|
}
|
|
}
|
|
|
|
// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
|
|
SqlDataSourceCommandType selectCommandType = SqlDataSourceCommandType.Text;
|
|
public SqlDataSourceCommandType SelectCommandType {
|
|
get { return selectCommandType; }
|
|
set { selectCommandType = value; }
|
|
}
|
|
|
|
public ParameterCollection SelectParameters {
|
|
get { return GetParameterCollection (ref selectParameters, true, true); }
|
|
}
|
|
|
|
// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
|
|
string sortParameterName = String.Empty;
|
|
public string SortParameterName {
|
|
get { return sortParameterName; }
|
|
set {
|
|
if (SortParameterName == value)
|
|
return;
|
|
sortParameterName = value;
|
|
OnDataSourceViewChanged (EventArgs.Empty);
|
|
}
|
|
}
|
|
|
|
// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
|
|
string updateCommand = String.Empty;
|
|
public string UpdateCommand {
|
|
get { return updateCommand; }
|
|
set { updateCommand = value; }
|
|
}
|
|
|
|
// LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
|
|
SqlDataSourceCommandType updateCommandType = SqlDataSourceCommandType.Text;
|
|
public SqlDataSourceCommandType UpdateCommandType {
|
|
get { return updateCommandType; }
|
|
set { updateCommandType = value; }
|
|
}
|
|
|
|
[EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
|
|
[PersistenceModeAttribute (PersistenceMode.InnerProperty)]
|
|
[DefaultValueAttribute (null)]
|
|
public ParameterCollection UpdateParameters {
|
|
get { return GetParameterCollection (ref updateParameters, false, false); }
|
|
}
|
|
|
|
void ParametersChanged (object source, EventArgs args)
|
|
{
|
|
OnDataSourceViewChanged (EventArgs.Empty);
|
|
}
|
|
|
|
ParameterCollection GetParameterCollection (ref ParameterCollection output, bool propagateTrackViewState, bool subscribeChanged)
|
|
{
|
|
if (output != null)
|
|
return output;
|
|
|
|
output = new ParameterCollection ();
|
|
if(subscribeChanged)
|
|
output.ParametersChanged += new EventHandler (ParametersChanged);
|
|
|
|
if (IsTrackingViewState && propagateTrackViewState)
|
|
((IStateManager) output).TrackViewState ();
|
|
|
|
return output;
|
|
}
|
|
|
|
protected virtual string ParameterPrefix {
|
|
get {
|
|
switch (owner.ProviderName) {
|
|
case "":
|
|
case "System.Data.SqlClient": return "@";
|
|
case "System.Data.OracleClient": return ":";
|
|
}
|
|
return "";
|
|
}
|
|
}
|
|
|
|
ParameterCollection deleteParameters;
|
|
ParameterCollection filterParameters;
|
|
ParameterCollection insertParameters;
|
|
ParameterCollection selectParameters;
|
|
ParameterCollection updateParameters;
|
|
|
|
bool tracking;
|
|
|
|
string name;
|
|
SqlDataSource owner;
|
|
|
|
#region OnDelete
|
|
static readonly object EventDeleted = new object ();
|
|
protected virtual void OnDeleted (SqlDataSourceStatusEventArgs e)
|
|
{
|
|
if (!HasEvents ()) return;
|
|
SqlDataSourceStatusEventHandler h = Events [EventDeleted] as SqlDataSourceStatusEventHandler;
|
|
if (h != null)
|
|
h (this, e);
|
|
}
|
|
|
|
public event SqlDataSourceStatusEventHandler Deleted {
|
|
add { Events.AddHandler (EventDeleted, value); }
|
|
remove { Events.RemoveHandler (EventDeleted, value); }
|
|
}
|
|
|
|
static readonly object EventDeleting = new object ();
|
|
protected virtual void OnDeleting (SqlDataSourceCommandEventArgs e)
|
|
{
|
|
if (!HasEvents ()) return;
|
|
SqlDataSourceCommandEventHandler h = Events [EventDeleting] as SqlDataSourceCommandEventHandler;
|
|
if (h != null)
|
|
h (this, e);
|
|
}
|
|
public event SqlDataSourceCommandEventHandler Deleting {
|
|
add { Events.AddHandler (EventDeleting, value); }
|
|
remove { Events.RemoveHandler (EventDeleting, value); }
|
|
}
|
|
#endregion
|
|
|
|
#region OnFiltering
|
|
static readonly object EventFiltering = new object ();
|
|
protected virtual void OnFiltering (SqlDataSourceFilteringEventArgs e)
|
|
{
|
|
if (!HasEvents ()) return;
|
|
SqlDataSourceFilteringEventHandler h = Events [EventFiltering] as SqlDataSourceFilteringEventHandler;
|
|
if (h != null)
|
|
h (this, e);
|
|
}
|
|
public event SqlDataSourceFilteringEventHandler Filtering {
|
|
add { Events.AddHandler (EventFiltering, value); }
|
|
remove { Events.RemoveHandler (EventFiltering, value); }
|
|
}
|
|
#endregion
|
|
|
|
#region OnInsert
|
|
static readonly object EventInserted = new object ();
|
|
protected virtual void OnInserted (SqlDataSourceStatusEventArgs e)
|
|
{
|
|
if (!HasEvents ()) return;
|
|
SqlDataSourceStatusEventHandler h = Events [EventInserted] as SqlDataSourceStatusEventHandler;
|
|
if (h != null)
|
|
h (this, e);
|
|
}
|
|
|
|
public event SqlDataSourceStatusEventHandler Inserted {
|
|
add { Events.AddHandler (EventInserted, value); }
|
|
remove { Events.RemoveHandler (EventInserted, value); }
|
|
}
|
|
|
|
static readonly object EventInserting = new object ();
|
|
protected virtual void OnInserting (SqlDataSourceCommandEventArgs e)
|
|
{
|
|
if (!HasEvents ()) return;
|
|
SqlDataSourceCommandEventHandler h = Events [EventInserting] as SqlDataSourceCommandEventHandler;
|
|
if (h != null)
|
|
h (this, e);
|
|
}
|
|
public event SqlDataSourceCommandEventHandler Inserting {
|
|
add { Events.AddHandler (EventInserting, value); }
|
|
remove { Events.RemoveHandler (EventInserting, value); }
|
|
}
|
|
#endregion
|
|
|
|
#region OnSelect
|
|
static readonly object EventSelected = new object ();
|
|
protected virtual void OnSelected (SqlDataSourceStatusEventArgs e)
|
|
{
|
|
if (!HasEvents ()) return;
|
|
SqlDataSourceStatusEventHandler h = Events [EventSelected] as SqlDataSourceStatusEventHandler;
|
|
if (h != null)
|
|
h (this, e);
|
|
}
|
|
|
|
public event SqlDataSourceStatusEventHandler Selected {
|
|
add { Events.AddHandler (EventSelected, value); }
|
|
remove { Events.RemoveHandler (EventSelected, value); }
|
|
}
|
|
|
|
static readonly object EventSelecting = new object ();
|
|
protected virtual void OnSelecting (SqlDataSourceSelectingEventArgs e)
|
|
{
|
|
if (!HasEvents ()) return;
|
|
SqlDataSourceSelectingEventHandler h = Events [EventSelecting] as SqlDataSourceSelectingEventHandler;
|
|
if (h != null)
|
|
h (this, e);
|
|
}
|
|
public event SqlDataSourceSelectingEventHandler Selecting {
|
|
add { Events.AddHandler (EventSelecting, value); }
|
|
remove { Events.RemoveHandler (EventSelecting, value); }
|
|
}
|
|
#endregion
|
|
|
|
#region OnUpdate
|
|
static readonly object EventUpdated = new object ();
|
|
protected virtual void OnUpdated (SqlDataSourceStatusEventArgs e)
|
|
{
|
|
if (owner.EnableCaching)
|
|
owner.Cache.Expire ();
|
|
|
|
if (!HasEvents ()) return;
|
|
SqlDataSourceStatusEventHandler h = Events [EventUpdated] as SqlDataSourceStatusEventHandler;
|
|
if (h != null)
|
|
h (this, e);
|
|
}
|
|
|
|
public event SqlDataSourceStatusEventHandler Updated {
|
|
add { Events.AddHandler (EventUpdated, value); }
|
|
remove { Events.RemoveHandler (EventUpdated, value); }
|
|
}
|
|
|
|
static readonly object EventUpdating = new object ();
|
|
protected virtual void OnUpdating (SqlDataSourceCommandEventArgs e)
|
|
{
|
|
if (!HasEvents ()) return;
|
|
SqlDataSourceCommandEventHandler h = Events [EventUpdating] as SqlDataSourceCommandEventHandler;
|
|
if (h != null)
|
|
h (this, e);
|
|
}
|
|
public event SqlDataSourceCommandEventHandler Updating {
|
|
add { Events.AddHandler (EventUpdating, value); }
|
|
remove { Events.RemoveHandler (EventUpdating, value); }
|
|
}
|
|
#endregion
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|