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

Running out of PGA memory with MULTISET ops? Watch out for DISTINCT!

A PL/SQL team inside Oracle made excellent use of nested tables and MULTISET operators in SQL, blending data in tables with procedurally-generated datasets (nested tables).  All was going well when they hit the dreaded: ORA-04030: out of process memory when trying to allocate 2032 bytes  They asked for my help.  The error occurred on this SELECT: SELECT  *    FROM header_tab trx    WHERE (generated_ntab1 SUBMULTISET OF trx.column_ntab)       AND ((trx.column_ntab MULTISET             EXCEPT DISTINCT generated_ntab2) IS EMPTY) The problem is clearly related to the use of those nested tables. Now, there was clearly sufficient PGA for the nested tables themselves. So the problem was in executing the MULTISET-related functionality. We talked for a bit about dropping the use of nested tables and instead doing everything in SQL, to avoid the PGA error. That would, however require lots of work, revamping algorithms, ensuring correctness, you know the score. Then my eyes snagge

How to Pick the Limit for BULK COLLECT

This question rolled into my In Box today: In the case of using the LIMIT clause of BULK COLLECT, how do we decide what value to use for the limit? First I give the quick answer, then I provide support for that answer Quick Answer Start with 100. That's the default (and only) setting for cursor FOR loop optimizations. It offers a sweet spot of improved performance over row-by-row and not-too-much PGA memory consumption. Test to see if that's fast enough (likely will be for many cases). If not, try higher values until you reach the performance level you need - and you are not consuming too much PGA memory.  Don't hard-code the limit value: make it a parameter to your subprogram or a constant in a package specification. Don't put anything in the collection you don't need. [from Giulio Dottorini] Remember: each session that runs this code will use that amount of memory. Background When you use BULK COLLECT, you retrieve more than row with each fetch,

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