从 SSMS 连接到 Cloud SQL for SQL Server

本页面介绍如何创建和连接到 SQL Server 实例,并使用 Google Cloud 控制台和客户端执行基本的 SQL 操作。如果您及时完成本快速入门中的步骤(包括清理),那么在此期间所创建资源的费用通常不会超过 1 美元。

准备工作

  1. 登录您的 Google Cloud 账号。如果您是 Google Cloud 新手,请创建一个账号来评估我们的产品在实际场景中的表现。新客户还可获享 $300 赠金,用于运行、测试和部署工作负载。
  2. 在 Google Cloud Console 中的项目选择器页面上,选择或创建一个 Google Cloud 项目

    转到“项目选择器”

  3. 确保您的 Google Cloud 项目已启用结算功能

  4. 在 Google Cloud Console 中的项目选择器页面上,选择或创建一个 Google Cloud 项目

    转到“项目选择器”

  5. 确保您的 Google Cloud 项目已启用结算功能

  6. 启用必要的 Google Cloud API。

    控制台

    在 Google Cloud 控制台中,转到 API 页面。

    转到“API”

    启用 Cloud SQL Admin API。

    gcloud

    点击以下按钮打开 Cloud Shell,以通过命令行直接在浏览器中访问 Google Cloud 资源。Cloud Shell 可用于运行本快速入门中介绍的 gcloud 命令。

    打开 Cloud Shell

    按照以下方式使用 Cloud Shell 运行 gcloud services enable 命令,以启用本快速入门所需的 API。

    gcloud services enable sqladmin.googleapis.com

    此命令会启用以下 API:

    • Cloud SQL Admin API

创建 Cloud SQL 实例

在本快速入门中,您将使用 Google Cloud 控制台。如需使用 gcloud CLI、cURL 或 PowerShell,请参阅创建实例

  1. 在 Google Cloud 控制台中,转到 Cloud SQL 实例页面。

    转到“Cloud SQL 实例”

  2. 点击创建实例
  3. 点击选择 SQL Server (Choose SQL Server)。
  4. 实例 ID 部分输入 myinstance
  5. sqlserver 用户输入密码。
  6. 点击创建

    您会返回到实例列表。您可以立即点击新实例以查看详细信息,但该实例只能在初始化并启动之后才可用于其他操作。

    :在此示例中,将使用默认设置(包括公共 IP 地址)创建实例。

使用 SQL Server Management Studio 连接到实例

  1. 可选:如果您运行的是 SQL Server 的本地实例,请先停止该实例,然后再连接到 Cloud SQL 实例。否则,您可能会遇到 address already in use 之类的错误。
  2. 安装 gcloud CLIgcloud CLI 提供 gcloud CLI,以与 Cloud SQL 和其他 Google Cloud 服务进行交互。gcloud CLI 使用 Admin API 访问 Cloud SQL,因此您必须先启用 Admin API,然后才能使用 gcloud CLI 访问 Cloud SQL。
  3. 在 bash shell 命令提示符或 Windows PowerShell 中,运行以下命令来初始化 gcloud CLI:
      gcloud init
      
  4. 运行以下命令以对 gcloud CLI 进行身份验证:
      gcloud auth login
      
  5. 下载并安装 Cloud SQL Auth 代理(请参阅安装 Cloud SQL Auth 代理)。记下 Cloud SQL Auth 代理的位置,因为您将在下一步中运行 Cloud SQL Auth 代理。
  6. 使用 bash shell 命令提示符(或使用 Windows PowerShell)运行 Cloud SQL Auth 代理。具体而言,运行以下命令,将 Instance-connection-name 替换为 Google Cloud 控制台中您的实例“概览”标签页内的相应值:
      ./cloud-sql-proxy INSTANCE_CONNECTION_NAME
      

如需详细了解如何安装和使用 Cloud SQL Auth 代理,请参阅 Cloud SQL Auth 代理简介

如下一部分所述,现在,您可以使用 SSMS 和本地主机 IP 地址连接到 SQL Server 实例。

使用 SSMS 对象资源管理器建立连接

  1. 在 SSMS 中,从文件菜单中选择连接对象资源管理器

    选择对象资源管理器

  2. 连接对话框中指定以下值:

    1. 对于“服务器类型”,选择数据库引擎
    2. 对于“服务器名称”,输入 127.0.0.1 作为 SQL Server 实例的 IP 地址。
    3. 对于“身份验证”,输入 SQL Server 身份验证
    4. 对于“登录名”,输入 sqlserver
    5. 对于“密码”,输入创建实例时所用的密码。
  3. 点击连接按钮。

创建数据库并上传数据

  1. 在 SSMS 对象资源管理器窗口中,右键点击实例下的数据库节点,然后选择新建数据库

    选择新数据库

  2. 对于数据库名称,输入 testdb,然后点击确定按钮。

    在对话框中输入数据库名称 testdb

  3. 在新创建的 testdb 数据库下,右键点击节点,然后选择新建 > 表

    表”" class="l10n-absolute-url-src screenshot" alt="The New menu in the testdb database." l10n-attrs-original-order="src,alt,alt,class" src="https://cloud.google.com/static/sql/images/quickstart-sql-server-3.png" />

  4. 创建表对话框中输入以下值:

    1. 属性窗口中,对于标识 > 名称,输入 guestbook
    2. 对于第一个列名称,输入 entryID,将其“数据类型”设置为 int,然后取消选中允许 Null 值 (Allow Nulls) 复选框。
      1. 列属性 (Column Properties) 窗口中,展开标识规范 (Identity Specification) 项,并将 (Is Identity) 设置为
    3. 对于第二个列名称,输入 guestname,并将其“数据类型”设置为“varchar(255)”。
    4. 对于第三个列名称,输入 content,并将其“数据类型”设置为“varchar(255)”。

    为表输入值

  5. 点击文件菜单,然后选择保存 guestbook

    保存 guestbook 表

  6. 右键点击数据库下的 testdb 表,然后选择新建查询

    对于 testdb,选择“新建查询”

  7. SQL 查询文本窗口中输入以下两个 INSERT 语句,然后点击执行按钮。

    INSERT INTO guestbook (guestName, content) values ('first guest', 'I got here!');
    
    INSERT INTO guestbook (guestName, content) values ('second guest', 'Me too!');
    

    例如:输入两个插入语句

  8. 对象资源管理器 (Object Explorer) 窗口中,展开数据库 > testdb 项下的项。右键点击 dbo.guestbook 表,然后选择选择前 1000 行 (Select Top 1000 Rows)。

    选择前面的行

您插入的两条记录显示为结果,以及用于查询记录的 SQL SELECT 语句。

查看查询结果

清理

为避免因本页中使用的资源导致您的 Google Cloud 账号产生费用,请按照以下步骤操作。

  1. 在 Google Cloud 控制台中,转到 Cloud SQL 实例页面。

    转到“Cloud SQL 实例”

  2. 选择 myinstance 实例以打开实例详情页面。
  3. 在页面顶部的图标栏中,点击删除
  4. 删除实例窗口中,输入实例的名称,然后点击删除

可选的清理步骤

如果您没有使用在本快速入门中启用的 API,则可以将其停用。

  • 在本快速入门中启用的 API:
    • Cloud SQL Admin API
  1. 在 Google Cloud 控制台中,转到 API 页面。

    转到“API”

  2. 选择 Cloud SQL Admin API,然后点击停用 API 按钮。

后续步骤