INSERT INTO [table] (col) VALUES (@col);
SELECT SCOPE_IDENTITY();
After you create the query, you mark the execute mode as scalar so that you can get the value back out, only to find the next time you modify that table adapter, the query loses its execute mode and reverts back to Non-Query (the default execute mode for Insert queries). All of the sudden your post-insert logic is doing all sorts of baffling things related to the first record in the table, or worse, no record.
It seems that Visual Studio is supposed to mark the query when you modify it so that future updates don't overwrite your customizations, but unless I am absolutely stupid, this never works.
Thwart the behavior by doing something so illogical that it must work.
When using the Add Query wizard on the table adapter
- Select "Use SQL statements", click Next.
- Select the Insert option (if you want to get a base insert statement for your self, copy the query into your clipboard, go previous and change your query type to "SELECT which returns a single value")
- OR -
Select the "SELECT which returns a single value" (if you have your query and don't mind typing it)
and of course, click Next. - Enter your query, click Next.
- Name your query, click Next.
- Oh! the horror. The wizard is throwing a warning message: Failed to get schema for this query. Should we halt, go back, rack our brains for hours trying to determine the best course of action to resolve this tragic error? Of course not. If you are reasonably certain that the query you just pasted or typed into the field is correct, apply your settings and click Finish. You will be rewarded with what should be a table adapter update-proof insert statement that NEVER loses its scalar execution mode. NEVER!
No comments:
Post a Comment