SqlDataSource.cs 13 KB

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