So many companies today want someone with Oracle experience. I have none, but it seems to me that it shouldn't be hard to figure out quickly. However, when potential employers ask me if I've worked with Oracle, the line "No, but I'm an expert with Microsoft SQL Server, Borland Interbase, PostgreSQL, and MySQL, and I have no doubt that I would be able to apply my experience to using Oracle's product" doesn't seem to fly. I don't think it would matter to them if I had helped design SQL Server, they want someone who's worked with Oracle. Do they know something about the magical database called "Oracle" that I don't? Or is it just another relational database that they've attached too much importance to?
The biggest problem we had with it was knowing how to effectively use and tune it. The SQL was the easy part. Quite honestly, running MSSQL server was a joke to run compared to that. I'm not saying Oracle is bad. There's a lot to it, and I would definately not take the opinion that you can get up to speed in an afternoon with it.
I'm in the middle of a job search now, and I have experienced the same problem. From an application developer perspective, the underlying database is largely irrelevant; the differences can be learned/looked up rather quickly. I've had similar experiences with J2EE app servers (e.g. "must be expert in Websphere". Really?)
My conclusions have been that either the HR/Recruiter is clueless, or the management is clueless. Stuff like the database should be clearly in the "nice to have" or "software we use" category of a job description (I'm assuming here the job is not for an Oracle administrator, but for a software engineer or similar)
Developers are lucky enough to have our pick of jobs right now, so if you can't even get an interview with your very reasonable explanation, it's probably not a place you want to work anyway.
Well, you usually don't hire a DBA, or a senior database programmer, just to write ANSI SQL. The hard parts, and the valuable skills, are in installation, maintenance, backups and restores, reporting, complex PL-SQL programming, and probably most important, tuning. All of those things are totally specific to the database vendor, and very little of your existing knowledge transfers over. That's why it matters.
I don't have experience with Oracle so I can't answer your question directly. However I can say that I have run into the same type of problem many times in my own field. It seems to be a failure of recruiters who are not technical and don't have or don't want to talk things over with a technical manager on the hiring side. Instead they rely on their narrow set of requirements and if you don't match, then you're out.
However in the case of Oracle you could download the Free Oracle Express Version and work your way through various exercises. After doing so you should be able say you have some Oracle experience.
Oracle has always had a higher service ceiling, but it generally comes at the price of being harder to set up and administer, so if the company is using Oracle it's quite understandable that they would desire or require experience with it.
That said, most of the times I've encountered Oracle databases in the wild, it's been a case of howitzer-vs.-mouse. On my current project, we have a top-shelf server devoted entirely to an Oracle database with two tables with a few hundred records each.
Once you get through the configuration hassles, though (and it's wonderful to have an actual Oracle DBA do this for you), working with Oracle is barely distinguishable from any other database, so I would expect a company that already has good Oracle DBAs on hand to be more willing to hire people without specific Oracle experience.
Under the hood Oracle is extremely different from MS SQL and personally i'm an Oracle fan. I find it scales better, is quicker, has better support and has more functionality.
However it seems harder to understand, harder to setup and harder to perform day to day functions. Although it's not actually harder, it has a proper learning curve and is less forgiving. So experience is more valuable.
I find a trend that an Oracle DBA quickly learns how to use MS SQL and it's guis. Stick an MS SQL DBA on an Oracle database and there just lost. If only for a time. However I started out on Oracle so i'm obviously bious. I used to often think to myself 'if i was working on oracle i'd just do X' and no doubt vice versa.
I'm an Oracle fan even after working on MS SQL for 4 years now.
Oracle also has a different locking architecture than most other databases. A programmer will easily be able to write crud statements that accomplish a task in oracle if they are only familiar with another database. However, they won't know how to most effectively take advantage of Oracle's unique architecture to improve performance. See Tom Kyte's Expert Oracle Database Architecture for a full explanation of this.
If you are using Oracle, you probably need oracle DBA to set it up and maintain it. If you are programmer using SQL, it is pretty similar to other DBs.
If you are to use PL/SQL, well, it's pretty unique and you can do a lot of strange stuff. For example, I saw code serving web pages using PL/SQL... Just PL/SQL, with writing out < html> and < body> tags and everything :)
I have written a few small-scale apps with different databases:
- Oracle - requires somebody to do some maintainance every month or so (note, we don't have a competent oracle DBA, developers are not DBAs)
- SQL Server - setup few years ago, nobody even touched that machine in a year or so (no DBA needed)
- MySQL - no maintainance in a year after DB was setup. (no dba...)
So, yes, I see the reason why company would want somebody with Oracle experience...
Is .Net all that different from Java?
If you ask this question to either a hard-core .Net or a Java developer you'll get very scornful looks. Yet, a DBA, or a computer scientist may see the two as almost identical... It all depends how deep you're scratching beneath the surface.
It is more expensive!
There are many worse career moves than being an Oracle expert, IMHO. In a way, it doesn't matter if Oracle is better...the market is the market.