473,943 Members | 19,306 Online
Bytes | Software Development & Data Engineering Community
+ Post

Home Posts Topics Members FAQ

SqlDataAdaptor problem

Hi,

I have a problem understanding the SqlDataAdaptor and the DataSet.

I have a dll which has various methods for running stored procedures etc. It
also has a method which allows the client to return a DataSet from a table.
The client can modify this DataSet and I have wrote a function which will
take this DataSet back in and update the Database.

I assume this is what is meant with disconnected datasets?

Anyway, the method for updating the DataSet is not very good.

The problem is, a SqlDataAdaptor is required to update the Database.
When the DataSet was first returned to the user, the SqlDataAdaptor was a
local variable and is now out of scope. To update I have to do this:

1 - Create a new SqlDataAdaptor with the same SQL statement when I
originally got the DataSet

2. Use the Update method to update the DataSet

This really isnt a good way of working, sicne the original SQL statment to
get the DataSet needs to be kept.

I dont think I fully understand how this should work.

Any help on this would be appreciated.

--
Steven
www.stevenblair.com
Nov 15 '05 #1
3 2000
It's kind of hard to follow what you're doing in your code. Can you supply a
sample?

You don't want to copy the adapter. That won't work.

Why is the SqlDataAdapter out of scope?

If you have a method that creates the SqlDataAdapter locally and then
returns it, then a reference is returned and the original won't be disposed
of.

Pete

"Steven Blair" <st**********@b tinternet.com> wrote in message
news:bu******** **@titan.btinte rnet.com...
Hi,

I have a problem understanding the SqlDataAdaptor and the DataSet.

I have a dll which has various methods for running stored procedures etc. It also has a method which allows the client to return a DataSet from a table. The client can modify this DataSet and I have wrote a function which will
take this DataSet back in and update the Database.

I assume this is what is meant with disconnected datasets?

Anyway, the method for updating the DataSet is not very good.

The problem is, a SqlDataAdaptor is required to update the Database.
When the DataSet was first returned to the user, the SqlDataAdaptor was a
local variable and is now out of scope. To update I have to do this:

1 - Create a new SqlDataAdaptor with the same SQL statement when I
originally got the DataSet

2. Use the Update method to update the DataSet

This really isnt a good way of working, sicne the original SQL statment to
get the DataSet needs to be kept.

I dont think I fully understand how this should work.

Any help on this would be appreciated.

--
Steven
www.stevenblair.com

Nov 15 '05 #2
Steven,

I assume you are using some sort of generic method to handle this. You
are right, you are either going to have to keep around the SQL statement, or
you will have to have some way of reconstructing it. However, this isn't a
bad design. The way to get around this is to have some sort of unique
identifier which allows you to know the operation (or SQL statement) that
you need to perform.

For example, you could have separate methods, like UpdateMyTable1,
UpdateMyTable2, etc, etc. Because each of the methods has a unique
identity, you can easily determine what the SQL should be. Another way to
do this would be to insert something into the data set upon creation that
would allow you to create the SQL when you get it back for updating.

Hope this helps.
--
- Nicholas Paldino [.NET/C# MVP]
- mv*@spam.guard. caspershouse.co m

"Steven Blair" <st**********@b tinternet.com> wrote in message
news:bu******** **@titan.btinte rnet.com...
Hi,

I have a problem understanding the SqlDataAdaptor and the DataSet.

I have a dll which has various methods for running stored procedures etc. It also has a method which allows the client to return a DataSet from a table. The client can modify this DataSet and I have wrote a function which will
take this DataSet back in and update the Database.

I assume this is what is meant with disconnected datasets?

Anyway, the method for updating the DataSet is not very good.

The problem is, a SqlDataAdaptor is required to update the Database.
When the DataSet was first returned to the user, the SqlDataAdaptor was a
local variable and is now out of scope. To update I have to do this:

1 - Create a new SqlDataAdaptor with the same SQL statement when I
originally got the DataSet

2. Use the Update method to update the DataSet

This really isnt a good way of working, sicne the original SQL statment to
get the DataSet needs to be kept.

I dont think I fully understand how this should work.

Any help on this would be appreciated.

--
Steven
www.stevenblair.com

Nov 15 '05 #3
Here is a example of what I am doing:

public bool Update(DataSet ds,ref int rowsUpdated,str ing table)

{

string select;

select = String.Format(" SELECT * FROM {0}",table);

SqlConnection myConnection = new SqlConnection(G etConnectionStr ing() );

SqlDataAdapter m_DataAdapter = new SqlDataAdapter( select,myConnec tion);

SqlCommandBuild er objBuilder = new SqlCommandBuild er(m_DataAdapte r);

m_DataAdapter.U pdateCommand = objBuilder.GetU pdateCommand();

rowsUpdated = m_DataAdapter.U pdate(ds);

return true;

}

So the client has to send in the original table that was used, then I am
guessing the line:

SqlDataAdapter m_DataAdapter = new SqlDataAdapter( select,myConnec tion);

Doea another full select on the database then an update after that.
Thats why i I think this way is flawed.

Hope this makes a bit more sense now.

--
Steven
www.stevenblair.com

"Steven Blair" <st**********@b tinternet.com> wrote in message
news:bu******** **@titan.btinte rnet.com...
Hi,

I have a problem understanding the SqlDataAdaptor and the DataSet.

I have a dll which has various methods for running stored procedures etc. It also has a method which allows the client to return a DataSet from a table. The client can modify this DataSet and I have wrote a function which will
take this DataSet back in and update the Database.

I assume this is what is meant with disconnected datasets?

Anyway, the method for updating the DataSet is not very good.

The problem is, a SqlDataAdaptor is required to update the Database.
When the DataSet was first returned to the user, the SqlDataAdaptor was a
local variable and is now out of scope. To update I have to do this:

1 - Create a new SqlDataAdaptor with the same SQL statement when I
originally got the DataSet

2. Use the Update method to update the DataSet

This really isnt a good way of working, sicne the original SQL statment to
get the DataSet needs to be kept.

I dont think I fully understand how this should work.

Any help on this would be appreciated.

--
Steven
www.stevenblair.com

Nov 15 '05 #4

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

0
3094
by: Bruce Davis | last post by:
I'm having a problem on windows (both 2000 and XP) with a multi-threaded tkinter gui application. The problem appears to be a deadlock condition when a child thread pops up a Pmw dialog window in the context of a main window. The problem does not occur on HPUX or Linux. The following simple example code illustrates the problem and the work around I've come up with; However, I'd like, very much, to get rid of the kludgy work around....
11
3785
by: Kostatus | last post by:
I have a virtual function in a base class, which is then overwritten by a function of the same name in a publically derived class. When I call the function using a pointer to the derived class (ClassB* b; b->func(); ) the base-class function is called instead of the new function in the derived class. All other similar functions (virtual in the base class and overwritten in the the derived class) work fine, it's just this one function. ...
117
7380
by: Peter Olcott | last post by:
www.halting-problem.com
28
5253
by: Jon Davis | last post by:
If I have a class with a virtual method, and a child class that overrides the virtual method, and then I create an instance of the child class AS A base class... BaseClass bc = new ChildClass(); .... and then call the virtual method, why is it that the base class's method is called instead of the overridden method? How do I fix this if I don't know at runtime what the child class is? I'm using Activator.CreateInstance() to load the...
1
1905
by: Iwan Petrow | last post by:
Hi, I have the following situation: Two tables with relation: T1: Id_T1:Primary key Data1_T1 Data2_T2 Id_T2:Secondary key
0
1100
by: Steven Blair | last post by:
Hi, I have a problem understanding the SqlDataAdaptor and the DataSet. I have a dll which has various methods for running stored procedures etc. It also has a method which allows the client to return a DataSet from a table. The client can modify this DataSet and I have wrote a function which will take this DataSet back in and update the Database. I assume this is what is meant with disconnected datasets?
6
3830
by: Ammar | last post by:
Dear All, I'm facing a small problem. I have a portal web site, that contains articles, for each article, the end user can send a comment about the article. The problem is: I the comment length is more that 1249 bytes, then the progress bar of the browser will move too slow and then displaying that the page not found!!!! If the message is less than or equal to 1249 then no problem.
16
4947
by: Dany | last post by:
Our web service was working fine until we installed .net Framework 1.1 service pack 1. Uninstalling SP1 is not an option because our largest customer says service packs marked as "critical" by Microsoft must be installed on their servers. Now german Umlaute (ä, ü, ö) and quotes are returned incorrectly in SOAP fault responses. This can be easily verified: Implement the following in a web service method (just raises a SOAPException with a...
2
4568
by: Mike Collins | last post by:
I cannot get the correct drop down list value from a drop down I have on my web form. I get the initial value that was loaded in the list. It was asked by someone else what the autopostback was set to...it is set to false. Can someone show me what I am doing wrong and tell me the correct way? Thank you. In the page load event, I am doing the following:
0
9970
by: Hystou | last post by:
Most computers default to English, but sometimes we require a different language, especially when relocating. Forgot to request a specific language before your computer shipped? No problem! You can effortlessly switch the default language on Windows 10 without reinstalling. I'll walk you through it. First, let's disable language synchronization. With a Microsoft account, language settings sync across devices. To prevent any complications,...
0
11542
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers, it seems that the internal comparison operator "<=>" tries to promote arguments from unsigned to signed. This is as boiled down as I can make it. Here is my compilation command: g++-12 -std=c++20 -Wnarrowing bit_field.cpp Here is the code in...
0
11133
jinu1996
by: jinu1996 | last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven tapestry of website design and digital marketing. It's not merely about having a website; it's about crafting an immersive digital experience that captivates audiences and drives business growth. The Art of Business Website Design Your website is...
0
10669
tracyyun
by: tracyyun | last post by:
Dear forum friends, With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each protocol has its own unique characteristics and advantages, but as a user who is planning to build a smart home system, I am a bit confused by the choice of these technologies. I'm particularly interested in Zigbee because I've heard it does some...
1
8233
isladogs
by: isladogs | last post by:
The next Access Europe User Group meeting will be on Wednesday 1 May 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM). In this session, we are pleased to welcome a new presenter, Adolph Dupré who will be discussing some powerful techniques for using class modules. He will explain when you may want to use classes instead of User Defined Types (UDT). For example, to manage the data in unbound forms. Adolph will...
0
7395
by: conductexam | last post by:
I have .net C# application in which I am extracting data from word file and save it in database particularly. To store word all data as it is I am converting the whole word file firstly in HTML and then checking html paragraph one by one. At the time of converting from word file to html my equations which are in the word document file was convert into image. Globals.ThisAddIn.Application.ActiveDocument.Select();...
0
6090
by: TSSRALBI | last post by:
Hello I'm a network technician in training and I need your help. I am currently learning how to create and manage the different types of VPNs and I have a question about LAN-to-LAN VPNs. The last exercise I practiced was to create a LAN-to-LAN VPN between two Pfsense firewalls, by using IPSEC protocols. I succeeded, with both firewalls in the same network. But I'm wondering if it's possible to do the same thing, with 2 Pfsense firewalls...
1
4914
by: 6302768590 | last post by:
Hai team i want code for transfer the data from one system to another through IP address by using C# our system has to for every 5mins then we have to update the data what the data is updated we have to send another system
2
4515
muto222
by: muto222 | last post by:
How can i add a mobile payment intergratation into php mysql website.

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.