成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SQL Insert語句生成器簡介

數據庫 SQL Server
下面將為您介紹SQL Insert語句生成器的程序代碼,供您參考, Insert語句是SQL語句中最常用的語句之一,希望對您學習SQL能夠有所幫助。

下面將為您介紹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語句寫法

 

責任編輯:段燃 來源: 博客園
相關推薦

2024-07-09 08:49:56

2010-09-07 16:46:56

SQL語句nsert

2015-08-25 11:07:58

2017-07-01 16:02:39

分布式ID生成器

2025-01-23 08:36:27

CSS開發工具

2011-12-23 13:42:05

JavaScript

2021-04-22 21:15:38

Generator函數生成器

2024-11-01 15:51:06

2017-09-06 09:26:03

Python生成器協程

2023-07-02 14:14:37

ChatGPTMidjourney

2021-12-04 22:07:44

Python

2015-08-25 15:54:17

程序員代碼生成器

2021-07-23 11:24:54

Create Inc開源G代碼生成器

2024-08-19 00:00:00

表單生成器開發開源

2023-05-17 16:02:00

CSS工具代碼生成器

2020-09-08 11:21:48

SQL生成器跨庫

2023-01-06 07:52:52

代碼生成器開發

2023-03-08 09:06:24

2022-07-25 10:27:36

背景生成器工具前端

2022-12-15 08:49:58

ReactQR生成器
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产成人精品免费视频 | 国产97碰免费视频 | 久久综合久久久 | 亚洲视频欧美视频 | 在线2区| 色婷婷一区二区三区四区 | 福利社午夜影院 | 在线日韩欧美 | 午夜免费视频观看 | 国产欧美精品区一区二区三区 | 成人午夜激情 | 男女国产网站 | 中文字幕一区在线 | av网站免费 | 国产高潮av | 亚洲一区二区三区视频免费观看 | 国产精品亚洲一区二区三区在线 | 天天宗合网 | 国产精品视频一区二区三区 | 中文成人无字幕乱码精品 | 亚洲a视频 | 精品国产乱码久久久久久老虎 | 日韩在线一区二区三区 | 国产97久久 | 精品久久伊人 | 日韩手机视频 | 国产精品99久久久久久久久 | 欧美精品久久久久 | 日韩精品视频在线观看一区二区三区 | 丁香婷婷在线视频 | 99热精品6| 中文字幕日韩欧美一区二区三区 | 一区二区三区四区免费视频 | 久久久www成人免费无遮挡大片 | 欧美日韩在线视频一区 | 欧美成人一区二免费视频软件 | 亚洲精品aⅴ | 艹逼网 | 天天操天天怕 | 中文字幕二区 | 久久这里只有 |