本文实例为大家分享了Java执行SQL脚本文件到数据库的具体方式,供大家参考,具体内容如下
代码:RunSqlService:
				?
			
| 
								1
 
								2
 
								3
 
								4
 
								5
 
								6
 
								7
 
								8
 
								9
 
								10
 
								11
 
								12
 
								13
 
								14
 
								15
 
								16
 
								17
 
								18
 
								19
 
								20
 
								21
 
								22
 
								23
 
								24
 
								25
 
								26
 
								27
 
								28
 
								29
 
								30
 
								31
 
								32
 
								33
 
								34
 
								35
 
								36
 
								37
 
								38
 
								39
 
								40
 
								41
 
								42
 
								43
 
								44
 
								45
 
								46
 
								47
 
								48
 
								49
 
								50
 
								51
 
								52
 
								53
 
								54
 
								55
						 | @AutowiredprivateRunSqlDao runSqlDao;/*** 读取文件内容到SQL中执行* @param sqlPath SQL文件的路径:如:D:/TestProject/web/sql/脚本.Sql*/publicvoidrunSqlByReadFileContent(String sqlPath) throwsException {try{String sqlStr = readFileByLines(sqlPath);// System.out.println("获得的文本:" + sqlStr);if(sqlStr.length() > 0) {runSqlDao.runSqlBySqlStr(sqlStr);}} catch(Exception e) {e.printStackTrace();throwe;}}/*** 以行为单位读取文件,常用于读面向行的格式化文件*/privateString readFileByLines(String filePath) throwsException {StringBuffer str = newStringBuffer();BufferedReader reader = null;try{reader = newBufferedReader(newInputStreamReader(newFileInputStream(filePath), "UTF-8"));String tempString = null;intline = 1;// 一次读入一行,直到读入null为文件结束while((tempString = reader.readLine()) != null) {// 显示行号// System.out.println("line " + line + ": " + tempString);str = str.append(" "+ tempString);line++;}reader.close();} catch(IOException e) {e.printStackTrace();throwe;} finally{if(reader != null) {try{reader.close();} catch(IOException e1) {}}}returnstr.toString();} | 
RunSqlDao :
				?
			
| 
								1
 
								2
 
								3
 
								4
 
								5
 
								6
 
								7
 
								8
						 | /*** @param sqlStr*/publicvoidrunSqlBySqlStr(String sqlStr) {Map<String,Object> map=newHashMap<String,Object>();map.put("sqlStr", sqlStr);sqlSessionTemplate.selectList("runSql.runSqlBySqlStr", map);} | 
SQLMap:
				?
			
| 
								1
 
								2
 
								3
 
								4
 
								5
 
								6
 
								7
						 | <mapper namespace="runSql"><selectid="runSqlBySqlStr"parameterType="map"><![CDATA[ ${sqlStr}]]></select></mapper> | 
这种写法:只支持数据的变化(新增、修改、删除),且SQL文件内容以begin开始,以end结束。无法更新表字段修改等操作。
方式二;使用ScriptRunner
代码:RunSqlService:
				?
			
| 
								1
 
								2
 
								3
 
								4
 
								5
 
								6
 
								7
 
								8
 
								9
 
								10
 
								11
 
								12
 
								13
 
								14
 
								15
 
								16
 
								17
						 | /*** 执行sql脚本文件 使用ScriptRunner* @param sqlPath SQL文件的路径:如:D:/TestProject/web/sql/脚本.Sql*/publicvoidrunSqlByScriptRunner(String sqlPath) throwsException {try{SqlSession sqlSession = sqlSessionFactory.openSession();Connection conn = sqlSession.getConnection();ScriptRunner runner = newScriptRunner(conn);runner.setEscapeProcessing(false);runner.setSendFullScript(true); runner.runScript(newInputStreamReader(newFileInputStream(sqlPath), "UTF-8"));} catch(Exception e) {e.printStackTrace();throwe;}} | 
	
	这种写法:只能有一行SQL,即一次执行一个SQL语句,否则就会报错。
方式三:使用ScriptUtils
代码:RunSqlService:(以下两种方式:脚本.Sql 和RunSqlService 在同一目录下)
方法(1)
				?
			
                	
    
	
	
		
		
	
 
	
		
			
	
	 
     
	
			
                 
			
		
		
			
			
			
    
        
        
	
			
						
			
            			
    		
    		
		
	    
    	
    	
        
    	
    
| 
								1
 
								2
 
								3
 
								4
 
								5
 
								6
 
								7
 
								8
 
								9
 
								10
 
								11
 
								12
 
								13
 
								14
						 | /*** 执行sql脚本文件 使用Spring工具类*/publicvoidrunSqlBySpringUtils() throwsException {try{SqlSession sqlSession = sqlSessionFactory.openSession();Connection conn = sqlSession.getConnection();ClassPathResource rc = newClassPathResource("脚本.Sql", RunSqlDao.class);ScriptUtils.executeSqlScript(conn, rc);} catch(Exception e) {e.printStackTrace();throwe;}} | 
方法(2)
				?
			
	
						
						
						
						
						
						
						
																		
    
        
    
        
                        
                
                    
                
                
                
                    
                
                
                
                    
                
                
                
                    
                
                        
    
 																		
						
																		
    
        
 												
						
																		
	
	
		
				
			
																		
						
						
					
				
				                | 
								1
 
								2
 
								3
 
								4
 
								5
 
								6
 
								7
 
								8
 
								9
 
								10
 
								11
 
								12
 
								13
 
								14
 
								15
						 | /*** 执行sql脚本文件 使用Spring工具类*/publicvoidrunSqlBySpringUtils() throwsException {try{SqlSession sqlSession = sqlSessionFactory.openSession();Connection conn = sqlSession.getConnection();ClassPathResource rc = newClassPathResource("脚本.Sql", RunSqlDao.class);EncodedResource er = newEncodedResource(rc, "utf-8");ScriptUtils.executeSqlScript(conn, er);} catch(Exception e) {e.printStackTrace();throwe;}} | 
方法(1),脚本.Sql文件必须是ANSI的,否则执行到数据中汉字是乱码。
方法(2)解决了方法(1)的问题,完美了,喜欢的小伙伴们快拿去享用吧。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持快网idc。
相关文章
             猜你喜欢
        
        - 个人网站服务器域名解析设置指南:从购买到绑定全流程 2025-06-10
- 个人网站搭建:如何挑选具有弹性扩展能力的服务器? 2025-06-10
- 个人服务器网站搭建:如何选择适合自己的建站程序或框架? 2025-06-10
- 64M VPS建站:能否支持高流量网站运行? 2025-06-10
- 64M VPS建站:怎样选择合适的域名和SSL证书? 2025-06-10
			TA的动态
			
		
				- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
				您的支持,是我们最大的动力!				
			
		
        热门文章
        
    
    - 
            2025-05-25 22
- 
            2025-06-04 30
- 
            2025-05-27 37
- 
            2025-05-29 61
- 
            2025-06-04 69
		热门评论
	
	 
        
 
    		 
            	 
															 
         
         
        
 
                        