Ho cercato di trovare una risposta a questa domanda ora per giorni e trovo difficile credere che questo non possa essere fatto.Accesso ai dati recuperati
voglio arrivare al DataSet/DataTable
che è costruito quando un metodo SqlDataSource.Select
viene chiamato automaticamente dal ASP.NET run-time quando una pagina è in costruzione.
So che posso eseguirlo nel codice ma questo fa un secondo viaggio nel database e vorrei davvero evitare questo. Ogni esempio che ho trovato ti dice di eseguire il metodo Select nel codice sottostante.
C'è un modo per accedere ai dati che sono già stati recuperati?
Sai, ho cercato di capirlo una volta, anni fa, e ho deciso che era solo più facile da legare il codice in code-behind quindi ho avuto più facile accesso al set di dati. Se qualcuno sa come farlo, potrebbe cambiare il modo in cui mi avvicino a situazioni simili che vanno avanti. +1 per chiedere. – David
Non lo userei affatto. Utilizzare invece ADO.NET (ad esempio 'DataAdapter.Fill (DataTable)') o un vero mappatore ORM come NHibernate o Entity framework. Ad ogni modo, non è chiaro il motivo per cui pensi che "il codice dietro faccia un secondo viaggio nel database". Usa 'if (! IsPostBack)' allora. –
Non ho davvero una scelta sul controllo. Devo apportare una modifica a una pagina esistente e non ho il lusso di riscriverla. Quando si chiama il metodo di selezione su SqlDataSource, viene eseguito un viaggio nel database in base a Microsoft http://msdn.microsoft.com/en-us/library/system.web.ui.webcontrols.sqldatasource.select.aspx – dscarr