| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115 | ;;; orgtbl-sqlinsert.el --- orgtbl to SQL insert statements.;; Copyright (C) 2008  Free Software Foundation;; Author: Jason Riedy <jason@acm.org>;; Keywords: org, tables, sql;; This program is free software; you can redistribute it and/or modify;; it under the terms of the GNU General Public License as published by;; the Free Software Foundation, either version 3 of the License, or;; (at your option) any later version.;; This program is distributed in the hope that it will be useful,;; but WITHOUT ANY WARRANTY; without even the implied warranty of;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the;; GNU General Public License for more details.;; You should have received a copy of the GNU General Public License;; along with this program.  If not, see <http://www.gnu.org/licenses/>.;;; Commentary:;; Converts an orgtbl to a sequence of SQL insertion commands.;; Table cells are quoted and escaped very conservatively.;;; Code:(defun orgtbl-to-sqlinsert (table params)  "Convert the orgtbl-mode TABLE to SQL insert statements.TABLE is a list, each entry either the symbol `hline' for a horizontalseparator line, or a list of fields for that line.PARAMS is a property list of parameters that can influence the conversion.Names and strings are modified slightly by default.  Single-ticksare doubled as per SQL's standard mechanism.  Backslashes anddollar signs are deleted.  And tildes are changed to spaces.These modifications were chosed for use with TeX.  SeeORGTBL-SQL-STRIP-AND-QUOTE.Supports all parameters from ORGTBL-TO-GENERIC.  New to this functionare::sqlname   The name of the database table; defaults to the name of the           target region.:nowebname If not nil, used as a wrapping noweb fragment name.The most important parameters of ORGTBL-TO-GENERIC for SQL are::splice    When set to t, return only insert statements, don't wrap           them in a transaction.  Default is nil.:tstart, :tend           The strings used to begin and commit the transaction.:hfmt      A function that gathers the quoted header names into a           dynamically scoped variable HDRLIST.  Probably should           not be changed by the user.The general parameters :skip and :skipcols have already been applied whenthis function is called."  (let* (hdrlist	 (alignment (mapconcat (lambda (x) (if x "r" "l"))			       org-table-last-alignment ""))	 (nowebname (plist-get params :nowebname))	 (breakvals (plist-get params :breakvals))         (firstheader t)         (*orgtbl-default-fmt* 'orgtbl-sql-strip-and-quote)	 (params2	  (list	   :sqlname name	   :tstart (lambda () (concat (if nowebname					  (format "<<%s>>= \n" nowebname)					"")				      "BEGIN TRANSACTION;"))	   :tend (lambda () (concat "COMMIT;" (if nowebname "\n@ " "")))	   :hfmt (lambda (f) (progn (if firstheader (push f hdrlist)) ""))	   :hlfmt (lambda (lst) (setq firstheader nil))	   :lstart (lambda () (concat "INSERT INTO "				      sqlname "( "				      (mapconcat 'identity (reverse hdrlist)						 ", ")				      " )" (if breakvals "\n" " ")				      "VALUES ( "))	   :lend " );"	   :sep " , "	   :hline nil	   :remove-nil-lines t))	 (params (org-combine-plists params2 params))         (sqlname (plist-get params :sqlname)))    (orgtbl-to-generic table params)))(defun orgtbl-sql-quote (str)  "Convert single ticks to doubled single ticks and wrap in single ticks."  (concat "'" (mapconcat 'identity (split-string str "'") "''") "'"))(defun orgtbl-sql-strip-dollars-escapes-tildes (str)  "Strip dollarsigns and backslash escapes, replace tildes with spaces."  (mapconcat 'identity	     (split-string (mapconcat 'identity				      (split-string str "\\$\\|\\\\")				      "")			   "~")	     " "))(defun orgtbl-sql-strip-and-quote (str)  "Apply ORGBTL-SQL-QUOTE and ORGTBL-SQL-STRIP-DOLLARS-ESCAPES-TILDESto sanitize STR for use in SQL statements."  (cond ((stringp str)         (orgtbl-sql-quote (orgtbl-sql-strip-dollars-escapes-tildes str)))        ((sequencep str) (mapcar 'orgtbl-sql-strip-and-quote str))        (t nil)))(provide 'orgtbl-sqlinsert);;; orgtbl-sqlinsert.el ends here
 |