在工作中我们常常需要使用powershell连接Oracle数据库。
但是在百度找到的代码都是很老的,而且还需要oracle数据库连接客户端。查找一番后发现Oracle官方早已经发布了对.net官方连接库,高效简单。
连接库地址:
https://www.oracle.com/technetwork/developer-tools/visual-studio/overview/index.html
创新互联服务项目包括裕安网站建设、裕安网站制作、裕安网页制作以及裕安网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,裕安网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到裕安省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!
我写的小小demo:
官方文档:
https://docs.oracle.com/cd/E11882_01/win.112/e23174/client.htm#ODPNT0008
用例:
$AssemblyFile = "Oracle.ManagedDataAccess.dll"
[Reflection.Assembly]::LoadFile($AssemblyFile)
$username = "xx"
$password = "xx"
$datasource = "192.168.xx.xx/dbname"
$sql = "SELECT * from xxdb"
$connectionnectionString = 'User Id=' + $username + ';Password=' + $password + ';Data Source=' + $datasource
$connectionnection = New-Object Oracle.ManagedDataAccess.Client.OracleConnection($connectionnectionString)
$connectionnection.open()
$command=$connection.CreateCommand()
$command.CommandText=$sql
$da = New-Object Oracle.ManagedDataAccess.Client.OracleDataAdapter($command)
$builder=New-Object Oracle.ManagedDataAccess.Client.OracleCommandBuilder($da) #用来更新数据库
$ds = New-Object system.Data.DataSet [void]$da.fill($ds,"xxdb")
foreach($row in $ds.Tables["xxdb"] )
{
$row["xxFLAG"]="1"
$da.Update($ds,"xxdb") #更新数据库
}
$connection.close()