- What I learned going back to UX school
Data driven usability questions: "People throw around sayings like “Easy to Use” or “Intuitive” but without some data those are merely opinions. When it comes to measuring ease of use, there are well established things to track: Success rate: What percent of users can even do the thing its supposed to let them do. Often this is well below 100%. Time on task: how long does it take users to do the thing it supposed to do. Better designs take users less time. Error rates: how many mistakes or confusions does the user have."
(categories: ux usability-testing usability testing data metrics ) - Numbers Every Programmer Should Know By Year
Ran into this a couple weeks ago when onsite with a customer and was seeing 3ms for a "file.exists" type of operation when inside of a VM which was about 100x slower than corresponding VM’s in our own infrastructure.
(categories: architecture performance programming systems speed ) - How To Run a 5 Whys (With Humans, Not Robots)
Quote: "Which is the Root Cause? DB access bug or monitoring failure? Answer: don’t care about "root causes”. They don’t exist (multiple things conspire for failures to happen). Also, kind of moral/blame-ish. Ask instead: if we made an incremental improvement in area A or area B , which would prevent the broadest class of problems going ahead? Much better conversation… Remember, There Is No Axe Murderer (Probably)."
(categories: management process rca root-cause-assessment ) - Custom T-Shirts – Design Your Own T-Shirts Online – Free Shipping!
Great custom t-shirt site.
(categories: t-shirts design )
All posts by ajohnson
Links: 1-4-2013
- Study Hacks » Blog Archive » Knowledge Workers are Bad at Working (and Here’s What to Do About It…)
I like the notion of ‘deep work’, social software seems to discourage this kind of thing.
(categories: focus priorities work productivity )
jTDS, SQL Server, IN and 2000 or more parameters
It’s been a really really long time since I blogged about an obscure problem at work and it’s the new year and all and hey… why not write a blog post once a year?
A couple weeks ago we came across a bug where someone had written some SQL that used the IN keyword (harmless) but then at some point the code that used that SQL encountered a situation where the IN clause contained more than a couple thousand parameters, which resulted in an error message from Oracle:
ORA-01795: maximum number of expressions in a list is 1000
Lots of stuff on the interwebs about that issue, workaround was relatively easy (query was turned into a couple queries, each with less than a thousand parameters). Weird thing was that then a couple weeks later we ran into an issue that had the same symptoms (minus the Oracle error message) but was being executed against SQL Server. There is some documentation available on MSDN that talks about maximum number of parameters per stored procedure and maximum number of parameters for a user defined function (both 2,100 if you care), but I couldn’t / can’t find anything official that talks about a 1,000 parameter limit or even a 2,100 parameter limit for queries using an IN clause… guessing that stored procedure / user defined function are ~= parameters passed via a prepared statement. Anyway, if you write a bunch of code using C# (which I don’t have access to right now) against SQL Server and use more than 2,100 parameters in a SQL statement, then you’ll most likely get an error message that says something like this:
Too many parameters were provided in this RPC request
which you can read more about here. But if you’re using Java and SQL Server, then you’re most likely using the jTDS driver and if you use more than 2,000 parameters as part of a prepared statement while using a version greater than SQL Server 7 or more than 1,000 parameters as part of a prepared statement and are using SQL Server 7, then you’ll get an error message that looks like this:
Caused by: java.sql.SQLException: Prepared or callable statement has more than 2000 parameter markers.
at net.sourceforge.jtds.jdbc.SQLParser.parse(SQLParser.java:1139)
at net.sourceforge.jtds.jdbc.SQLParser.parse(SQLParser.java:156)
at net.sourceforge.jtds.jdbc.JtdsPreparedStatement.(JtdsPreparedStatement.java:104)
at net.sourceforge.jtds.jdbc.ConnectionJDBC2.prepareStatement(ConnectionJDBC2.java:2372)
at net.sourceforge.jtds.jdbc.ConnectionJDBC2.prepareStatement(ConnectionJDBC2.java:2330)
Just for kicks I checked out the source code for jTDS to see where this was actually happening, it’s in net.sourceforge.jtds.jdbc.SQLParser (as the stack trace above shows), code looks like this:
// Impose a reasonable maximum limit on the number of parameters
// unless the connection is sending statements unprepared (i.e. by
// building a plain query) and this is not a procedure call.
//
if (params != null && params.size() > 255 && connection.getPrepareSql() != TdsCore.UNPREPARED && procName != null) {
int limit = 255; // SQL 6.5 and Sybase < 12.50
if (connection.getServerType() == Driver.SYBASE) {
if (connection.getDatabaseMajorVersion() > 12 || connection.getDatabaseMajorVersion() == 12 && connection.getDatabaseMinorVersion() >= 50) {
limit = 2000; // Actually 2048 but allow some head room
}
} else {
if (connection.getDatabaseMajorVersion() == 7) {
limit = 1000; // Actually 1024
} else
if (connection.getDatabaseMajorVersion() > 7) {
limit = 2000; // Actually 2100
}
}
if (params.size() > limit) {
throw new SQLException(Messages.get("error.parsesql.toomanyparams", Integer.toString(limit)), "22025");
}
}
If you’re super odd and have access to a SQL Server instance and want to actually see this in action:
int count = 3000;
String connectionstring = "jdbc:jtds:sqlserver://yourserver:1435/dbname;user=username;password=password;";
Class.forName("net.sourceforge.jtds.jdbc.Driver");
Connection con = DriverManager.getConnection(connectionstring);
List
for (int i=0; i
and grab the setValues and preparePlaceHolders methods from the code pasted in this stackoverflow.com thread. Execute that from a test harness and you'll get the error from jTDS as I pasted above. Not a jTDS issue really, just obscure and different per database server, which sucks when you have to support four different versions (Oracle, Postgres, SQL Server, MySQL) like we do at work.
Bunch of stackoverflow.com threads that talk about how to work around this limitation. Doesn't appear that Postgres has a limit (at least that we've found yet), brief reading I did suggests that MySQL has a limit of 65,000.
Links: 12-16-2012
- Moserware: The First Few Milliseconds of an HTTPS Connection
This is brilliant, love someone diving in this deep.
(categories: https ssl rsa encryption security )
Links: 11-27-2012
- Rands In Repose: Stables and Volatiles
Quote: "Your Stables are there to remind you about reality and to define process whereby large groups of people can be coordinated to actually get work done. Your Stables bring predictability, repeatability, credibility to your execution, and you need to build a world where they can thrive. Your Volatiles are there to remind you that nothing lasts, and that the world is full of Volatiles who consider it their mission in life to replace the inefficient, boring, and uninspired. You can’t actually build them a world because they’ll think you’re up to something Stable, so you need to create a corner of the building where they can disrupt." Yes.
(categories: engineering software entrepreneurship management )
Links: 11-26-2012
- Bezos’s Insistence on Full Narrative Prose
Quote: "One of my favorite Joan Didion quotes is “I don’t know what I think until I try to write it down.” Writing is thinking. A lot of busy people say they wish they had more time to “think” — to be proactively thoughtful rather than reactive. But “thought time” is a hard thing to actually schedule, let alone measure. Writing, on the other hand, is something you can schedule to do and then evaluate and measure the output (e.g. 700 words a day or a blog post a week). When someone tells me they don’t do much writing anymore, I sometimes wonder, When do you think deep-ish thoughts? And how do you ever know how coherent your thoughts actually are?" Super interesting in light of the stuff that I just read about Winston Churchill, who was a prolific writer who, maybe not coincidentally, was also a deep thinker with a lot of focus. Makes you wonder which leads to which.
(categories: focus priorities thinking writing amazon )
Links: 11-9-2012
- Play Offense When Predicting Revenue
Same thing can / should be applied to bigger software releases: instead of asking if the release will go out on time, ask which features are 100% done and bug free and which features need more work.
(categories: sales management engineering software )
Links: 11-7-2012
- American politics: The right Republican | The Economist
Quote: "Nowadays, a candidate must believe not just some but all of the following things: that abortion should be illegal in all cases; that gay marriage must be banned even in states that want it; that the 12m illegal immigrants, even those who have lived in America for decades, must all be sent home; that the 46m people who lack health insurance have only themselves to blame; that global warming is a conspiracy; that any form of gun control is unconstitutional; that any form of tax increase must be vetoed, even if the increase is only the cancelling of an expensive and market-distorting perk; that Israel can do no wrong and the “so-called Palestinians”, to use Mr Gingrich’s term, can do no right; that the Environmental Protection Agency, the Department of Education and others whose names you do not have to remember should be abolished."
(categories: via:tim-bray politics government republicans )
Links: 10-29-2012
- On Being A Senior Engineer
An awesome list of attributes for real "senior" engineers.
(categories: career hr culture engineering management )
Links: 10-20-2012
- Alexey Ragozin: Understanding GC pauses in JVM, HotSpot’s minor GC.
Deep look at how GC works in the JVM.
(categories: java jvm gc garbagecollection ) - Alexey Ragozin: Understanding GC pauses in JVM, HotSpot’s CMS collector.
Similar to the previous bookmark..
(categories: jvm java gc garbagecollection cms ) - My Ultimate Developer and Power Users Tool List for Mac OS X (2012 Edition) — carpeaqua by Justin Williams
Nice list of apps if you’re on OSX.
(categories: apple apps development osx tools ) - WebPerfDays: Performance Tools | High Performance Web Sites
GREAT list of performance tools for http / JS / css work.
(categories: performance javascript css profiling speed tools )