SqlDataSource.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456
  1. //
  2. // System.Web.UI.WebControls.SqlDataSource
  3. //
  4. // Authors:
  5. // Ben Maurer ([email protected])
  6. // Sanjay Gupta ([email protected])
  7. // Chris Toshok ([email protected])
  8. //
  9. // (C) 2003 Ben Maurer
  10. // (C) 2004-2006 Novell, Inc. (http://www.novell.com)
  11. //
  12. //
  13. // Permission is hereby granted, free of charge, to any person obtaining
  14. // a copy of this software and associated documentation files (the
  15. // "Software"), to deal in the Software without restriction, including
  16. // without limitation the rights to use, copy, modify, merge, publish,
  17. // distribute, sublicense, and/or sell copies of the Software, and to
  18. // permit persons to whom the Software is furnished to do so, subject to
  19. // the following conditions:
  20. //
  21. // The above copyright notice and this permission notice shall be
  22. // included in all copies or substantial portions of the Software.
  23. //
  24. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  25. // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  26. // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  27. // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
  28. // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
  29. // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  30. // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  31. //
  32. #if NET_2_0
  33. using System.Collections;
  34. using System.Collections.Specialized;
  35. using System.Configuration;
  36. using System.Drawing;
  37. using System.Web.Configuration;
  38. using System.Data.Common;
  39. using System.Data.SqlClient;
  40. using System.Text;
  41. using System.ComponentModel;
  42. namespace System.Web.UI.WebControls {
  43. [ParseChildrenAttribute (true)]
  44. [PersistChildrenAttribute (false)]
  45. [DefaultPropertyAttribute ("SelectQuery")]
  46. [DesignerAttribute ("System.Web.UI.Design.WebControls.SqlDataSourceDesigner, " + Consts.AssemblySystem_Design, "System.ComponentModel.Design.IDesigner")]
  47. [DefaultEventAttribute ("Selecting")]
  48. public class SqlDataSource : DataSourceControl {
  49. static readonly string [] emptyNames = new string [] { "DefaultView" };
  50. public SqlDataSource ()
  51. {
  52. }
  53. public SqlDataSource (string connectionString, string selectCommand)
  54. {
  55. ConnectionString = connectionString;
  56. SelectCommand = selectCommand;
  57. }
  58. public SqlDataSource (string providerName, string connectionString, string selectCommand)
  59. {
  60. ProviderName = providerName;
  61. ConnectionString = connectionString;
  62. SelectCommand = selectCommand;
  63. }
  64. protected override DataSourceView GetView (string viewName)
  65. {
  66. if (String.IsNullOrEmpty (viewName) || (String.Compare (viewName, emptyNames [0], StringComparison.InvariantCultureIgnoreCase) == 0))
  67. return View;
  68. else
  69. throw new ArgumentException ("viewName");
  70. }
  71. protected virtual SqlDataSourceView CreateDataSourceView (string viewName)
  72. {
  73. SqlDataSourceView view = new SqlDataSourceView (this, viewName, this.Context);
  74. view.DataSourceViewChanged += new EventHandler (ViewChanged);
  75. if (IsTrackingViewState)
  76. ((IStateManager) view).TrackViewState ();
  77. return view;
  78. }
  79. protected virtual DbProviderFactory GetDbProviderFactory ()
  80. {
  81. DbProviderFactory f = null;
  82. if (!String.IsNullOrEmpty (ProviderName)) {
  83. f = DbProviderFactories.GetFactory(ProviderName);
  84. return f;
  85. }
  86. return SqlClientFactory.Instance;
  87. }
  88. internal DbProviderFactory GetDbProviderFactoryInternal ()
  89. {
  90. return GetDbProviderFactory ();
  91. }
  92. protected override ICollection GetViewNames ()
  93. {
  94. return emptyNames;
  95. }
  96. public int Insert ()
  97. {
  98. return View.Insert (null);
  99. }
  100. public int Delete ()
  101. {
  102. return View.Delete (null, null);
  103. }
  104. public IEnumerable Select (DataSourceSelectArguments args)
  105. {
  106. return View.Select (args);
  107. }
  108. public int Update ()
  109. {
  110. return View.Update (null, null, null);
  111. }
  112. protected internal override void OnInit (EventArgs e)
  113. {
  114. Page.LoadComplete += OnPageLoadComplete;
  115. }
  116. void OnPageLoadComplete (object sender, EventArgs e)
  117. {
  118. FilterParameters.UpdateValues (Context, this);
  119. SelectParameters.UpdateValues (Context, this);
  120. }
  121. protected override void LoadViewState (object savedState)
  122. {
  123. Pair p = savedState as Pair;
  124. if (p != null) {
  125. base.LoadViewState (p.First);
  126. ((IStateManager) View).LoadViewState (p.Second);
  127. }
  128. }
  129. protected override object SaveViewState ()
  130. {
  131. object me = base.SaveViewState (), view = ((IStateManager) View).SaveViewState ();
  132. if (me != null || view != null)
  133. return new Pair (me, view);
  134. else
  135. return null;
  136. }
  137. protected override void TrackViewState ()
  138. {
  139. base.TrackViewState ();
  140. if (view != null)
  141. ((IStateManager) view).TrackViewState ();
  142. }
  143. [DefaultValue (true)]
  144. public virtual bool CancelSelectOnNullParameter {
  145. get { return View.CancelSelectOnNullParameter; }
  146. set { View.CancelSelectOnNullParameter = value; }
  147. }
  148. [DefaultValue (ConflictOptions.OverwriteChanges)]
  149. public ConflictOptions ConflictDetection {
  150. get { return View.ConflictDetection; }
  151. set { View.ConflictDetection = value; }
  152. }
  153. [DefaultValue (SqlDataSourceCommandType.Text)]
  154. public SqlDataSourceCommandType DeleteCommandType {
  155. get { return View.DeleteCommandType; }
  156. set { View.DeleteCommandType = value; }
  157. }
  158. [DefaultValue (SqlDataSourceCommandType.Text)]
  159. public SqlDataSourceCommandType InsertCommandType {
  160. get { return View.InsertCommandType; }
  161. set { View.InsertCommandType = value; }
  162. }
  163. [DefaultValue (SqlDataSourceCommandType.Text)]
  164. public SqlDataSourceCommandType SelectCommandType {
  165. get { return View.SelectCommandType; }
  166. set { View.SelectCommandType = value; }
  167. }
  168. [DefaultValue (SqlDataSourceCommandType.Text)]
  169. public SqlDataSourceCommandType UpdateCommandType {
  170. get { return View.UpdateCommandType; }
  171. set { View.UpdateCommandType = value; }
  172. }
  173. [DefaultValue ("{0}")]
  174. public string OldValuesParameterFormatString {
  175. get { return View.OldValuesParameterFormatString; }
  176. set { View.OldValuesParameterFormatString = value; }
  177. }
  178. [DefaultValue ("")]
  179. public string SortParameterName
  180. {
  181. get { return View.SortParameterName; }
  182. set { View.SortParameterName = value; }
  183. }
  184. [DefaultValueAttribute ("")]
  185. public string FilterExpression
  186. {
  187. get { return View.FilterExpression; }
  188. set { View.FilterExpression = value; }
  189. }
  190. private string providerName = "";
  191. [DefaultValueAttribute ("")]
  192. [TypeConverterAttribute ("System.Web.UI.Design.WebControls.DataProviderNameConverter, " + Consts.AssemblySystem_Design)]
  193. public virtual string ProviderName {
  194. get { return providerName; }
  195. set
  196. {
  197. providerName = value;
  198. RaiseDataSourceChangedEvent (EventArgs.Empty);
  199. }
  200. }
  201. private string connectionString = "";
  202. [EditorAttribute ("System.Web.UI.Design.WebControls.SqlDataSourceConnectionStringEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
  203. [DefaultValueAttribute ("")]
  204. public virtual string ConnectionString {
  205. get { return connectionString; }
  206. set
  207. {
  208. connectionString = value;
  209. RaiseDataSourceChangedEvent (EventArgs.Empty);
  210. }
  211. }
  212. // LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
  213. private SqlDataSourceMode dataSourceMode = SqlDataSourceMode.DataSet;
  214. [DefaultValueAttribute (SqlDataSourceMode.DataSet)]
  215. public SqlDataSourceMode DataSourceMode {
  216. get { return dataSourceMode; }
  217. set
  218. {
  219. dataSourceMode = value;
  220. RaiseDataSourceChangedEvent (EventArgs.Empty);
  221. }
  222. }
  223. [DefaultValueAttribute ("")]
  224. public string DeleteCommand {
  225. get { return View.DeleteCommand; }
  226. set { View.DeleteCommand = value; }
  227. }
  228. [EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
  229. [MergablePropertyAttribute (false)]
  230. [PersistenceModeAttribute (PersistenceMode.InnerProperty)]
  231. [DefaultValueAttribute (null)]
  232. public ParameterCollection DeleteParameters {
  233. get { return View.DeleteParameters; }
  234. }
  235. [DefaultValueAttribute (null)]
  236. [EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
  237. [MergablePropertyAttribute (false)]
  238. [PersistenceModeAttribute (PersistenceMode.InnerProperty)]
  239. public ParameterCollection FilterParameters {
  240. get { return View.FilterParameters; }
  241. }
  242. [DefaultValueAttribute ("")]
  243. public string InsertCommand {
  244. get { return View.InsertCommand; }
  245. set { View.InsertCommand = value; }
  246. }
  247. [PersistenceModeAttribute (PersistenceMode.InnerProperty)]
  248. [DefaultValueAttribute (null)]
  249. [MergablePropertyAttribute (false)]
  250. [EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
  251. public ParameterCollection InsertParameters {
  252. get { return View.InsertParameters; }
  253. }
  254. [DefaultValueAttribute ("")]
  255. public string SelectCommand {
  256. get { return View.SelectCommand; }
  257. set { View.SelectCommand = value; }
  258. }
  259. [DefaultValueAttribute (null)]
  260. [PersistenceModeAttribute (PersistenceMode.InnerProperty)]
  261. [MergablePropertyAttribute (false)]
  262. [EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
  263. public ParameterCollection SelectParameters {
  264. get { return View.SelectParameters; }
  265. }
  266. [DefaultValueAttribute ("")]
  267. public string UpdateCommand {
  268. get { return View.UpdateCommand; }
  269. set { View.UpdateCommand = value; }
  270. }
  271. [PersistenceModeAttribute (PersistenceMode.InnerProperty)]
  272. [EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
  273. [MergablePropertyAttribute (false)]
  274. [DefaultValueAttribute (null)]
  275. public ParameterCollection UpdateParameters {
  276. get { return View.UpdateParameters; }
  277. }
  278. #region TODO
  279. int cacheDuration = 0;
  280. bool enableCaching = false;
  281. string cacheKeyDependency = null;
  282. string sqlCacheDependency = null;
  283. DataSourceCacheManager cache = null;
  284. DataSourceCacheExpiry cacheExpirationPolicy = DataSourceCacheExpiry.Absolute;
  285. internal DataSourceCacheManager Cache
  286. {
  287. get
  288. {
  289. if (cache == null)
  290. cache = new DataSourceCacheManager (CacheDuration, CacheKeyDependency, CacheExpirationPolicy, this, Context);
  291. return cache;
  292. }
  293. }
  294. [DefaultValue ("")]
  295. public virtual string CacheKeyDependency
  296. {
  297. get { return cacheKeyDependency != null ? cacheKeyDependency : string.Empty; }
  298. set { cacheKeyDependency = value; }
  299. }
  300. [MonoTODO ("SQLServer specific")]
  301. [DefaultValue ("")]
  302. public virtual string SqlCacheDependency {
  303. get { return sqlCacheDependency != null ? sqlCacheDependency : string.Empty; }
  304. set { sqlCacheDependency = value; }
  305. }
  306. [DefaultValue (0)]
  307. public virtual int CacheDuration {
  308. get { return cacheDuration; }
  309. set
  310. {
  311. if (value < 0)
  312. throw new ArgumentOutOfRangeException ("value", "The duration must be non-negative");
  313. cacheDuration = value;
  314. }
  315. }
  316. [DefaultValue (DataSourceCacheExpiry.Absolute)]
  317. public virtual DataSourceCacheExpiry CacheExpirationPolicy {
  318. get { return cacheExpirationPolicy; ; }
  319. set { cacheExpirationPolicy = value; }
  320. }
  321. [DefaultValue (false)]
  322. public virtual bool EnableCaching {
  323. get { return enableCaching; }
  324. set
  325. {
  326. if (DataSourceMode == SqlDataSourceMode.DataReader && value == true)
  327. throw new NotSupportedException ();
  328. enableCaching = value;
  329. }
  330. }
  331. #endregion
  332. public event SqlDataSourceStatusEventHandler Deleted {
  333. add { View.Deleted += value; }
  334. remove { View.Deleted -= value; }
  335. }
  336. public event SqlDataSourceCommandEventHandler Deleting {
  337. add { View.Deleting += value; }
  338. remove { View.Deleting -= value; }
  339. }
  340. public event SqlDataSourceStatusEventHandler Inserted {
  341. add { View.Inserted += value; }
  342. remove { View.Inserted -= value; }
  343. }
  344. public event SqlDataSourceFilteringEventHandler Filtering {
  345. add { View.Filtering += value; }
  346. remove { View.Filtering -= value; }
  347. }
  348. public event SqlDataSourceCommandEventHandler Inserting {
  349. add { View.Inserting += value; }
  350. remove { View.Inserting -= value; }
  351. }
  352. public event SqlDataSourceStatusEventHandler Selected {
  353. add { View.Selected += value; }
  354. remove { View.Selected -= value; }
  355. }
  356. public event SqlDataSourceSelectingEventHandler Selecting {
  357. add { View.Selecting += value; }
  358. remove { View.Selecting -= value; }
  359. }
  360. public event SqlDataSourceStatusEventHandler Updated {
  361. add { View.Updated += value; }
  362. remove { View.Updated -= value; }
  363. }
  364. public event SqlDataSourceCommandEventHandler Updating {
  365. add { View.Updating += value; }
  366. remove { View.Updating -= value; }
  367. }
  368. SqlDataSourceView view;
  369. SqlDataSourceView View {
  370. get {
  371. if (view == null) {
  372. view = CreateDataSourceView ("DefaultView");
  373. view.DataSourceViewChanged += new EventHandler (ViewChanged);
  374. if (IsTrackingViewState)
  375. ((IStateManager) view).TrackViewState ();
  376. }
  377. return view;
  378. }
  379. }
  380. void ViewChanged (object source, EventArgs e)
  381. {
  382. RaiseDataSourceChangedEvent (e);
  383. }
  384. }
  385. }
  386. #endif