Skip to main content

Getting started with PL/SQL (and SQL (and Oracle Database))

Got this email Monday from a fellow new to PL/SQL and Oracle:
I have been in I.T. for a couple of years but always had this feeling that I could do better. I lost that hunger when the company I had worked for 10 years plucked me from the warehouse as a kind of internal promotion program. I guess you could say I slowly settled into a rut.  
I discovered your site recently and I am in the process of reviewing your tutorial videos (I have also started to read newer technical books). I am sure you have been told before but your tutorial videos are great!  
My problem is that I think the lessons would "stick" with me more if I had the chance to work with them and "play" around. 
I have very low self esteem (which I am also working on) so please don't laugh but is there a place that I can download a condensed or tutorial version of Oracle 11g?
First, I am always excited to hear from people who are just getting into Oracle Database, SQL and PL/SQL. Our part of the technology stack is "way down there" and often gets less attention these days. So my first response is always:

Welcome to my world! And it is a rather big, rich and supportive world. There are tens of thousands of experts in Oracle Database, all around the world, many of them eager to help and share their knowledge.

So many websites to visit and learn from, including:

PL/SQL Home Page - a great starting point for resources on PL/SQL

SQL Home Page - a great starting point for resources on SQL

Ask Tom - answers from a few of the biggest Oracle Database brains in the world

Oracle Technology Network, especially the forums - Oracle's own hosted community ecosystem

Oracle Dev Gym - classes, workouts and quizzes on SQL, PL/SQL, Database Design and more!

Databases for Developers - a lightweight, 12-week "bootcamp" introduction to databases and SQL for application developers.

But Robert, who wrote the above message, wasn't just looking for sources of information. He wants to be able to play around with the technology - hands-on. Good idea, Robert! Reading, watching, etc. can never replace what you learn by actually writing some code.

These days, Oracle makes it really, REALLY easy to play around with SQL and PL/SQL. Just go to LiveSQL and get started!


LiveSQL offers several pre-defined schemas with data (and more to come soon!), tutorials and lots of scripts contributed by experts around the world.

If you want a more full-blown interaction with Oracle Database, well, hey, you can download a VM of Oracle Database 12c Release 1, with a whole bunch of tools, all for free!

Comments

  1. Thanks to Steven 'hardcoding' is a four letter word.
    If you're already in the company and learning PL/SQL that's fantastic. I learned so much faster actually meeting a challenge then I ever did reading books. The challenge now is using that knowledge. I've been using PL/SQL for almost 2 years and all the job postings local to me want senior level developers.

    ReplyDelete
  2. Steven,

    One other incredibly useful resource you might mention is Oracle Express Edition.
    The main areas of difference between this and the VM images you mention are the fact that it's 11g (which is the version your correspondent expressed an interest in) and that it requires much less in the way of system resources to run.
    You can run Oracle XE on a machine with as little as 1GB RAM ( as I know from experience), as opposed to a Virtual Box Image, which seems to need at least 4GB ( including a minimum of 2GB for the guest).

    Express Edition may not be shiny and new, but it is a fantastic resource :-)

    Mike

    ReplyDelete
  3. Interesting what @anonymous said about job postings ...
    I can hardly see any Oracle jobs posted these days ...
    let alone positions for senior developers,
    except maybe for Oracle DBA-s, even those very rarely.
    Instead, there are a lot of SQL Server jobs, maybe this points to a kind of "trend" happening silently in the background ?

    Learning is valuable in any way, there are people who learn better by reading books, web sites, papers, while others prefer the direct challenge.
    I personally believe in both, with the first one however, preceding the second one.

    The LiveSQL is a very nice gift made by Oracle to the user community,
    though, it has (or maybe still has) a lot of limitations.
    Mainly, it can only access a very limited number of the DBMS packages.
    Also, it does not allow actions that require higher privileges, maybe kind of justifiable.
    Technically, however, I think that they should manage sessions in a different way, aka, allowing full control of the user upon transactions, instead of performing an automatic COMMIT after each page submission.
    I hope that it will still be enhanced further.

    Cheers,
    Iudith

    ReplyDelete

Post a Comment

Popular posts from this blog

Quick Guide to User-Defined Types in Oracle PL/SQL

A Twitter follower recently asked for more information on user-defined types in the PL/SQL language, and I figured the best way to answer is to offer up this blog post. PL/SQL is a strongly-typed language . Before you can work with a variable or constant, it must be declared with a type (yes, PL/SQL also supports lots of implicit conversions from one type to another, but still, everything must be declared with a type). PL/SQL offers a wide array of pre-defined data types , both in the language natively (such as VARCHAR2, PLS_INTEGER, BOOLEAN, etc.) and in a variety of supplied packages (e.g., the NUMBER_TABLE collection type in the DBMS_SQL package). Data types in PL/SQL can be scalars, such as strings and numbers, or composite (consisting of one or more scalars), such as record types, collection types and object types. You can't really declare your own "user-defined" scalars, though you can define subtypes  from those scalars, which can be very helpful from the p

The differences between deterministic and result cache features

 EVERY once in a while, a developer gets in touch with a question like this: I am confused about the exact difference between deterministic and result_cache. Do they have different application use cases? I have used deterministic feature in many functions which retrieve data from some lookup tables. Is it essential to replace these 'deterministic' key words with 'result_cache'?  So I thought I'd write a post about the differences between these two features. But first, let's make sure we all understand what it means for a function to be  deterministic. From Wikipedia : In computer science, a deterministic algorithm is an algorithm which, given a particular input, will always produce the same output, with the underlying machine always passing through the same sequence of states.  Another way of putting this is that a deterministic subprogram (procedure or function) has no side-effects. If you pass a certain set of arguments for the parameters, you will always get

My two favorite APEX 5 features: Regional Display Selector and Cards

We (the over-sized development team for the PL/SQL Challenge - myself and my son, Eli) have been busy creating a new website on top of the PLCH platform (tables and packages): The Oracle Dev Gym! In a few short months (and just a part time involvement by yours truly), we have leveraged Oracle Application Express 5 to create what I think is an elegant, easy-to-use site that our users will absolutely love.  We plan to initially make the Dev Gym available only for current users of PL/SQL Challenge, so we can get feedback from our loyal user base. We will make the necessary adjustments and then offer it for general availability later this year. Anyway, more on that as the date approaches (the date being June 27, the APEX Open Mic Night at Kscope16 , where I will present it to a packed room of APEX experts). What I want to talk about today are two features of APEX that are making me so happy these days: Regional Display Selector and Cards. Regional Display Sel