- Feature Articles
- CodeSOD
-
Error'd
- Most Recent Articles
- Secret Horror
- Not Impossible
- Monkeys
- Killing Time
- Hypersensitive
- Infallabella
- Doubled Daniel
- It Figures
- Forums
-
Other Articles
- Random Article
- Other Series
- Alex's Soapbox
- Announcements
- Best of…
- Best of Email
- Best of the Sidebar
- Bring Your Own Code
- Coded Smorgasbord
- Mandatory Fun Day
- Off Topic
- Representative Line
- News Roundup
- Editor's Soapbox
- Software on the Rocks
- Souvenir Potpourri
- Sponsor Post
- Tales from the Interview
- The Daily WTF: Live
- Virtudyne
Admin
Wow...1600 words a minute!
Admin
That's huge.
Admin
My eyes are bleeding.
CAPTCHA: conventio (which is what this line of code defies)
Admin
Added for "clarity" you say? There is no clarity for something like that.
Admin
I noticed that 'RECIEVE' is spelled wrong...I wonder if it even worked.
Admin
This is actually quite efficient. It describes the system in only 1,240 words. But I think I can clean it up a bit more, condensing it to one word:
Augh!
Admin
Now that's TRWTF.
How are systems like that able to work at all? Looks very enterprisey though...
Admin
And yet, there are "senior developers" out there who swear by doing things like this, or by setting the CommandText property of a SqlCommand, and wonder what's all the hullabaloo about these fancy "ORM" things, and why did Microsoft bother to add in Linq to SQL or Entity Framework at all.
Admin
But imagine how easy this is to deploy! Just update one line in a config file and you're good to go!
Admin
If you can pull everything you need in a single, guaranteed-consistent FETCH from the database, especially if its done a whole lot, that's not necessarily a WTF.
Sure, there's a lot of legacy-isms in there, but you might be looking at something that cut a two minute process with a ton of stupid SQL calls into a sub-second 250 line one.
Although the homegrown reverse polish in the resulting column names is unfortunate - and the massive REPLACE nest is probably optimizable at least.
Admin
If you had something that ugly in your codebase, wouldn't you hide it in a config file too?
Admin
I think it's better to go ahead and refactor as you go, making the code self-documenting, than to try documenting nasty code. You shouldn't use it prior to refactoring because programming against a well-documented mess is less productive than refactoring the mess to something clean and then programming against it. Simple, clean interfaces / contracts are more important than documentation, imo.
Admin
Disclaimer: we use ORM all over the place where it doesn't matter (GUIs, etc). We also generate massively-joined reporting queries and have a few hand-written 80LOC queries where it does (although nothing quite on this scale).
Admin
Shirley this is not possible. You can't put CDATA in an XML attribute, can you?
However, seeing as this is a .config file, one would reckon that this was an auto-generated file in a proprietary format that places the value of the DB query in an ultimately-generated XML file. Now let's conjecture that regular expressions are not supported... . . . Not a wtf?
Admin
It's called job security Doggs. Actually i dont think it was written by a person. It looks like it is some of that automated code that gets written like in Macromedia.
Admin
Ze goggles! They do nothing!
Admin
You've heard of stored procedures right? Well that is where any chunk of SQL code this long belongs. And while you're in there, you might be able to break it down into a few more logical steps, maybe use a temp table or a union.
This code has no place in a config file.
Admin
My favorite part:
I 'd like to think that this replaces all smilies into frowns into tears.
Admin
Ah, but having that SQL in a Sproc prevents the end user from changing a field, and the CEO must be able to customize the queries if he sees fit, at any time.
Admin
In a config file?! Good grief. This is what the Windows Registry is there for people!
Admin
And don't call me Surely.
Admin
Besides the replace madness, what's the problem?
Placing an SQL query in a config file? Maybe not the 'INDUSTRY STANDARD' (ohh beware the industry standard!), but not a wtf.
The length of the query? Has nobody else had to write a complex query that included multiple tables?
Maybe I'm not looking closely enough at the code.
Admin
Correct me if I'm wrong but wouldn't the proper way of writing "a complex query that included multiple tables" be to abstract things out into Views or Functions? The method shown is little more than spaghetti code.
Admin
Does this even work? It appears to be an SQL query but it has C-style comments inside it!
Admin
As we say in MMOs: "wat"
C-style comments work perfectly fine within SQL. I really hope this comment was a joke.
Admin
No. The best way to deal with this is to go work somewhere else.
Admin
If this was all in one line, it sure is some nice example of the code obfuscation. :D
Admin
I honestly didn't know C-style comments worked in SQL. Learned something new today.
Admin
I can understand the need for a single huge complex multi-table query - legacy crap is a fact of life. As others have pointed out, it might even be more efficient that multiple simple queries (databases are pretty good at optimizing so-so queries; even complex ones). I can even see the need for the nested replaces under certain circumstances (though probably a little hard to justify).
But all that on one long line?
Admin
You're forgiven :)
Admin
Views and functions can't be indexed (at least not views that come from more than one table, which defeats the purpose of views IMO)... At least if it's a join, the query optimizer may be able to make the query a little more effecient than it is written.
The REPLACE functions are WTF, but lets not forget the SQL injection possibility here (check the last WHERE clause).
I've seen stuff like this before, and it's terribly ineffecient. It looks like they're trying to generate massively complex reports (which obviously isn't a bad thing) from an RDB, likely a live application DB. This screams for OLAP or data warehousing... It's funny because this is the result of "business" wanting "up-to-the-second, real-time" reporting (which is never used). Then they cringe when someone generates a report that takes 8 minutes to create, which kills performance across the rest of the application.
Admin
Ouch. That, my friends is A config!
the actual program is probably actually like this:
Excuse my syntax errors, I haven't done .NET in a while
captcha: ideo
Admin
I don't think this guy ever heard of stored procedures or functions in SQL.
Admin
On the plus side, they aren't finishing the whole thing off with a GROUP BY. I've had to work with queries that have a hundred elaborate SELECT columns with most of them reappearing in their entirety in the GROUP BY clause.
I would say that Aaron should be thankful, but something tells me such a query probably lurks elsewhere in his codebase or config files.
Admin
Admin
Don't be so surly.
Admin
Who hasn't done something like this?
Admin
Or maybe he had heard of stored procedures, but he just didn't know where they get stored and so opted for a config file.
Admin
:`-(
Admin
It would be easy to prevent code like that. Pay programmers by the line.
Of course, that has other problems.
Admin
Well, I guess that's one way to store a procedure...
Admin
Of course this means that views generally don't need indexes, because the underlying (multiple) tables' indexes are at the optimizer's disposal.
Admin
Admin
Omg omg omg omg! It hurts so bad. Make the bad man stop!!!!!
Admin
This is crazy... They are BREAKING UP the string as part of a JOIN... Why bothering having more columns, when we can have all the data in one
Admin
Admin
Okay, Lockwood, show us on the doll where the bad SQL touched you.
Admin
That's what she.. wait, I mean, I've seen worse in a shop near and dear to my heart.
Admin
Actually, SQL doesn't have C-style comments. SQL allows nested multi-line comments. The following would break an ANSI-C compiler, but not SQL:
/* Comment 1: /* comment 2: this is nested. */ This is my main comment. */
Admin
I'm pretty sure if I worked with the author of this monstrocity, I would have shocked him repeatedy with a cattle prod.