java 生成sql语句

package com.iminido.util.dev;

import com.iminido.db.Conn;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;

public class DataBaseStruct {

//	private final String DRIVER =  "oracle.jdbc.driver.OracleDriver";
//	private final String URI = "jdbc:oracle:thin:@192.168.1.6:1521:orcl";
//	private final String NAME = "xcww";
//	private final String PASSWORD = "1";
    private Connection conn = null;
    private PreparedStatement pstmt = null;
    private ResultSet rs = null;
    private ResultSetMetaData rsm = null;

    public static void main(String[] args) {
        DataBaseStruct dbs = new DataBaseStruct();
        dbs.getTableStruct("t_user");
    }

    public void getTableStruct(String tableName) {
        try {
//	    	 Class.forName(DRIVER);
//			 conn = DriverManager.getConnection(URI,NAME,PASSWORD);
            conn = Conn.conn();
            pstmt = (PreparedStatement) conn.prepareStatement("select * from " + tableName);
            pstmt.execute();
            rsm = (ResultSetMetaData) pstmt.getMetaData();

            StringBuilder insert = new StringBuilder();
            insert.append("INSERT INTO " + tableName + "(");
            for (int i = 1; i < rsm.getColumnCount() + 1; i++) {
                insert.append("'").append(rsm.getColumnName(i)).append("',");
            }
            insert.append(") values (");
            for (int i = 1; i < rsm.getColumnCount() + 1; i++) {
                insert.append("'").append(rsm.getColumnName(i)).append("',");
            }
            insert.append(");");
            System.out.println(insert.toString().replace(",)", ")").toUpperCase());

        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            try {
                pstmt.close();
                conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值