当前位置:七道奇文章资讯数据防范MSSQL防范
日期:2011-01-25 23:11:00  来源:本站整理

SQL Insert语句生成器简介(1)[MSSQL防范]

赞助商链接



  本文“SQL Insert语句生成器简介(1)[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

下面将为您介绍SQL Insert语句生成器的程序代码,供您参考, Insert语句是SQL语句中最常用的语句之一,但愿对您学习SQL可以有所帮忙.

程序输出:

insert into User ( name, age ) values( 'BeanSoft', 27 )

import java.util.*;

import StringUtil;

/**
* 生成 Insert SQL 语句的类.
* @author beansoft
* @date 2009-4-5
*/
public class SQLInsert extends HashMap<String, Object> {
    private String table;// 表格名
    private String columns;// 列名表, 以逗号离隔
    /** 能否查抄列名有效性 */
    private boolean checkColumn = true;
    /** 能否答应反复设置列值, 默许答应 */
    private boolean allowDuplicate = true;
    /** 列表, 保存大概的列名 */
    private List<String> columnList = new ArrayList<String>();
    public SQLInsert() {}
    /**
     * 给定表名和列名(用来查验)的构造器.
     * @param table - 表名
     * @param columns - 列名(用来查验)
     */
    public SQLInsert(String table, String columns) {
        setTable(table);
        setColumns(columns);
    }
    public static void main(String[] args) {
        SQLInsert insert = new SQLInsert();
        insert.setTable("User");
        insert.setColumns("name, age");
        insert.put("name", "BeanSoft");
        insert.put("age", 27);
        System.out.println(insert);
    } 

public String toString() {
        if(table == null || table.length() == 0) {
            throw new Error("对不起, 请调用 setTable() 指定表名");
        }
        String sql = "insert into " + table + " ( ";
        String values = "values( ";
        if(this.size() == 0) {
            throw new Error("对不起, 没有任何列值, 无法生成 INSERT 语句");
        }  else if(columnList.size()  == 0){
            // 尝试从主键列表生成列名列表
            String[] cols = this.keySet().toArray(new String[0]);
            for(String col: cols) {
                columnList.add(col);
            }
        }
//        System.out.println("columnList=" + columnList.size());
        if(columnList.size() > 0 ) {
            for (int i = 0; i < columnList.size(); i++) {
                String col = columnList.get(i);
                Object value = this.get(col);
                if(value == null && checkColumn) {
                    throw new Error("对不起, 列[" + col + "]的值为空");
                }
                sql += col;
                if(!StringUtil.isNumeric(value + "")) {
                    values += "'" + value + "'";
                } else {
                    values += value;
                }
                if (columnList.size() > 1 && (i != columnList.size() - 1)) {
                    sql += (", ");
                    values += (", ");
                }
            }
        }

sql += (" ) ");
        values += (" )");

//        System.out.println("自动生成的 sql = " + sql + values);
        return sql + values;
    }

/**
     * @param columns the 列名表, 以逗号离隔 to set
     */ 

public void setColumns(String columns) {
        this.columns = columns;
        columnList.clear();
        if(columns != null) {
            // 替换空格等字符, 不然解析会出错
            StringBuffer buff = new StringBuffer();
            for(int i = 0; i < columns.length(); i++) {
                char ch = columns.charAt(i);
                if(Character.isSpaceChar(ch)) {
                    continue;
                }
                buff.append(ch);
            }
            String[] cols = buff.toString().split(",");
//            System.out.println("cols.length=" + cols.length);
            for(String col: cols) {
                columnList.add(col);
            }
        }
    }

/**
     * @return the 能否答应反复设置列值, 默许答应
     */
    public boolean isAllowDuplicate() {
        return allowDuplicate;
    }

/**
     * @param allowDuplicate the 能否答应反复设置列值, 默许答应 to set
     */
    public void setAllowDuplicate(boolean allowDuplicate) {
        this.allowDuplicate = allowDuplicate;
    }

/**
     * @return the 能否查抄列名有效性
     */
    public boolean isCheckColumn() {
        return checkColumn;
    }

/**
     * @param checkColumn the 能否查抄列名有效性 to set
     */
    public void setCheckColumn(boolean checkColumn) {
        this.checkColumn = checkColumn;
    }

/**
     * @return the 列名表, 以逗号离隔
     */
    public String getColumns() {
        return columns;
    }

/**
     * 表格名
     * @return
     */
    public String getTable() {
        return table;
    }

/**
     * 表格名
     * @param table
     */
    public void setTable(String table) {
        this.table = table;
    }
}
  以上是“SQL Insert语句生成器简介(1)[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:

  • Windows 搭配 IIS7 PHP MySQL 环境
  • sqlserver索引的原理及索引成立的注意事项小结
  • SQL Join的一些总结(实例)
  • SQL的Join利用图解教程
  • SQL中JOIN和UNION辨别、用法及示例介绍
  • 关于SQL中CTE(公用表表达式)(Common Table Expression)的总结
  • mysql Out of memory (Needed 16777224 bytes)的错误办理
  • mysql提醒[Warning] Invalid (old?) table or database name问题的办理办法
  • mysql启用skip-name-resolve情势时呈现Warning的处理办法
  • mysql启用skip-name-resolve情势时呈现Warning的处理办法
  • MySQL Order By语法介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .