【问题标题】:Can I Query a SQL Server Database from Azure Synapse Without Using a Pipeline?我可以在不使用管道的情况下从 Azure Synapse 查询 SQL Server 数据库吗?
【发布时间】:2021-08-04 01:15:30
【问题描述】:

是否可以使用 Pyspark+SQL 从 Azure 突触工作簿对 SQL 服务器数据库执行“SELECT”语句查询?

我能够将数据从 SQL Server 数据库引入 Azure Synapse 的唯一方法是创建集成管道。

我是使用 Azure Synapse 和 Apache Spark 的新手,因此非常感谢您提供的任何建议。

【问题讨论】:

    标签: azure-databricks azure-synapse


    【解决方案1】:

    这在理论上是可行的,我已经使用 Azure SQL 数据库进行了测试。我不是 100% 确定它可以与 SQL Server 一起使用。这需要网络安全是正确的,并且两个数据库之间应该有一条视线。例如,您在 Azure 中的 SQL Server 是否在同一个 vnet 或对等 vnet 上?

    Synapse 笔记本中的一个简单示例:

    import pyodbc
    
    sqlQuery = "select @@version v"
    
    try:
    
      conn = pyodbc.connect( 'DRIVER={ODBC Driver 17 for SQL Server};'
                            'SERVER=someSynapseDB.sql.azuresynapse.net;'
                            'DATABASE=yourDatabaseName;UID=someReadOnlyUser;'
                            'PWD=youWish;', autocommit = True )
    
      cursor = conn.cursor()
      cursor.execute(sqlQuery) 
    
      row = cursor.fetchone()
      while row:
        print(row[0])
        row = cursor.fetchone()
    
    except:
      raise
    
    finally:
      # Tidy up
      cursor.close()
      conn.close()
    

    我的结果:

    受 Jovan Popovic 这篇文章的启发:

    https://techcommunity.microsoft.com/t5/azure-synapse-analytics/query-serverless-sql-pool-from-an-apache-spark-scala-notebook/ba-p/2250968

    只是出于兴趣,您在笔记本中这样做有什么特别的原因吗? Synapse 管道是一种非常好的方法,典型的模式是在数据湖中暂存数据,例如是否有一些特殊的功能需要使用笔记本?

    【讨论】:

    • 嘿 wBob,感谢您的解决方案。 SQL Server 将位于托管实例上。我确实喜欢通过管道摄取数据,但我想避免在将任何数据复制到突触时产生成本。我想如果我使用突触工作簿进行任何编排,从长远来看,这不一定重要。再次感谢你:)
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2021-06-10
    • 1970-01-01
    • 2017-11-03
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多