Updating In-Memory (Temporary) SQL Tables With UPDATE / DELETE Clauses

Posted May 30, 2007 at 2:38 PM by Ben Nadel

Tags: SQL

This never occurred to me to try, but today, trying to solve a problem, I ran a SQL statement that attempted to use the UPDATE clause on an in-memory table. Much to my surprise (and delight), this worked! I had no idea that you could do this. To test it even further, I ran a DELETE clause as well. Worked like a charm!

Here is a demo of this in action:

  • <cfquery name="qID" datasource="#REQUEST.DSN.Source#">
  • DECLARE
  • @id TABLE (
  • id1 INT,
  • id2 INT
  • )
  • ;
  •  
  •  
  • <!---
  • Populate the in-memory table variable with the
  • pivot data. We are going to store the same ID
  • into both columns so that we can demonstrate
  • that it was updated.
  • --->
  • INSERT INTO @id
  • (
  • id1,
  • id2
  • )(
  • SELECT TOP 5
  • p.id AS id1,
  • p.id AS id2
  • FROM
  • pivot100 p
  • );
  •  
  •  
  • <!--- Update the in-memory query. --->
  • UPDATE
  • @id
  • SET
  • id2 = (id2 + 5)
  • ;
  •  
  •  
  • <!--- Delete from the in-memory query. --->
  • DELETE FROM
  • @id
  • WHERE
  • id1 >= 4
  • ;
  •  
  •  
  • <!--- Select all values from the in-memory table. --->
  • SELECT
  • *
  • FROM
  • @id
  • </cfquery>
  •  
  •  
  • <!--- Dump out the query with both ID columns. --->
  • <cfdump
  • var="#qID#"
  • label="ID Query"
  • />

CFDumping out the returned ColdFusion query object, we get:


 
 
 

 
Updating In-Memory SQL Tables  
 
 
 

Notice that the UPDATE added 5 to the id2 column and that the DELETE deleted the last two records. I can't believe I am only learning this now!



Reader Comments

May 30, 2007 at 2:58 PM // reply »
79 Comments

Trying to do it in a Query of Query is not so simple though! (but doable)


May 30, 2007 at 4:10 PM // reply »
11,314 Comments

Very true! If ColdFusion could come up with a way to support UPDATE and DELETE in query of queries... I don't know what I would do, but it would be nuts!


May 30, 2007 at 5:15 PM // reply »
22 Comments

Ben -

Thanks for posting this. I always enjoy reading your blog since I always learn something.

I've never thought about using in-memory sql tables. What would be some good reasons to use them?


May 30, 2007 at 5:28 PM // reply »
11,314 Comments

In-memory tables are great for when you need to do some sort of intermediary data filtering before your primary query. For instance, you might create a table variable that holds just a column of "valid" IDs for a table. Then you could join that to another table:

SELECT
u.id
FROM
user u
INNER JOIN
@valid_user vu
ON
u.id = vu.id

Assuming that @valid_user is a table object that has only valid IDs, this INNER JOIN would force only users with IDs in that valid_user table to be returned.

Not the best example, but I promise in-memory tables are awesome :)


May 31, 2007 at 9:24 AM // reply »
6 Comments

Ben,

Thank you for this. I have never used temp tables before because I usually did most database work through datasets. This could be very useful.

One question. is this supported with this syntax in both MSSQL and mySQL?

Thanks for this and your articles on CSV Parsing in particular. They have been very helpful with a project I am doing at home during the time I should be sleeping.

Regards,

Michael


May 31, 2007 at 9:29 AM // reply »
11,314 Comments

@Michael,

Glad to help. I am not sure about mySQL as I work in MS SQL Server 99% of the time. I assume that this stuff is mostly standard, but I that is just a guess. I know mySQL had a lot of "annoying" features in earlier versions that have been cleaned up in the latest release (or so I have been told) so hopefully this should work in the newest version.


Jun 1, 2007 at 6:07 PM // reply »
6 Comments

It's probably worth noting that table variables (@temp) in MS SQL are stored in RAM, as opposed to regular temp tables (#temp) are stored in the tempdb and require disk I/O. I use table variables when handling under 3000 records or so. Any larger and SQL Server will automatically start swapping data in the table to disk and the performance benifit is lost. Also I believe you can place indexes on a temp table, but not a table variable.

Another random fact. SQL Server 2005 will let you insert into a table variable with the output of a stored proc:

INSERT INTO @tmp
(col_1,
col_2)
EXEC ps_return_records

In SQL server 2000 you could only do this with temp tables.


Post A Comment

Comment Etiquette: Please do not post spam. Please keep the comments on-topic. Please do not post unrelated questions or large chunks of code. And, above all, please be nice to each other - we're trying to have a good conversation here.

Please review the following issues:

Author Name:


Author Email:

Author Website:

Comment:

Supported HTML tags for formatting: <strong>bold</strong>   <em>italic</em>   <code>code</code>







  • Help Wanted - Find Your Next ColdFusion Job
Ben Nadel's Company - Epicenter Consulting Recent Blog Comments
Jun 18, 2013 at 9:20 PM
Mapping AngularJS Routes Onto URL Parameters And Client-Side Events
I couldn't find examples of passing multiple arguments using the when() routing statement so figured out through trial and error that you can pass multiple arguments using the following format: .whe ... read »
Jun 18, 2013 at 3:39 PM
Experimenting With The Amazon Simple Storage Service (S3) API Using ColdFusion
Hi Ben, THANKS! While not bleeding edge, it is new to me & I like learning new things every day! ... read »
Jun 18, 2013 at 12:30 PM
Disabling Auto-Correct And Auto-Capitalize Features On iPhone Inputs
Also spellcheck="false" should be mentioned as part of html5 specs ... read »
Jun 18, 2013 at 8:40 AM
Using Named Functions Within Self-Executing Function Blocks In Javascript
Hi Ben, you forgot to mention the most important thing for named self-executing functions - they can be referenced by name ONLY inside their execution context (which is parens in this case), it mean ... read »
dee
Jun 18, 2013 at 7:01 AM
My Safari Browser SQLite Database Hello World Example
hai ben, this program is really good i could understand the concept but i dint know how to save it and how to open it as you have done in the video can u give that details pls ... read »
Jun 18, 2013 at 6:04 AM
Clearing Inline CSS Properties With jQuery
Thanks a lot for for post! It helped me a lot... after being stuck since 24 hrs.. found solution from your post. Thanks again! ... read »
Jun 18, 2013 at 2:31 AM
SOTR 2013 - The Best Conference I Never Went To
I keep watching it, should keep me happily distracted until SotR14 ;) ... read »
Jun 17, 2013 at 9:45 PM
What If All User Interface (UI) Data Came In Reports?
@Jonah, As I was reading what you wrote, it occurred to me that maybe I do something similar to that in some of my client-side code. In an application I'm working on, there are a bunch of unrelated ... read »
InVision App - Prototyping Made Beautiful With Prototyping Tools