SQL Server通过BCP进行大批量数据导入导出
预置条件:
使用sa帐号登录SQL Server Management Studio,右键点击安全性-登录名-数据库用户名属性,设置服务器角色为sysadmin。
删除已存在的存储过程
String JOB_BCP_DELETE_SQL = “IF EXISTS (SELECT * FROM sys.objects WHERE name = 'PROCEDURE_BCP_OUT' AND type in (N'P', N'PC'))\n DROP PROCEDURE PROCEDURE_BCP_OUT \n”; pre = conn.prepareStatement(JOB_BCP_DELETE_SQL); pre.execute();
创建存储过程
String sql = "set @sql = N'BCP ' + @tableName + ' out ' + @filePath + ' -c -t -U \"' + @userName + '\" -P \"' + @password + '\" -S \"' + @dbIp + '\"'\n"; StringBuffer createSqlBuf = new StringBuffer(); createSqlBuf.append("CREATE PROCEDURE PROCEDURE_BCP_OUT \n") .append("@dbIp nvarchar(256),\n") .append("@userName nvarchar(256),\n") .append("@password nvarchar(256),\n") .append("@tableName nvarchar(256),\n") .append("@filePath nvarchar(256)\n") .append("AS\n") .append("BEGIN\n") .append("EXEC master.sys.sp_configure 'show advanced options', 1\n") .append("RECONFIGURE\n") .append("EXEC master.sys.sp_configure 'xp_cmdshell', 1\n") .append("RECONFIGURE\n") .append("declare @sql nvarchar(256)\n") .append(sql) .append("EXEC master..xp_cmdshell @sql\n") .append("EXEC master.sys.sp_configure 'show advanced options', 1\n") .append("RECONFIGURE\n") .append("EXEC master.sys.sp_configure 'xp_cmdshell', 0\n") .append("RECONFIGURE\n") .append("END"); String createSql = createSqlBuf.toString(); pre = conn.prepareStatement(createSql); pre.execute();
执行存储过程
StringBuffer execSqlBuf = new StringBuffer(); execSqlBuf.append("EXECUTE PROCEDURE_BCP_OUT \n") .append("@dbIp=?, ").append("@userName=?, ").append("@password=?, ") .append("@tableName=?, ").append("@filePath=?"); String execSql = execSqlBuf.toString(); pre = conn.prepareStatement(execSql); pre.setString(1, dbIp); pre.setString(2, dbUserName); pre.setString(3, dbPassword); pre.setString(4, tableName); pre.setString(5, file); pre.execute();
【推荐】博客园的心动:当一群程序员决定开源共建一个真诚相亲平台
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】Flutter适配HarmonyOS 5知识地图,实战解析+高频避坑指南
【推荐】开源 Linux 服务器运维管理面板 1Panel V2 版本正式发布
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步