- Feature Articles
- CodeSOD
-
Error'd
- Most Recent Articles
- Office Politics
- Secret Horror
- Not Impossible
- Monkeys
- Killing Time
- Hypersensitive
- Infallabella
- Doubled Daniel
- 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
Why is it that the most ignorant are the most recalcitrant? And why can't the idiot be overruled from on-high? Surely a trivial benchmark would make it clear who is right?
Admin
Facts do not displace the idiot's ideas. Trivial benchmarks can't be done, because (a) the indices are mandatory and they cannot at any point in time, in any environment, be removed and (b) benchmarks are a waste of everyone's time because the idiot's ideas are always right. Finally (c) the idiot is always right. And he has better people skills than those with knowledge.
Admin
this remember me a guy i stumbled upon who designs databases only with nvarchar(max) column
Admin
It's called Dunning-Kruger.
Admin
"Dunning-Kruger" - soon to be known as "Trump syndrome" in the US.
Admin
People who are too stupid to understand the implications of the Dunning-Kruger effect know everything.
Admin
To: (Entire Company) From: (The Team) Subject: fwd: unauthorized database changes
Bob is to die. Evidence below:
Admin
Classic Expert Beginner in action from what I can see. Bob, from what I can tell, believes himself to be capable and knowledgeable, and goes out of his way to prevent people from proving him wrong. The only way that could end is if either the company goes bankrupt and he finds himself unable to hold down a job because he insists on sticking with his "standards," or he admits to himself that he doesn't know as much as he thinks he does and steps down/tries to learn something new. Guess which one is more likely.
Admin
what communication breakdown ... and then they will have audit for data access and won't have anything to show ... bad if they have audit trace in their contract ... bob must be fired.
Admin
"The table was populated by a trigger and it appeared that every single possible user action was logged here."
Why didn't they disable the triggers as a first port of call rather than just truncating the table regularly?
Admin
By that point, they weren't allowed to drop the trigger.
Admin
"i locked the schema in source control so no one but me can edit it." Removing the Trigger is a DML (i.e. Schema) command. Truncating is a Data Update command, presumably allowed for everybody (or how could the Application run).
And does anyone know what PHB in BOB.the.PHB stands for? Pathetic, Habitual, Boob?
Admin
Crap. I got it backwards, dyslexia,
DML is Data Manipulation Language, I meant to say DDL, Data Definition Language
Admin
Well, this, most likely: https://en.wikipedia.org/wiki/Pointy-haired_Boss
Admin
Ah the classic "we're so paranoid we need to log every single possible change" syndrome. Seems every company has some variation of that...
Admin
I've had a similar experience where the 'Head of Development' insisted that we had to use a flexible database structure that stored basically all data as key-value pairs, including data used for joins between tables. I put my foot down saying that the performance would be unacceptable, got backed up by a colleague, and as a result managed to get a higher-up manager to insist on a proof of concept. After the proof of concept the idea was never heard of again. For sparsely populated data that kind of structure can be worthwhile, but far too many management-level developers seem to make these kinds of elementary mistakes. They don't want to change, but it's not necessarily because they only ever believe they're right. they may also be insecure about their own position and unwilling to allow someone lower on the ladder to demonstrate superior knowledge, because that raises questions about whether they should be the senior staff member there.
Admin
He only locked the schema in source control so that only he can change it for future deployment.
He hasn't locked the schema on the customer's copy of the database. So the customer is free to remove the triggers.
Admin
PHB is a reference to the incompetent Pointy Haired Boss from Dilbert
Admin
@David Key-value pairs.... [shudder]. The tell-tale sign of a dedicated WTFerer being let loose on a database. Not that it's entirely their fault: they've probably drunk the industry-wide Woo Kool-Aid that says "You don't need to understand databases any more! NoSQL, LINQ...". I don't wander about sticking my oar in to write dreadful webpage/C++ code (because I don't know enough to do it well), so why do these bozos think they can get a database right? In this place, the key-value pair idiocy made it into production, and has 10 millions rows of crap. With no indexes at all. I'm leaving tomorrow.
Admin
Key-value is amazing if you have a database designed around it and an actual business case for it. Pretty damn useless otherwise.
I suppose it can be handy if you're too lazy to figure out any of the relationships your data has until you get to the code, but in that case, any database design is going to suck.
Admin
Honestly, just f*** people like Bob!
Admin
I can never work with people this stupid I either leave or fight with them until someone is fired. Usually it's them. Actually it's never been me but if it were then it would probably be for the best.
Admin
Multiple WTFs here. WTF1: Management allowing their coders (yes coders) to write crappy code that the performance guys then have to fix??? Obviously that has been an ongoing problem, so why not embed the performance guys with the regular developers? Some training might not be a bad idea either. WTF2: Henry not showing performance numbers before & after the mods to management/client? I would have expected an email along the lines of: From: Henry To : Bob CC: BIG BOSS Subject: RE> unauthorized database changes
You are the one who doesn't know what he is talking about. Attached are the performance reports before and after the mods.
WTF3: The "lead developer" Colin not overriding Bob. It's his job to handle this kind of situations. He should have told Bob to back off.
Admin
A subtle WTF is still using VARCHAR when you've transitioned from MySQL to a real database, like PostgreSQL. The proper solution is TEXT for that column, as that will literally speed things up, since the DB won't have to keep testing how long the stored value is, so that it can throw an error on overflow. Something MySQL rarely does, ironically.
Admin
It's known as the Entity Attribute Value anti pattern, at least if applied across any significant part of a database.
https://en.wikipedia.org/wiki/Entity%E2%80%93attribute%E2%80%93value_model
An example of a case it works for is if you are doing something like adding optional fields to a table dynamically e.g. selling cars, but without knowing what properties of the car you might wish to set up at design time, so you allow extra fields on top of the core fields, so salesmen or whoever can add spoiler angle or whatever ridiculous fields they dream up as a property to be reported on. The reporting is a little tricky of course, but feasible.
Admin
Who says he's incompetent? Dilbert's PHB never gets fired, does nothing all day except hold meetings and write up performance reviews, and he gets paid a ton. Sounds like a great plan....
Admin
Dunning-Kruger
Admin
I think you missed the part where Bob is the manager. He himself decided he would do databases. So...
Admin
Some people are saying Dunning-Kruger, which is true, but it's also survivor bias: people willing to learn eventually stop being ignorant
Admin
Indices do improve performance. Unfortunately, they only improve query performance, which is pretty useless on a write-only table.
Admin
I think part of this is made up, but I recognize the basic parts of it. My favorite was the index on a single character field that was varchar(1) and only had the value Y in it. A truly useless index, but insignificant so we did not fix it.
The mismatch in data type for the joins was a significant performance problem, was essentially a typo, and was easily fixed through an alter command, although the process took a month or more.
Admin
That Make America Grate Again guy?
Admin
ALTER TABLE Audit_Table ENGINE=BLACKHOLE;
Problem solved :)
Admin
The "audit everything" is usually a sign of major troubles, but occasionally not. When it is needed, there are plenty of implementations (almost all of them asynchronous, yet still robust) that can handle many terabytes [petabytes database are becoming more common every day] without significant performance issues...
Admin
needless to say (which is why it wasn't mentioned), colin was fired by bob for being a boob. bob then got a promotion, and colin couldn't get another job.
Admin
@SirTwist: Indexes don't always improve overall performance, since the database has to do extra work to keep them up to date. They don't even always improve query performance - I couldn't tell you how many times I've had to nudge the database towards a different query plan because it wanted to use an index that actually made things worse. In fact, the last time I did that was this morning.
This is not as much of a problem as it used to be now that histograms are in common use, but even then it's possible for the optimiser to make a bad choice. Or, as in my case, the main database I pull data from doesn't have histograms collected because doing so somehow stuffs up performance for the front-end application. We can't modify the queries the front-end application submits but I can modify the queries I use (for loading the BI warehouse and various other systems), so I get to deal with the consequences.
Admin
Bad idea. You don't want them breeding.
Admin
YMMD :D But did they switch back to MySQL after trying PostgreSQL?
Admin
(spam)
Admin
Everyone knows that if you don't know all the extra properties at design time, you add fields like: UserF1 varchar2(256), UserF2 varchar2(256), ... UserF99 varchar2(256)
That way you can avoid the dreaded EAV anti-pattern.
Admin
Can somebody ban this troll?
Admin
U MAD FUCCBOI?!
Admin
Oh look, matrix code spew all over the comments section. It at least took the edge off of a hilariously arrogant fool who reminds me of a person I know whom thinks you can port a 32 bit application into 64 bit just by hitting the 64 bit checkbox in whatever the fuck compiler he used and have zero issues.
Admin
Stop horsing around
Admin
@Scarlet_Manuka, I'm guessing your using SQL Server. If so you might consider restoring the database to a different box, updating the stats there, and then you can export the stats objects back to the original server. Not only will your stats be kept relatively up to date, but you'll also be testing your restores. We do it here as we unfortunately have 10TB+ tables that not partitioned.....
Admin
@Scarlet_Manuka, I'm guessing your using SQL Server. If so you might consider restoring the database to a different box, updating the stats there, and then you can export the stats objects back to the original server. Not only will your stats be kept relatively up to date, but you'll also be testing your restores. We do it here as we unfortunately have 10TB+ tables that not partitioned.....
Admin
Oh hey, a perfect time to use my new ISO basic Latin bookmarklet...
Well that was kinda disappointing...
Admin
Oh, now I see... it's hieroglyphics, which don't translate well into ISO basic Latin. A slight modification to just remove the Zalgo, and now...
Google Translate says: "I'm in terrible software practices, a great hero chosen to save the world and you if you are not in my way, you will be just like any other bad programming I found and you will want to check your bug. I am the world from a terrible software practices If you choose to do a great hero and you are not of my old way you will be just like any other program I've found a bad and you check your bug [...]"
Admin
"Why is it that the most ignorant are the most recalcitrant?"
The Dunning-Kruger Effect. - The inability of those of low ability to recognize their ineptitude and evaluate their ability accurately.
A variation on the theme: The skill set required to fix a problem is the same as needed to recognize that a problem exists in the first place.
Admin
I have that to deal with at my current project. All the tables also keep some auditing data on top of that. Really fun, especially when the one who created it is also in charge and thinks it is the best thing since sliced bread.