`
daoshud1
  • 浏览: 558093 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

java 解析sql脚本

 
阅读更多
java执行sql脚本,一种是解析sql脚本,生成每一条sql语句,由java jdbc去执行。
第二种是利用 Ant 的SQL Task来实现执行SQL 脚本的功能。http://daoshud1.iteye.com/blog/1913149

public static void main(String[] args) {
		try {
			List<String> sqlList = new sqlUtil().loadSql("g:\\menuinfo-sql-data.sql");
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}

	/**
	 * 
	* @Title: loadSql 
	* @Description: TODO(解析sql) 
	* @param @param sqlFile
	* @param @return
	* @param @throws Exception    设定文件 
	* @return List<String>    返回类型 
	* @throws
	 */
	private  List<String> loadSql(String sqlFile) throws Exception {
		List<String> sqlList = new ArrayList<String>();
		try {
			InputStream sqlFileIn = new FileInputStream(sqlFile);
			StringBuffer sqlSb = new StringBuffer();
			byte[] buff = new byte[1024];
			int byteRead = 0;
			while ((byteRead = sqlFileIn.read(buff)) != -1) {
				sqlSb.append(new String(buff, 0, byteRead,"utf-8"));//防止中文乱码
			}
			// Windows 下换行是 \r\n, Linux 下是 \n
			String[] sqlArr = sqlSb.toString()
					.split("(;\\s*\\r\\n)|(;\\s*\\n)");
			for (int i = 0; i < sqlArr.length; i++) {
				String sql = sqlArr[i].replaceAll("--.*", "").trim();
				if (!sql.equals("")) {
					sqlList.add(sql);
				}
			}
			return sqlList;
		} catch (Exception ex) {
			throw new Exception(ex.getMessage());
		}
	}

	/**
	 * 
	* @Title: execute 
	* @Description: TODO(这里用一句话描述这个方法的作用) 
	* @param @param conn
	* @param @param sqlFile
	* @param @throws Exception    设定文件 
	* @return void    返回类型 
	* @throws
	 */
	public void execute(Connection conn, String sqlFile){
		try {
			Statement stmt = null;
			List<String> sqlList = loadSql(sqlFile);
			stmt = conn.createStatement();
			for (String sql : sqlList) {
				stmt.addBatch(sql);
			}
			int[] rows = stmt.executeBatch();
		} catch (Exception e) {
			e.printStackTrace();
		}finally{
//			clise();
		}
	}
分享到:
评论

相关推荐

    java的sql解析器jsqlparser

    然后,你可以创建一个`CCJSqlParserManager`实例,使用它来解析SQL字符串,得到AST。之后,遍历AST并提取所需信息。例如,以下是一个简单的代码片段: ```java import net.sf.jsqlparser.JSQLParserException; ...

    java检查sql语法是否正确

    为了实现这一目标,开发者通常会利用Java的JDBC(Java Database Connectivity)API或者其他第三方库来执行预编译或解析SQL语句。下面我们将详细探讨如何在Java中检查SQL语法的正确性。 首先,JDBC API提供了一个`...

    通过解析sql语句获取表血缘关系项目

    "通过解析SQL语句获取表血缘关系项目"是一个针对数据库管理的实用技术,主要用于理解和跟踪数据的来源与流向,即血缘关系。血缘关系追踪在数据质量、合规性、审计和数据治理中扮演着关键角色。以下是关于这个主题的...

    解析SQL提取表名并输出文本文件

    本文将深入探讨如何通过解析SQL文件来提取其中的表名,并将其保存为文本文件,这对于数据库管理员、数据分析师以及软件开发人员来说是一项非常实用的技能。 首先,让我们理解SQL语句的基本结构。SQL主要由DML(数据...

    批量执行SQL脚本(附源码).zip

    源码附带的这个工具可能采用了一种类似批处理的方式,逐行读取SQL脚本,解析语句,并通过数据库连接执行。在编程实现上,可能会使用如Java的JDBC(Java Database Connectivity)或者Python的psycopg2(PostgreSQL ...

    读取Excel生成Sql脚本

    总的来说,"读取Excel生成Sql脚本"是一个利用Java编程语言,结合JDBC和POI库实现的数据处理工具。它简化了从Excel到数据库的数据迁移过程,提升了数据操作的效率。对于熟悉Java和数据库的开发者来说,这是一个非常有...

    Java开发的sql生成器

    1. **元数据解析**:它能读取数据库的元数据,如表结构、字段类型等,为生成SQL语句提供基础信息。 2. **语法规则引擎**:根据预定义的模板或者用户配置,结合元数据信息,生成符合SQL语法的语句。 3. **动态条件...

    批量执行Sql脚本工具(含代码)

    5. **SQL解析与执行**:工具需要能够解析SQL脚本文件,识别每条命令并正确执行。这可能涉及到对SQL语法的解析和命令执行逻辑。 6. **错误处理**:在批量执行过程中,如果遇到错误,工具应具备捕获和处理异常的能力...

    Java Sql 格式化工具

    它可能包含了读取SQL语句、解析语法结构、应用格式规则以及生成格式化后SQL的逻辑。对于想要自定义或扩展格式化功能的开发者来说,这是一个重要的起点。 使用这些文件,开发者可以按照以下步骤进行操作: 1. 首先...

    一款基于SQL查询ES的Java工具包,支持SQL解析DSL,支持JDBC驱动,支持和Mybatis、Spring集成.zip

    描述中提到的“支持SQL解析DSL”意味着该工具包包含了一个SQL解析器,能够将SQL查询语句转换为Domain Specific Language (DSL)。DSL是专为特定领域设计的语言,这里指的就是Elasticsearch的查询DSL。这种方式使得...

    java+sql学生成绩管理系统(有文档).rar

    2. “SQL生成数据表.txt”包含创建数据库和数据表的SQL脚本,用于初始化数据库环境。 3. “源代码”目录下包含系统的所有Java源文件,如控制器类、模型类、DAO(Data Access Object)类等。 4. “DATA”可能存放系统...

    基于Java的动态脚本语言(DSL)解析框架设计源码

    本项目为基于Java实现的动态脚本语言(DSL)解析框架设计源码,包含72个文件,其中包含60个Java源文件、6个DSL脚本文件以及其他辅助文件,旨在提供灵活的解析能力,特别适用于动态SQL(DSQL)场景,如Flink SQL、...

    图书管理系统附带sql脚本-java版

    《图书管理系统附带SQL脚本-Java版》 在当今数字化时代,图书管理系统的存在显得尤为重要,它使得图书的借阅、归还、查询等操作变得更加便捷高效。本项目是基于Java语言开发的一款图书管理系统,结合了SQL数据库...

    基于java的数据库脚本转换工具(mysql-&gt;oracle).zip

    此外,如果这个"java0323"文件包含了源代码,那么它也提供了一个学习和研究的机会,让我们了解如何用Java进行数据库脚本的解析、转换以及数据库操作。通过分析和理解代码,开发者可以提升自己的Java编程技巧和数据库...

    开发GraphQL服务以及前台系统搭建(含Java代码和sql脚本).zip

    这个压缩包包含了实现这一目标所需的各种资源,包括Java代码和SQL脚本。GraphQL是一种强大的查询语言,它允许客户端定义他们需要的数据结构,从而提高了API的效率和灵活性。Java作为后端开发的主要语言之一,常用于...

    mysql 逆向解析mysqlbinlog成sql工具,可以解析5.7json字段,批量执行

    先私信后购买,解析binlog利器,回滚恢复误删除数据

    基于java+Sqlserver的网上书店课程设计源码

    "基于java+Sqlserver的网上书店课程设计源码"是一个关于软件开发的项目,主要使用Java编程语言和SQL Server数据库系统来构建一个在线书店的应用程序。这个项目可能是一个教育背景下的课程设计任务,目的是让学生掌握...

    报表技术POI(含java源码、文档、SQL脚本、excel数据).zip

    描述中提到的“java源码、文档、SQL脚本、excel数据”,这些内容代表了学习和实践报表技术POI所必需的各种资源。Java源码可能是实现了POI库的示例代码,供开发者参考和学习;文档可能包含了关于如何使用POI库进行...

    java连接SQL Server 2000 and Server2008的工具

    9. **性能优化**:使用`PreparedStatement`代替`Statement`可以提高性能,因为预编译的SQL语句可以减少解析时间。此外,还可以使用连接池(如C3P0, HikariCP)来管理数据库连接,提高应用的响应速度和并发能力。 ...

    使用antlrv3实现sql的解析

    在本主题中,“使用antlrv3实现sql的解析”指的是利用ANTLR v3版本来创建一个解析器,该解析器可以理解并解析SQL语句,特别是针对Oracle和Microsoft SQL Server(MSSQL)的语法。 ANTLR工作原理主要包括以下几个...

Global site tag (gtag.js) - Google Analytics