Structure Mysql
(* Mysql -- interface to the MySQL database server -- requires Dynlib *)
type dbconn                                   (* Connection to server *)
type dbresult                                 (* Result of a query    *)
eqtype oid                                    (* (not used by Mysql)  *)
exception Closed                              (* Connection is closed *)
exception Null                                (* Field value is NULL  *)
(* Opening, closing, and maintaining database connections *)
val openbase : { dbhost    : string option,   (* database server host *)
                 dbname    : string option,   (* database name        *)
                 dboptions : string option,   (* (not used by Mysql)  *)
                 dbport    : string option,   (* database server port *)
                 dbpwd     : string option,   (* user passwd          *)
                 dbtty     : string option,   (* (not used by Mysql)  *)
                 dbuser    : string option    (* database user        *)
               } -> dbconn
val closebase    : dbconn -> unit
val db           : dbconn -> string
val host         : dbconn -> string option
val options      : dbconn -> string
val port         : dbconn -> string
val tty          : dbconn -> string
val status       : dbconn -> bool
val reset        : dbconn -> unit
val errormessage : dbconn -> string option
(* Query execution and result set information *)
datatype dbresultstatus =
    Bad_response            (* (not used by Mysql)                    *)
  | Command_ok              (* The query was a command                *)
  | Copy_in                 (* (not used by Mysql)                    *)
  | Copy_out                (* (not used by Mysql)                    *)
  | Empty_query
  | Fatal_error             (* (not used by Mysql)                    *)
  | Nonfatal_error
  | Tuples_ok               (* The query successfully returned tuples *)
val execute      : dbconn -> string -> dbresult
val resultstatus : dbresult -> dbresultstatus
val ntuples      : dbresult -> int
val cmdtuples    : dbresult -> int
val nfields      : dbresult -> int
val fname        : dbresult -> int -> string
val fnames       : dbresult -> string vector
val fnumber      : dbresult -> string -> int option
(* Accessing the fields of a resultset *)
val getint       : dbresult -> int -> int -> int
val getreal      : dbresult -> int -> int -> real
val getstring    : dbresult -> int -> int -> string
val getdate      : dbresult -> int -> int -> int * int * int   (* Y M D *)
val gettime      : dbresult -> int -> int -> int * int * int   (* H M S *)
val getdatetime  : dbresult -> int -> int -> Date.date
val getbool      : dbresult -> int -> int -> bool
val isnull       : dbresult -> int -> int -> bool
datatype dynval =
    Bool of bool                        (* (not used by Mysql)   *)
  | Int of int                          (* Mysql int4            *)
  | Real of real                        (* Mysql float8 (float4) *)
  | String of string                    (* Mysql text (varchar)  *)
  | Date of int * int * int             (* Mysql date yyyy-mm-dd *)
  | Time of int * int * int             (* Mysql time hh:mm:ss   *)
  | DateTime of Date.date               (* Mysql datetime        *)
  | Oid of oid                          (* (not used by Mysql)   *)
  | Bytea of Word8Array.array           (* (not used by Mysql)   *)
  | NullVal                             (* Mysql NULL value      *)
val getdynfield  : dbresult -> int -> int -> dynval
val getdyntup    : dbresult -> int -> dynval vector
val getdyntups   : dbresult -> dynval vector vector 
val dynval2s     : dynval -> string
(* Bulk copying to or from a table *)
val copytableto   : dbconn * string * (string -> unit) -> unit
val copytablefrom : dbconn * string * ((string -> unit) -> unit) -> unit
(* Some standard ML and MySQL types: *)
datatype dyntype = 
    BoolTy              (* ML bool              (not used by Mysql)     *)
  | IntTy               (* ML int               Mysql int4              *)
  | RealTy              (* ML real              Mysql float8, float4    *)
  | StringTy            (* ML string            Mysql text, varchar     *) 
  | DateTy              (* ML (yyyy, mth, day)  Mysql date              *)
  | TimeTy              (* ML (hh, mm, ss)      Mysql time              *)
  | DateTimeTy          (* ML Date.date         Mysql datetime, abstime *)
  | OidTy               (* ML oid               (not used by Mysql)     *)
  | ByteArrTy           (* ML Word8Array.array  (not used by Mysql)     *)
  | UnknownTy of oid
val fromtag : dyntype -> string
val ftype   : dbresult -> int -> dyntype
val ftypes  : dbresult -> dyntype Vector.vector
val applyto : 'a -> ('a -> 'b) -> 'b
(* Formatting the result of a database query as an HTML table *)
val formattable : dbresult -> Msp.wseq
val showquery   : dbconn -> string -> Msp.wseq
(*
   [dbconn] is the type of connections to a MySQL database.
   [dbresult] is the type of result sets from MySQL queries.
   [openbase { dbhost, dbport, dboptions, dbtty, dbname, dbuser, dbpwd }] 
   opens a connection to a MySQL database server on the given host
   (default the local one) on the given port (default ?), to the given
   database (defaults to the user's login name), for the given user
   name (defaults to the current user's login name), and the given
   password (default none).  The result is a connection which may be
   used in subsequent queries.  In MySQL, unlike PostgreSQL, the
   dboptions and dbtty fields are not used.
   [closebase dbconn] closes the database connection.  No further
   queries can be executed.
   [db dbconn] returns the name of the database.
   [host dbconn] returns SOME h, where h is the database server host
   name, if the connection uses the Internet; returns NONE if the
   connection is to a socket on the local server.
   [options dbconn] returns the options given when opening the database.
   [port dbconn] returns the port number of the connection.
   [tty dbconn] returns the name of the tty used for logging.
   [status dbconn] returns true if the connection is usable, false
   otherwise.
   [reset dbconn] attempts to close and then reopen the connection to
   the database server.
   [errormessage dbconn] returns NONE if no error occurred, and SOME msg
   if an error occurred, where msg describes the error.
   [execute dbconn query] sends an SQL query to the database server
   for execution, and returns a resultset dbres.
   
   [resultstatus dbres] returns the status of the result set dbres.
   After a select query that succeeded, it will be Tuples_ok.
   
   [ntuples dbres] returns the number of tuples in the result set
   after a query.
   [cmdtuples dbres] returns the number of tuples affected by an
   insert, update, or delete SQL command.
   [nfields dbres] returns the number of fields in each tuple after a
   query.
   [fname dbres fno] returns the name of field number fno (in the
   result set after a query).  The fields are numbered 0, 1,...
   [fnames dbres] returns a vector of the field names (in the result
   set after a query).
   [fnumber dbres fname] returns SOME i where i is the number (0, 1,
   ...) of the field called fname (in the result set after a query),
   if the result set contains such a field name; returns NONE otherwise.
   [ftype dbres fno] returns the dyntype of field number fno (in the
   result set after a query).
   [ftypes dbres] returns a vector of the dyntypes (in the result set
   after a query).
   [fromtag dt] returns the name of the preferred MySQL type used
   to represent values of the dyntype dt.  This may be used when
   building `create table' statements.
   [getint dbres fno tupno] returns the integer value of field number
   fno in tuple tupno of result set dbres.  Raises Null if the value
   is NULL.
   [getreal dbres fno tupno] returns the floating-point value of field
   number fno in tuple tupno of result set dbres.  Raises Null if the
   value is NULL.
   [getstring dbres fno tupno] returns the string value of field
   number fno in tuple tupno of result set dbres.  Raises Null if the
   value is NULL.
   [getdate dbres fno tupno] returns the date (yyyy, mth, day) value
   of field number fno in tuple tupno of result set dbres.  Raises
   Null if the value is NULL.  Raises Fail if the field cannot be
   scanned as a date.
   [gettime dbres fno tupno] returns the time-of-day (hh, mm, ss)
   value of field number fno in tuple tupno of result set dbres.
   Raises Null if the value is NULL.  Raises Fail if the field cannot
   be scanned as a time.
   [getdatetime dbres fno tupno] returns the Date.date value of field
   number fno in tuple tupno of result set dbres.  Raises Null if the
   value is NULL.  Raises Fail if the field cannot be scanned as a
   date.
   [getbool dbres fno tupno] returns the boolean value of field number
   fno in tuple tupno of result set dbres.  Raises Null if the value
   is NULL.
   [isnull dbres fno tupno] returns true if the value of field number
   fno in tuple tupno of result set dbres is NULL; false otherwise.
   [getdynfield dbres fno tupno] returns the value of field number fno
   in tuple tupno of result set dbres as a dynval (a wrapped value).
   A NULL value is returned as NullVal.  Note that the partial
   application  (getdynfield dbres fno)  precomputes the type of the 
   field fno.  Hence it is far more efficient to compute 
        let val getfno = getdynfield dbres fno
        in tabulate(ntuples dbres, getfno) end
   than to compute
        let fun getfno tupno = getdynfield dbres fno tupno
        in tabulate(ntuples dbres, getfno) end
   because the latter repeatedly computes the type of the field.
   [getdyntup dbres tupno] returns the fields of tuple tupno in result
   set dbres as a vector of dynvals.
   [getdyntups dbres] returns all tuples of result set dbres as a
   vector of vectors of dynvals.
   [dynval2s dv] returns a string representing the dynval dv.
   [applyto x f] computes f(x).  This is convenient for applying
   several functions (given in a list or vector) to the same value:
      map (applyto 5) (tabulate(3, getdynfield dbres))
   equals 
      [getdynfield dbres 0 5, getdynfield dbres 1 5, getdynfield dbres 2 5]
   [copytableto(dbconn, tablename, put)] simulates a PostgreSQL "COPY
   TABLE TO" statement, applies the function put to every tuple of the
   table, represented as a line of text (not terminated by newline
   \n), and cleans up at the end.  For instance, to copy the contents
   of a table t to a text stream s (one tuple on each line), define
      fun put line = 
          (TextIO.output(s, line); TextIO.output(s, "\n"))
   and execute
      copytableto(dbconn, "t", put).
   [copytablefrom(dbconn, tablename, useput)] simulates a PostgreSQL
   "COPY TABLE FROM" statement, creates a put function for copying
   lines to the table, passes the put function to useput, and cleans
   up at the end.  The put function may be called multiple times for
   each line (tuple); the end of each line is indicated by the
   newline character "\n" as usual.  For instance, to copy the
   contents of a text stream s to a table t, define
      fun useput put = 
          while not (TextIO.endOfStream s) do put(TextIO.inputLine s);
   and execute
      copytablefrom(dbconn, "t", useput).
   Note that TextIO.inputLine preserves the newline at the end of each 
   line.  
   [formattable dbresult] returns a wseq representing an HTML table.
   The HTML table has a column for every field in the dbresult.  The
   first row is a table header giving the names of the fields in the
   dbresult.  The remaining rows correspond to the tuples in the
   dbresult, in the order they are provided by the database server.
   Null fields are shown as NULL.
   [showquery dbconn query] sends the SQL query to the database
   server, then uses formattable to format the result of the query.
*)
Moscow ML 2.10