powershell 之数据库操作

#region 配置函数 c  
function c{  
    #====创建object  
    $o=new-object psobject  
 
    #-------数据库连接配置--------  
    $o|Add-Member -MemberType NoteProperty -Name t -Value 'mysql'         #数据库类型  
    $o|Add-Member -MemberType NoteProperty -Name h -Value 'localhost'     #主机地址  
    $o|Add-Member -MemberType NoteProperty -Name u -Value 'root'          #登录名  
    $o|Add-Member -MemberType NoteProperty -Name p -Value 'root'          #登录密码  
    $o|Add-Member -MemberType NoteProperty -Name d -Value 'monitor'       #认访问的数据库  
    $o|Add-Member -MemberType NoteProperty -Name c -Value 'utf8'          #编码  
    #--------expand--------  
 
    #--------expand--------  
 
    #====对传入参数进行验证并输出返回值  
    switch($args[0]){  
        't'{return $o.t;break}  
        'h'{return $o.h;break}  
        'u'{return $o.u;break}  
        'p'{return $o.p;break}  
        'd'{return $o.d;break}  
        'c'{return $o.c;break}  
        default{  
            Write-Warning "当前参数 $args 无效,请检查参数是否正确,可用参数及表示如下:"  
            write-host t : 表示数据库类型 -ForegroundColor Yellow  
            write-host h : 表示主机地址 -ForegroundColor Yellow  
            write-host u : 表示登录数据库的账号 -ForegroundColor Yellow  
            write-host p : 表示登录数据库的密码 -ForegroundColor Yellow  
            write-host d : 表示认访问的数据库名 -ForegroundColor Yellow  
            write-host d : 表示连接数据库所使用的字符集 -ForegroundColor Yellow  
            exit  
        }  
    }  
}  
#endregion  
 
#region 数据库操作函数 _odb_  
function _odb_  
{  
    param  
    (  
        $funName, #执行的函数名  
        $sql      #执行的sql脚本  
    )  
    #====从配置函数c中,获取配置信息  
    $dbtpye=c t  
    $server=c h  
    $uid=c u  
    $pwd=c p  
    $dbname=c d  
    $char=c c  
     
    #====验证数据库类型,创建数据库对象  
    switch($dbtpye){  
        'mssql'{  
            $conn = New-Object System.Data.sqlClient.sqlConnection  
            $cmd = new-object System.Data.sqlClient.sqlCommand  
            $sqlAdapter = New-Object system.Data.sqlClient.sqlDataAdapter  
            break  
        }  
        'MysqL'{  
            try{  
            [void][System.Reflection.Assembly]::LoadWithPartialName("MysqL.data")  
            }catch{Write-Warning '请安装MysqL连接组件mysql-connector-net-6.5.4'}  
            $conn = New-Object MysqL.Data.MysqLClient.MysqLConnection  
            $cmd = new-object MysqL.data.MysqLclient.MysqLcommand  
            $sqlAdapter = New-Object MysqL.Data.MysqLClient.MysqLDataAdapter  
            break  
        }  
    }  
    try{  
        $conn.ConnectionString="server=$server;uid=$uid;pwd=$PWD;database=$dbname;charset=$char"  
        $conn.open()  
    }  
    catch{  
        Write-warning '数据库连接错误!'  
        return $false  
    }  
    $cmd.Connection=$conn  
 
     
    #region用于写入、更新等无返回值操作 _exec_  
    function _exec_  
    {  
        $cmd.CommandText=$sql  
        [void]$cmd.ExecuteNonQuery()  
    }  
    #endregion  
     
    #region用于查询、有返回值操作 _get_  
    function _get_  
    {  
        $cmd.commandtext=$sql  
        $sqlAdapter.SelectCommand = $cmd  
        $DataSet = New-Object System.Data.DataSet  
        [void]$sqlAdapter.Fill($DataSet,"data")  
        return $dataset.tables['data']  
    }  
    #endregion  
 
    #判断传入值,并执行相应函数  
    switch($funName){  
        '_exec_'{_exec_;break}  
        '_get_'{_get_;break}  
    }  
    $conn.Close()  
}  
#endregion

调用

_odb_ _get_ sql    有返回值
或
_odb_ _exec_ sql   无返回值

相关文章

这篇文章主要介绍“hive和mysql的区别是什么”,在日常操作中...
这篇“MySQL数据库如何改名”文章的知识点大部分人都不太理解...
这篇文章主要介绍“mysql版本查询命令是什么”的相关知识,小...
本篇内容介绍了“mysql怎么修改字段的内容”的有关知识,在实...
这篇文章主要讲解了“mysql怎么删除unique约束”,文中的讲解...
今天小编给大家分享一下mysql怎么查询不为空的字段的相关知识...