`
dftwillson
  • 浏览: 2145 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

Test jdbc insert

 
阅读更多
package gs;

/*public class t {

public static void main(String[] args) {
// TODO Auto-generated method stub

}

}
导出insertsql语句*/
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.Types;
import java.util.ArrayList;
import java.util.List;

public class Test {
private static Connection conn = null;
private static Statement sm = null;
private static String schema = "FJSTL";// 模式名
private static String select = "SELECT * FROM";// 查询sql
private static String insert = "INSERT INTO";// 插入sql
private static String values = "VALUES";// values关键字
private static String[] table = { "T_USER" };// table数组
private static List<String> insertList = new ArrayList<String>();// 全局存放insertsql文件的数据
private static String filePath = "E://insertSQL.txt";// 绝对路径 导出数据的文件

/**
* 导出数据库表
*
* @param args
* @throws SQLException
*/
public static void main(String[] args) throws SQLException {
List<String> listSQL = new ArrayList<String>();
//Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
String url="jdbc:oracle:thin:@localhost:1521:orcl";//orcl为数据库的SID?
String user="system";
        String password="orcl";
//Connection?conn=?DriverManager.getConnection(url,user,password);
connectSQL("oracle.jdbc.driver.OracleDriver", url, user, password);// 连接数据库
listSQL = createSQL();// 创建查询语句
executeSQL(conn, sm, listSQL);// 执行sql并拼装
createFile();// 创建文件
}

/**
* 创建insertsql.txt并导出数据
*/
private static void createFile() {
File file = new File(filePath);
if (!file.exists()) {
try {
file.createNewFile();
} catch (IOException e) {
System.out.println("创建文件名失败!!");
e.printStackTrace();
}
}
FileWriter fw = null;
BufferedWriter bw = null;
try {
fw = new FileWriter(file);
bw = new BufferedWriter(fw);
if (insertList.size() > 0) {
for (int i = 0; i < insertList.size(); i++) {
bw.append(insertList.get(i));
bw.append("\n");
}
}
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
bw.close();
fw.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}

/**
* 拼装查询语句
*
* @return 返回select集合
*/
private static List<String> createSQL() {
List<String> listSQL = new ArrayList<String>();
for (int i = 0; i < table.length; i++) {
StringBuffer sb = new StringBuffer();
sb.append(select).append(" ").append(schema).append(".")
.append(table[i]);
listSQL.add(sb.toString());
}
return listSQL;
}

/**
* 连接数据库 创建statement对象
*
* @param driver
* @param url
* @param UserName
* @param Password
*/
public static void connectSQL(String driver, String url, String UserName,
String Password) {
try {
Class.forName(driver).newInstance();
conn = DriverManager.getConnection(url, UserName, Password);
sm = conn.createStatement();
} catch (Exception e) {
e.printStackTrace();
}
}

/**
* 执行sql并返回插入sql
*
* @param conn
* @param sm
* @param listSQL
* @throws SQLException
*/
public static void executeSQL(Connection conn, Statement sm, List listSQL)
throws SQLException {
List<String> insertSQL = new ArrayList<String>();
ResultSet rs = null;
try {
rs = getColumnNameAndColumeValue(sm, listSQL, rs);
} catch (SQLException e) {
e.printStackTrace();
} finally {
rs.close();
sm.close();
conn.close();
}
}

/**
* 获取列名和列值
*
* @param sm
* @param listSQL
* @param rs
* @return
* @throws SQLException
*/
private static ResultSet getColumnNameAndColumeValue(Statement sm,
List listSQL, ResultSet rs) throws SQLException {
if (listSQL.size() > 0) {
for (int j = 0; j < listSQL.size(); j++) {
String sql = String.valueOf(listSQL.get(j));
rs = sm.executeQuery(sql);
ResultSetMetaData rsmd = rs.getMetaData();
int columnCount = rsmd.getColumnCount();
while (rs.next()) {
StringBuffer ColumnName = new StringBuffer();
StringBuffer ColumnValue = new StringBuffer();
for (int i = 1; i <= columnCount; i++) {
String value = rs.getString(i).trim();
if ("".equals(value)) {
value = " ";
}
if (i == 1 || i == columnCount) {
ColumnName.append(rsmd.getColumnName(i));
if (Types.CHAR == rsmd.getColumnType(i)
|| Types.VARCHAR == rsmd.getColumnType(i)
|| Types.LONGVARCHAR == rsmd
.getColumnType(i)) {
ColumnValue.append("'").append(value)
.append("',");
} else if (Types.SMALLINT == rsmd.getColumnType(i)
|| Types.INTEGER == rsmd.getColumnType(i)
|| Types.BIGINT == rsmd.getColumnType(i)
|| Types.FLOAT == rsmd.getColumnType(i)
|| Types.DOUBLE == rsmd.getColumnType(i)
|| Types.NUMERIC == rsmd.getColumnType(i)
|| Types.DECIMAL == rsmd.getColumnType(i)) {
ColumnValue.append(value).append(",");
} else if (Types.DATE == rsmd.getColumnType(i)
|| Types.TIME == rsmd.getColumnType(i)
|| Types.TIMESTAMP == rsmd.getColumnType(i)) {
ColumnValue.append("timestamp'").append(value)
.append("',");
} else {
ColumnValue.append(value).append(",");
}
} else {
ColumnName.append("," + rsmd.getColumnName(i));
if (Types.CHAR == rsmd.getColumnType(i)
|| Types.VARCHAR == rsmd.getColumnType(i)
|| Types.LONGVARCHAR == rsmd
.getColumnType(i)) {
ColumnValue.append("'").append(value)
.append("'").append(",");
} else if (Types.SMALLINT == rsmd.getColumnType(i)
|| Types.INTEGER == rsmd.getColumnType(i)
|| Types.BIGINT == rsmd.getColumnType(i)
|| Types.FLOAT == rsmd.getColumnType(i)
|| Types.DOUBLE == rsmd.getColumnType(i)
|| Types.NUMERIC == rsmd.getColumnType(i)
|| Types.DECIMAL == rsmd.getColumnType(i)) {
ColumnValue.append(value).append(",");
} else if (Types.DATE == rsmd.getColumnType(i)
|| Types.TIME == rsmd.getColumnType(i)
|| Types.TIMESTAMP == rsmd.getColumnType(i)) {
ColumnValue.append("timestamp'").append(value)
.append("',");
} else {
ColumnValue.append(value).append(",");
}
}
}
System.out.println(ColumnName.toString());
System.out.println(ColumnValue.toString());
insertSQL(ColumnName, ColumnValue);
}
}
}
return rs;
}

/**
* 拼装insertsql 放到全局list里面
*
* @param ColumnName
* @param ColumnValue
*/
private static void insertSQL(StringBuffer ColumnName,
StringBuffer ColumnValue) {
for (int i = 0; i < table.length; i++) {
StringBuffer insertSQL = new StringBuffer();
insertSQL.append(insert).append(" ").append(schema).append(".")
.append(table[i]).append("(").append(ColumnName.toString())
.append(")").append(values).append("(")
.append(ColumnValue.toString()).append(");");
insertList.add(insertSQL.toString());
System.out.println(insertSQL.toString());
}
}
}
分享到:
评论

相关推荐

    jdbc Connection test

    在IT行业中,JDBC(Java Database Connectivity)是Java语言中用于与各种数据库进行交互的一组接口和类。本文将深入探讨如何使用Eclipse IDE来连接MySQL-Front数据库,并实现数据表的插入和删除操作。 首先,我们...

    sqljdbc和测试jdbc连接类

    - `void testInsert()`: 插入一条新的记录并验证是否成功。 - `void testUpdate()`: 更新已有记录并验证更改。 - `void testDelete()`: 删除一条记录并检查是否已被删除。 - `void testTransaction()`: 演示如何...

    JDBC_test2.zip

    - **增(Insert)**:项目可能包含了插入新记录到数据库的逻辑,通过PreparedStatement对象来构造SQL INSERT语句,并使用JDBC调用executeUpdate()方法执行。 - **删(Delete)**:删除记录可能通过调用类似...

    TestJdbc.rar

    4. **SQL操作**:执行增删查改(CRUD)操作,例如`select * from students`,`insert into students values(...)`等。 5. **结果集处理**:使用`ResultSet`对象遍历查询结果,提取所需数据。 6. **事务处理**:...

    eclipse jdbc

    String upd = "insert into test (id, name) values (1001, 'zhsp1029')"; int count = stmt.executeUpdate(upd); ``` 常见参数 在 JDBC URL 中,可以添加一些参数来配置连接的行为,例如: * user:用户名 * ...

    Hive_JDBC.zip_hive java_hive jdbc_hive jdbc pom_java hive_maven连

    sql = "INSERT INTO TABLE " + tableName + " VALUES (1, 'one')"; stmt.execute(sql); sql = "SELECT * FROM " + tableName; ResultSet res = stmt.executeQuery(sql); while (res.next()) { System.out....

    SpringBoot+Mybatis-Plus整合Sharding-JDBC5.1.1实现单库分表【全网最新】.doc

    ### SpringBoot+Mybatis-Plus 整合 Sharding-JDBC5.1.1 实现单库分表 #### 一、前言与背景 在现代软件开发中,随着业务量的增长,单一数据库往往难以满足高性能、高并发的需求,因此分库分表成为了一种常见的解决...

    JDBC数据库连接测试

    Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "password"); // 创建PreparedStatement对象 String sql = "INSERT INTO users(name, email) VALUES (?, ?)"; ...

    spring jdbc Templatetest 访问mysql数据库,批量插入数据

    在Java开发中,Spring JDBC Template是一个非常重要的工具,它提供了对数据库操作的抽象层,简化了JDBC的繁琐工作,使我们能够更加专注于业务逻辑。本主题将详细讲解如何使用Spring JDBC Template访问MySQL数据库并...

    jdbc线程池演示demo

    &lt;jdbc-url&gt;jdbc:mysql://localhost:3306/test&lt;/jdbc-url&gt; &lt;user&gt;username &lt;password&gt;password &lt;max-pool-size&gt;100 &lt;min-pool-size&gt;10 ``` 3. 初始化数据源:在Java代码中,通过读取配置文件初始化C3P0数据...

    JDBC示例代码.zip

    在"JDBC示例代码.zip"压缩包中,包含两个文件:Test01.java和SqlHelper.java,它们代表了JDBC操作数据库的基本步骤。 Test01.java可能是主程序,它调用SqlHelper.java中的方法来执行数据库操作。在Test01中,我们...

    JDBC创建触发器 JDBC存储过程 JDBC创建表 数据备份 java备份数据库/JAVA恢复数据、java导入sql脚本

    一旦需要恢复,Java程序可以连接到数据库,读取备份文件,然后使用`Statement`执行`INSERT INTO`、`UPDATE`或`DELETE`语句来恢复数据。此外,如果备份是SQL脚本,可以使用`Statement.execute()`或`Statement....

    jdbc连接数据库步骤

    String url = "jdbc:mysql://localhost:3306/test"; String username = "root"; String password = "root"; Connection con = DriverManager.getConnection(url, username, password); ``` 如果连接成功,将...

    click-house-jdbc-test.zip

    本资源为利用clickhouse的jdbc官方驱动 封装完整的增删改查示例。 修饰符和类型 方法 说明 void batchInsertData(clickhouse.service.impl.ClickHouseWrap clickHouseWrap, String tableName, List,Object&gt;&gt; field...

    JDBC访问数据库步骤

    使用 Statement 对象执行 SQL 语句,例如 `INSERT`、`UPDATE`、`DELETE`、`SELECT` 等。执行结果可以是更新计数或结果集。 步骤 5:处理结果 如果是查询语句,需要处理结果集,使用 `ResultSet` 对象获取结果集中...

    JDBC的应用

    为了向 `DemoTable` 插入多条记录,我们连续执行了多个 `INSERT INTO` 语句。 查询数据库并获取结果集则需要用到 `executeQuery()` 方法,它会返回一个 `ResultSet` 对象。我们可以遍历 `ResultSet`,提取并展示...

    JDBC_test:练习JDBC程序

    **JDBC_test: 练习JDBC程序** 在Java编程中,JDBC(Java Database Connectivity)是连接Java应用程序与各种数据库的重要桥梁。本项目“JDBC_test”旨在提供一个实践平台,帮助开发者深入理解并熟练掌握JDBC的核心...

    Access_JDBC30 无使用次数限制 - 破解

    statement.execute("insert into test(field1,field2,field3,field4,field5,field6) values('field1_"+i+"','field2_"+i+"','field3_"+i+"','field4_"+i+"','field5_"+i+"','filed6_"+i+"')"); } ResultSet ...

    使用Spring JDBC 案例

    &lt;property name="jdbcUrl" value="jdbc:mysql://localhost:3306/test"/&gt; ``` 2. **DBCP连接池**: DBCP(BasicDataSource)是Apache Commons的一个组件,配置如下: ```xml ...

    (java)JDBC_example.rar_JDBC例子_jdbc_jdbc Java

    - `CreatTableTest.java`: 这个文件可能包含创建数据库表的示例代码,通常使用`Statement.executeUpdate()`来执行`CREATE TABLE` SQL语句。 - `DoUpdateTest.java`: 可能用于演示如何执行数据库的更新操作,如`...

Global site tag (gtag.js) - Google Analytics