User not logged in - login - register
Home Calendar Books School Tool Photo Gallery Message Boards Users Statistics Advertise Site Info
go to bottom | |
 Message Boards » » Breaking out views in a SQL Server query Page [1]  
FroshKiller
All American
51913 Posts
user info
edit post

This may be a basic question, but I'm not sure how to phrase it, and I'm having trouble finding help as a result.

I have a relatively simple query for SQL Server that makes use of a view, and that view itself is built on other views. Rather than having to inspect each view definition and work backwards to implement the query without the view, is there any way to sort of "decompile" the query, like maybe some tool that can piece the query back together from the query plan?

9/17/2014 2:45:34 PM

Noen
All American
31346 Posts
user info
edit post

If you run the query in SQL Management Studio, you can use the execution plan that should give you the "decompiled" query visually.

http://msdn.microsoft.com/en-us/library/ms191194.aspx

Outside SMS, http://stackoverflow.com/questions/7359702/how-do-i-obtain-a-query-execution-plan seems like a pretty good reference for your options.

But actually reconstructing a sql query from the plan is going to be manual from everything I can tell. Maybe if you used the SHOWPLAN_XML OFF flag, it'll spit out a parseable SQL query, but I doubt it.

9/17/2014 7:57:05 PM

neodata686
All American
11577 Posts
user info
edit post

Explain that shit.

9/17/2014 8:07:38 PM

FroshKiller
All American
51913 Posts
user info
edit post

Noen: Yeah, I'm familiar with query plans, but I'm wanting something that will bridge the gap and "recompile" the query plan for me sans views.

neodata686: I'll give you a trivial example.

Suppose I have a table called friends with columns for my friends' names and how much I think they're willing to spend on birthday presents for me.

Suppose I also have a table called gifts with columns for descriptions of gifts, their prices, and how badly on a five-point scale that I want them.

In order to raise the quality of the gifts I receive, I want gently suggest gift ideas to my cheapskate friends in a way that minimizes their expenditures and maximizes my satisfaction. To help me with this, I create a couple of views: good_cheap_gifts and cheapskate_friends.

create view good_cheap_gifts as
select description, price from gifts where want > 2 and price < 10.00

create view cheapskate_friends as
select name, budget from friends where budget < 20.00


With my business logic abstracted out (writing WHERE clauses is hard!), I can now very easily join my views together to get a list of good gift ideas to suggest to my skinflint friends. And I can take that a step further by creating a new view to encapsulate that:

create view cheap_gifts_from_cheap_people as
select f.name, g.description from cheapskate_friends f join good_cheap_gifts g on g.price <= f.budget


What I want to do is take this query:

select * from cheap_gifts_from_cheap_people


And get the query itself (not the record set) parsed out for me like this:

select f.name, g.description from friends f join gifts g on g.price <= f.budget where f.budget < 20.00 and g.price < 10.00 and g.want > 2


Extremely trivial example.

[Edited on September 18, 2014 at 8:16 AM. Reason : equality]

9/18/2014 8:15:42 AM

BigMan157
no u
103354 Posts
user info
edit post

if you find something that does, it post it

9/18/2014 8:47:42 AM

neodata686
All American
11577 Posts
user info
edit post

Quote :
"neodata686: I'll give you a trivial example."


Sorry it was a joke. 'Explain' is the command you run to see a query plan in SQL. So I wasn't actually saying explain it in the sense you thought.

9/18/2014 9:29:45 AM

FroshKiller
All American
51913 Posts
user info
edit post

Oh. Well, as you can see, I'm not talking about getting the query plan. I bascially want a query with an equivalent query plan that doesn't use the views.

9/18/2014 9:46:32 AM

neodata686
All American
11577 Posts
user info
edit post

Yeah I just thought it was funny. I haven't used SQL Server in a while nor do I use a lot of views in Postgres.

9/18/2014 10:01:32 AM

DoubleDown
All American
9382 Posts
user info
edit post

My DBA pretty much forbids us from creating views

9/18/2014 12:20:24 PM

FroshKiller
All American
51913 Posts
user info
edit post

Yeah, well, this guy's DBA should've done.

9/18/2014 12:54:39 PM

skywalkr
All American
6788 Posts
user info
edit post

I don't have access to the tool anymore but I think you can do what you are after in Rapid SQL. When I was using it I wanted to know what tables a view was using and the where criteria. I selected the view and was able to see the code behind it. I think that is what you are looking for at least.

9/19/2014 4:06:39 PM

FroshKiller
All American
51913 Posts
user info
edit post

No, it isn't. I don't have any trouble getting a view's definition. What I want is to replace a view currently in use with a query with the equivalent query logic based on the view's definition.

Maybe this analogy will make it more clear: I want to inline a function from a linked library.

9/19/2014 11:25:23 PM

DoubleDown
All American
9382 Posts
user info
edit post

You don't communicate very well for an English major

BTW, congrats for being the first person to ever type that phrase

[link]https://www.google.com/search?q="inline+a+function+from+a+linked+library"[/link]

9/20/2014 12:52:00 AM

FroshKiller
All American
51913 Posts
user info
edit post

Yeah, that's what it is. I don't communicate well.

9/20/2014 2:12:19 AM

synapse
play so hard
60940 Posts
user info
edit post

How many views are we talking here?

Can't you just look at all the view definitions and construct a single query out of them or are there 100 views or something?

9/20/2014 10:27:38 AM

FroshKiller
All American
51913 Posts
user info
edit post

I don't know, there are at least eight. I can certainly do it manually--I just don't want to. There may as well be a hundred. It wouldn't matter.

9/20/2014 12:00:02 PM

 Message Boards » Tech Talk » Breaking out views in a SQL Server query Page [1]  
go to top | |
Admin Options : move topic | lock topic

© 2024 by The Wolf Web - All Rights Reserved.
The material located at this site is not endorsed, sponsored or provided by or on behalf of North Carolina State University.
Powered by CrazyWeb v2.39 - our disclaimer.