使用Powershell管理Linux 下的 SQL Server-阿里云开发者社区

开发者社区> 技术小阿哥> 正文

使用Powershell管理Linux 下的 SQL Server

简介:
+关注继续查看

我们上一篇文章介绍了在Centos 7.3下安装及配置 SQL Server,今天我们主要介绍的是如何在Windows下使用Powershell来管理Linux下的SQL Server,其实说到Powershell大家都已经很熟悉了,Powershell不止是命令集合也是批量程序,可以很好的协助管理员提高日常的运维工作,但是微软的Powershell有一个毛病就是不同的服务需要安装不同的Powershell,对于Lync下的Shell、Exchange Shell和系统自带的Powershell就有很大的区别,另外还有今天我们介绍的内容使用Powershell管理SQL Server,需要安装单独的SSMS才可以使用powershell导出sql的模块,如果使用系统再带的Powershell导入sqlserver模块的话会提示错误,希望后期微软能彻底解决这个问题。好了不多说了,言归正传,开始我们今天的介绍;

我们首先得知,SQL Powershell 包含在 SQL Server Manager Studio上的,所以我们只需要下载对应的SSMS即可;下载链接

https://docs.microsoft.com/en-us/sql/ssms/sql-server-management-studio-ssms

clipboard

安装步骤我们跳过了

clipboard

下载后安装我们就可以使用系统自带的Powershell进行管理了(前提我们已经安装了刚才下载的SSMS工具才可以使用系统自带的Powershell)

clipboard

clipboard

我们首先需要导入sql的模块

1
import-module sqlserver

clipboard

验证SQLServer模块状态

1
Get-Module -Name SqlServer

clipboard

接下来我们使用powershell链接SQL Server 然后获取server信息

1
2
3
4
5
6
7
8
9
10
11
12
13
# Prompt for credentials to login into SQL Server
$serverInstance = "<your_server_instance>"
$credential = Get-Credential
# Load the SMO assembly and create a Server object
[System.Reflection.Assembly]::LoadWithPartialName('Microsoft.SqlServer.SMO') | out-null
$server = New-Object ('Microsoft.SqlServer.Management.Smo.Server') $serverInstance
# Set credentials
$server.ConnectionContext.LoginSecure=$false
$server.ConnectionContext.set_Login($credential.UserName)
$server.ConnectionContext.set_SecurePassword($credential.Password)
# Connect to the Server and get a few properties
$server.Information | Select-Object Edition, HostPlatform, HostDistribution | Format-List
# done

我们为了方便我们使用Powershell ISE进行执行脚本

clipboard

然后我们开始编写powershell脚本;

clipboard

执行提示需要输入SQL Server的账户及密码

clipboard

我的执行结果信息显示不全,应该显示系统的版本:比如linux等。

clipboard

最后,我们再说一下,如何使用powershell管理SQL Server on Linux呢

首先是通过在powershell下导入sql的模块

1
import-module sqlserver

然后使用powershell连接sqlserver,连接sql server的powershell我们可以使用以下方法

1
2
3
4
5
6
7
8
9
10
11
12
13
# Prompt for credentials to login into SQL Server
$serverInstance = "<your_server_instance>"
$credential = Get-Credential
# Load the SMO assembly and create a Server object
[System.Reflection.Assembly]::LoadWithPartialName('Microsoft.SqlServer.SMO') | out-null
$server = New-Object ('Microsoft.SqlServer.Management.Smo.Server') $serverInstance
# Set credentials
$server.ConnectionContext.LoginSecure=$false
$server.ConnectionContext.set_Login($credential.UserName)
$server.ConnectionContext.set_SecurePassword($credential.Password)
# Connect to the Server and get a few properties
$server.Information
# done

输入SQL Server的账户及密码验证一下即可

clipboard

执行后我们就可以看见操作结果

clipboard

clipboard

最后我们就可以使用powershell操作sqlserver了

操作命令跟我们在本地的命令是一样的;sqlcmd

clipboard

其实通过想通过powershell连接SQL Server还有另外一种方法--这样的方法是最常见、也是最方便的使用方法,其实Linux下的使用mysql也是同样的方法,只是参数不同而已

首先是导入sql server模块

1
2
import-module sqlserver
sqlcmd -S 192.168.5.20 -U sa -P 的方式也是可以的

clipboard

其实接下来的所有操作跟我们在windows上的使用powershell是一样的

同样使用帮助命令进行操作

1
get-help sqlserver

clipboard

因为需要下载安装一下帮助命令所以比较慢,在此我就不等了

接下来我们使用powershell管理一下我们的SQL数据比如我们查看当前系统有哪些数据库

1
2
select name from sys.databases;
go

clipboard

接下来我们创建一个数据库,然后插入数据

1
2
create database xll;
go

clipboard

然后我们选择数据库

1
2
use xll;
go

clipboard

接下来我们创建一张表,在刚才选择的数据库下

1
2
create table xllinfo (id int ,name varchar(50),quantity int);
go

clipboard

我们查看当前的表信息

1
2
select * from xllinfo;
go

clipboard

然后我们给表中插入数据

1
2
3
INSERT INTO testtb VALUES (1, 'zs', 27);
INSERT INTO testtb VALUES (1, 'ls', 29);
go

clipboard

我们继续查询

1
2
select * from xllinfo;
go

clipboard

接下来我们在SSMS下也确认一下

clipboard

clipboard



本文转自 高文龙 51CTO博客,原文链接:http://blog.51cto.com/gaowenlong/1903554,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
sqlServer对内存的管理
简介     理解SQL Server对于内存的管理是对于SQL Server问题处理和性能调优的基本,本篇文章讲述SQL Server对于内存管理的内存原理。   二级存储(secondary storage)     对于计算机来说,存储体系是分层级的。
858 0
PostgreSQL 10.1 手册_部分 III. 服务器管理_第 29 章 监控磁盘使用
第 29 章 监控磁盘使用 目录 29.1. 判断磁盘用量 29.2. 磁盘满失败 本章讨论如何监控PostgreSQL数据库系统的磁盘使用情况。 本文转自PostgreSQL中文社区,原文链接:第 29 章 监控磁盘使用
707 0
PostgreSQL 10.1 手册_部分 III. 服务器管理_第 29 章 监控磁盘使用_29.1. 判断磁盘用量
29.1. 判断磁盘用量 每个表都有一个主要的堆磁盘文件,大多数数据都存储在其中。如果一个表有着可能会很宽(尺寸大)的列, 则另外还有一个TOAST文件与这个表相关联, 它用于存储因为太宽而不能存储在主表里面的值(参阅第 66.2 节)。
851 0
PostgreSQL 10.1 手册_部分 III. 服务器管理_第 29 章 监控磁盘使用_29.2. 磁盘满失败
29.2. 磁盘满失败 一个数据库管理员最重要的磁盘监控任务就是确保磁盘不会写满。一个写满了的数据磁盘可能不会导致数据的崩溃,但它肯定会让系统变得不可用。如果保存 WAL 文件的磁盘变满,会发生数据库服务器致命错误并且可能发生关闭。
1089 0
通过Windows PowerShell远程管理计算机(精简版)
现在你手中有一台server(主控端),你打算通过主控端远程管理多台server(被控端)。这个过程可以通过Windows PowerShell来完成。 首先在被控端上以管理员权限打开PowerShell,输入以下命令(其中XXX是IP中的字段,TrustedHosts填写的是主控端的IP地址。
733 0
Sql Server用管理器建表后如何查看创建表的语句
右键建的那个表--&gt;编写表脚本为--&gt;CREATE到--&gt;新建编辑器查看窗口,就会出现新建表的SQL语句.
1555 0
13694
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载