SqlDataSource.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449
  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. if (IsTrackingViewState)
  75. ((IStateManager) view).TrackViewState ();
  76. return view;
  77. }
  78. protected virtual DbProviderFactory GetDbProviderFactory ()
  79. {
  80. DbProviderFactory f = null;
  81. if (!String.IsNullOrEmpty (ProviderName)) {
  82. f = DbProviderFactories.GetFactory(ProviderName);
  83. return f;
  84. }
  85. return SqlClientFactory.Instance;
  86. }
  87. internal DbProviderFactory GetDbProviderFactoryInternal ()
  88. {
  89. return GetDbProviderFactory ();
  90. }
  91. protected override ICollection GetViewNames ()
  92. {
  93. return emptyNames;
  94. }
  95. public int Insert ()
  96. {
  97. return View.Insert (null);
  98. }
  99. public int Delete ()
  100. {
  101. return View.Delete (null, null);
  102. }
  103. public IEnumerable Select (DataSourceSelectArguments args)
  104. {
  105. return View.Select (args);
  106. }
  107. public int Update ()
  108. {
  109. return View.Update (null, null, null);
  110. }
  111. protected internal override void OnInit (EventArgs e)
  112. {
  113. Page.LoadComplete += OnPageLoadComplete;
  114. }
  115. void OnPageLoadComplete (object sender, EventArgs e)
  116. {
  117. FilterParameters.UpdateValues (Context, this);
  118. SelectParameters.UpdateValues (Context, this);
  119. }
  120. protected override void LoadViewState (object savedState)
  121. {
  122. Pair p = savedState as Pair;
  123. if (p != null) {
  124. base.LoadViewState (p.First);
  125. ((IStateManager) View).LoadViewState (p.Second);
  126. }
  127. }
  128. protected override object SaveViewState ()
  129. {
  130. object me = base.SaveViewState (), view = ((IStateManager) View).SaveViewState ();
  131. if (me != null || view != null)
  132. return new Pair (me, view);
  133. else
  134. return null;
  135. }
  136. protected override void TrackViewState ()
  137. {
  138. base.TrackViewState ();
  139. if (view != null)
  140. ((IStateManager) view).TrackViewState ();
  141. }
  142. [DefaultValue (true)]
  143. public virtual bool CancelSelectOnNullParameter {
  144. get { return View.CancelSelectOnNullParameter; }
  145. set { View.CancelSelectOnNullParameter = value; }
  146. }
  147. [DefaultValue (ConflictOptions.OverwriteChanges)]
  148. public ConflictOptions ConflictDetection {
  149. get { return View.ConflictDetection; }
  150. set { View.ConflictDetection = value; }
  151. }
  152. [DefaultValue (SqlDataSourceCommandType.Text)]
  153. public SqlDataSourceCommandType DeleteCommandType {
  154. get { return View.DeleteCommandType; }
  155. set { View.DeleteCommandType = value; }
  156. }
  157. [DefaultValue (SqlDataSourceCommandType.Text)]
  158. public SqlDataSourceCommandType InsertCommandType {
  159. get { return View.InsertCommandType; }
  160. set { View.InsertCommandType = value; }
  161. }
  162. [DefaultValue (SqlDataSourceCommandType.Text)]
  163. public SqlDataSourceCommandType SelectCommandType {
  164. get { return View.SelectCommandType; }
  165. set { View.SelectCommandType = value; }
  166. }
  167. [DefaultValue (SqlDataSourceCommandType.Text)]
  168. public SqlDataSourceCommandType UpdateCommandType {
  169. get { return View.UpdateCommandType; }
  170. set { View.UpdateCommandType = value; }
  171. }
  172. [DefaultValue ("{0}")]
  173. public string OldValuesParameterFormatString {
  174. get { return View.OldValuesParameterFormatString; }
  175. set { View.OldValuesParameterFormatString = value; }
  176. }
  177. [DefaultValue ("")]
  178. public string SortParameterName
  179. {
  180. get { return View.SortParameterName; }
  181. set { View.SortParameterName = value; }
  182. }
  183. [DefaultValueAttribute ("")]
  184. public string FilterExpression
  185. {
  186. get { return View.FilterExpression; }
  187. set { View.FilterExpression = value; }
  188. }
  189. private string providerName = "";
  190. [DefaultValueAttribute ("")]
  191. [TypeConverterAttribute ("System.Web.UI.Design.WebControls.DataProviderNameConverter, " + Consts.AssemblySystem_Design)]
  192. public virtual string ProviderName {
  193. get { return providerName; }
  194. set
  195. {
  196. providerName = value;
  197. RaiseDataSourceChangedEvent (EventArgs.Empty);
  198. }
  199. }
  200. private string connectionString = "";
  201. [EditorAttribute ("System.Web.UI.Design.WebControls.SqlDataSourceConnectionStringEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
  202. [DefaultValueAttribute ("")]
  203. public virtual string ConnectionString {
  204. get { return connectionString; }
  205. set
  206. {
  207. connectionString = value;
  208. RaiseDataSourceChangedEvent (EventArgs.Empty);
  209. }
  210. }
  211. // LAME SPEC: MSDN says value should be saved in ViewState but tests show otherwise.
  212. private SqlDataSourceMode dataSourceMode = SqlDataSourceMode.DataSet;
  213. [DefaultValueAttribute (SqlDataSourceMode.DataSet)]
  214. public SqlDataSourceMode DataSourceMode {
  215. get { return dataSourceMode; }
  216. set
  217. {
  218. dataSourceMode = value;
  219. RaiseDataSourceChangedEvent (EventArgs.Empty);
  220. }
  221. }
  222. [DefaultValueAttribute ("")]
  223. public string DeleteCommand {
  224. get { return View.DeleteCommand; }
  225. set { View.DeleteCommand = value; }
  226. }
  227. [EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
  228. [MergablePropertyAttribute (false)]
  229. [PersistenceModeAttribute (PersistenceMode.InnerProperty)]
  230. [DefaultValueAttribute (null)]
  231. public ParameterCollection DeleteParameters {
  232. get { return View.DeleteParameters; }
  233. }
  234. [DefaultValueAttribute (null)]
  235. [EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
  236. [MergablePropertyAttribute (false)]
  237. [PersistenceModeAttribute (PersistenceMode.InnerProperty)]
  238. public ParameterCollection FilterParameters {
  239. get { return View.FilterParameters; }
  240. }
  241. [DefaultValueAttribute ("")]
  242. public string InsertCommand {
  243. get { return View.InsertCommand; }
  244. set { View.InsertCommand = value; }
  245. }
  246. [PersistenceModeAttribute (PersistenceMode.InnerProperty)]
  247. [DefaultValueAttribute (null)]
  248. [MergablePropertyAttribute (false)]
  249. [EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
  250. public ParameterCollection InsertParameters {
  251. get { return View.InsertParameters; }
  252. }
  253. [DefaultValueAttribute ("")]
  254. public string SelectCommand {
  255. get { return View.SelectCommand; }
  256. set { View.SelectCommand = value; }
  257. }
  258. [DefaultValueAttribute (null)]
  259. [PersistenceModeAttribute (PersistenceMode.InnerProperty)]
  260. [MergablePropertyAttribute (false)]
  261. [EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
  262. public ParameterCollection SelectParameters {
  263. get { return View.SelectParameters; }
  264. }
  265. [DefaultValueAttribute ("")]
  266. public string UpdateCommand {
  267. get { return View.UpdateCommand; }
  268. set { View.UpdateCommand = value; }
  269. }
  270. [PersistenceModeAttribute (PersistenceMode.InnerProperty)]
  271. [EditorAttribute ("System.Web.UI.Design.WebControls.ParameterCollectionEditor, " + Consts.AssemblySystem_Design, "System.Drawing.Design.UITypeEditor, " + Consts.AssemblySystem_Drawing)]
  272. [MergablePropertyAttribute (false)]
  273. [DefaultValueAttribute (null)]
  274. public ParameterCollection UpdateParameters {
  275. get { return View.UpdateParameters; }
  276. }
  277. #region TODO
  278. int cacheDuration = 0;
  279. bool enableCaching = false;
  280. string cacheKeyDependency = null;
  281. string sqlCacheDependency = null;
  282. DataSourceCacheManager cache = null;
  283. DataSourceCacheExpiry cacheExpirationPolicy = DataSourceCacheExpiry.Absolute;
  284. internal DataSourceCacheManager Cache
  285. {
  286. get
  287. {
  288. if (cache == null)
  289. cache = new DataSourceCacheManager (CacheDuration, CacheKeyDependency, CacheExpirationPolicy, this, Context);
  290. return cache;
  291. }
  292. }
  293. [DefaultValue ("")]
  294. public virtual string CacheKeyDependency
  295. {
  296. get { return cacheKeyDependency != null ? cacheKeyDependency : string.Empty; }
  297. set { cacheKeyDependency = value; }
  298. }
  299. [MonoTODO ("SQLServer specific")]
  300. [DefaultValue ("")]
  301. public virtual string SqlCacheDependency {
  302. get { return sqlCacheDependency != null ? sqlCacheDependency : string.Empty; }
  303. set { sqlCacheDependency = value; }
  304. }
  305. [DefaultValue (0)]
  306. public virtual int CacheDuration {
  307. get { return cacheDuration; }
  308. set
  309. {
  310. if (value < 0)
  311. throw new ArgumentOutOfRangeException ("value", "The duration must be non-negative");
  312. cacheDuration = value;
  313. }
  314. }
  315. [DefaultValue (DataSourceCacheExpiry.Absolute)]
  316. public virtual DataSourceCacheExpiry CacheExpirationPolicy {
  317. get { return cacheExpirationPolicy; ; }
  318. set { cacheExpirationPolicy = value; }
  319. }
  320. [DefaultValue (false)]
  321. public virtual bool EnableCaching {
  322. get { return enableCaching; }
  323. set
  324. {
  325. if (DataSourceMode == SqlDataSourceMode.DataReader && value == true)
  326. throw new NotSupportedException ();
  327. enableCaching = value;
  328. }
  329. }
  330. #endregion
  331. public event SqlDataSourceStatusEventHandler Deleted {
  332. add { View.Deleted += value; }
  333. remove { View.Deleted -= value; }
  334. }
  335. public event SqlDataSourceCommandEventHandler Deleting {
  336. add { View.Deleting += value; }
  337. remove { View.Deleting -= value; }
  338. }
  339. public event SqlDataSourceStatusEventHandler Inserted {
  340. add { View.Inserted += value; }
  341. remove { View.Inserted -= value; }
  342. }
  343. public event SqlDataSourceFilteringEventHandler Filtering {
  344. add { View.Filtering += value; }
  345. remove { View.Filtering -= value; }
  346. }
  347. public event SqlDataSourceCommandEventHandler Inserting {
  348. add { View.Inserting += value; }
  349. remove { View.Inserting -= value; }
  350. }
  351. public event SqlDataSourceStatusEventHandler Selected {
  352. add { View.Selected += value; }
  353. remove { View.Selected -= value; }
  354. }
  355. public event SqlDataSourceSelectingEventHandler Selecting {
  356. add { View.Selecting += value; }
  357. remove { View.Selecting -= value; }
  358. }
  359. public event SqlDataSourceStatusEventHandler Updated {
  360. add { View.Updated += value; }
  361. remove { View.Updated -= value; }
  362. }
  363. public event SqlDataSourceCommandEventHandler Updating {
  364. add { View.Updating += value; }
  365. remove { View.Updating -= value; }
  366. }
  367. SqlDataSourceView view;
  368. SqlDataSourceView View {
  369. get {
  370. if (view == null) {
  371. view = CreateDataSourceView ("DefaultView");
  372. if (IsTrackingViewState)
  373. ((IStateManager) view).TrackViewState ();
  374. }
  375. return view;
  376. }
  377. }
  378. }
  379. }
  380. #endif