Linux下使用python脚本执行BCP导入导出方式
作者:我是李超人
这篇文章主要介绍了Linux下使用python脚本执行BCP导入导出方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
使用python脚本执行BCP导入导出
创建一张表Test001
create table Test001( ID int, age int, name varchar(50) )
再创建一张表Test002
create table Test002( Id int, age int, name varchar(50), addr varchar(50) )
插入三条数据
insert into Test002 values(1,25,'Bob','New York') insert into Test002 values(2,22,'Mary','HongKong') insert into Test002 values(3,25,'David','London')

Python脚本
#!/usr/bin/env python
#coding=utf-8
import pymssql
import subprocess
class testBcp:
def getConn(self):
server = "192.168.1.1"
user= "sa"
password = "testBcp@1"
db = "TESTBCP"
# 打开数据库连接
conn = pymssql.connect(server,user,password,db)
return conn
def BCPExe(self,bcpString):
conn = self.getConn()
# 使用cursor()方法获取操作游标
cursor = conn.cursor()
result_code = subprocess.call(bcpString, shell=True)
print(result_code)
if __name__=="__main__":
tB=testBcp()
BCPout="bcp 'select ID,age,name from TESTBCP.dbo.Test002' queryout tempData.csv -c -U sa -P testBcp@1 -S 192.168.1.1"
BCPin='bcp TESTBCP.dbo.Test001 in tempData.csv -c -U sa -P testBcp@1 -S 192.168.1.1'
#select ID,age,name from TESTBCP.dbo.Test002 使用sql语句查询出结果集写入tempData.csv文件中
tB.BCPExe(BCPout)
#将文件中的数据写入表test001中
tB.BCPExe(BCPin)以上python脚本首先从test002中将数据查询出来,将结果集使用BCP写入tempData.csv文件中,然后再使用BCP将文件中的数据写入表test001中。
此时可以看到test001中现在已经有数据了。

注意:
如果文件中的数据源是来自于多个渠道
那么在拼接字符串的时候切记每个字段要使用’\t’隔开
否则会由于文件中数据格式不正确导致BCP写入操作失败
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
