SQL Insert语句生成器简介

下面将为您介绍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);
    } #p#
    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
     */ #p#
    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;
    } #p#

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

    /**
     * 表格名
     * @param table
     */
    public void setTable(String table) {
        this.table = table;
    }
}
 

 

【编辑推荐】

SQL数据库压缩语句简介

如何使用SQL语句修改字段默认值

教您用事务一次处理多条SQL语句

通过执行多条SQL语句实现数据库事务

存储过程优化的SQL语句写法

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/240316.html<

(0)
运维的头像运维
上一篇2025-04-23 19:46
下一篇 2025-04-23 19:48

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注