PostgreSQL provides four kinds of
   functions:
   
-       query language functions 
      (functions written in SQL)
      
-       procedural language 
      functions (functions written in, for example, PL/Tcl or PL/pgSQL)
      
-       internal functions
      
-       C language functions
      
  
   Every kind
   of  function  can take a base type, a composite type, or
   some combination as arguments (parameters).   In  addition, 
   every kind of function can return a base type or
   a composite type.  It's easiest to define SQL 
   functions, so we'll start with those.  Examples in this section 
   can also be found in funcs.sql 
   and funcs.c in the tutorial directory.
  
   Throughout this chapter, it can be useful to look at the reference
   page of the CREATE FUNCTION command to
   understand the examples better.