?? rowmap.java
字號(hào):
/* * Copyright (c) 2000 jPOS.org. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * 3. The end-user documentation included with the redistribution, * if any, must include the following acknowledgment: * "This product includes software developed by the jPOS project * (http://www.jpos.org/)". Alternately, this acknowledgment may * appear in the software itself, if and wherever such third-party * acknowledgments normally appear. * * 4. The names "jPOS" and "jPOS.org" must not be used to endorse * or promote products derived from this software without prior * written permission. For written permission, please contact * license@jpos.org. * * 5. Products derived from this software may not be called "jPOS", * nor may "jPOS" appear in their name, without prior written * permission of the jPOS project. * * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE JPOS PROJECT OR ITS CONTRIBUTORS BE LIABLE FOR * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. * ==================================================================== * * This software consists of voluntary contributions made by many * individuals on behalf of the jPOS Project. For more * information please see <http://www.jpos.org/>. */package org.jpos.tpl;import java.math.BigDecimal;import java.util.Date;import java.util.Hashtable;import java.util.Iterator;import java.util.Map;import org.jpos.iso.ISODate;/** * SQL string manipulation helper class * @author apr@cs.com.uy * @version $Id: RowMap.java,v 1.7 2004/11/19 15:24:56 apr Exp $ */public class RowMap { protected Map map; public RowMap () { map = new Hashtable(); } public void set (String name, String value) { map.put (name, value != null ? "'"+escape(value)+"'" : "null"); } public void set (String name, int value) { map.put (name, Integer.toString (value)); } public void set (String name, long value) { map.put (name, Long.toString (value)); } public void set (String name, BigDecimal value) { map.put (name, value.toString()); } public void set (String name, Date d) { map.put (name, d == null ? "null" : "'" + ISODate.formatDate (d, "yyyy-MM-dd HH:mm:ss") + "'"); } public Map getMap() { return map; } public String getInsertSql (String tableName) { StringBuffer columns = new StringBuffer(); StringBuffer values = new StringBuffer(); Iterator iter = map.entrySet().iterator(); boolean first = true; while (iter.hasNext()) { Map.Entry entry = (Map.Entry) iter.next(); if (!first) { columns.append (','); values.append (','); } else first = false; columns.append (entry.getKey()); values.append (entry.getValue()); } return "INSERT INTO "+tableName+ " (" + columns.toString() +") VALUES (" + values.toString() + ")"; } public String getUpdateSql (String tableName, String where) { StringBuffer sb = new StringBuffer(); Iterator iter = map.entrySet().iterator(); boolean first = true; while (iter.hasNext()) { Map.Entry entry = (Map.Entry) iter.next(); if (!first) sb.append (','); else first = false; sb.append (entry.getKey()); sb.append ('='); sb.append (entry.getValue()); } return "UPDATE "+tableName+ " SET "+sb.toString() + " WHERE " + where; } public String escape (String s) { if (s.indexOf ("'") != -1 ) { StringBuffer sb = new StringBuffer(s.length() + 1); // at least 1 char c; for(int i=0; i < s.length(); i++ ) { c = s.charAt (i); if (c == '\'' || c == '\\') sb.append ('\\'); sb.append(c); } s = sb.toString(); } return s; }}
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -