Hi @Simon Zhang
I'm glad that you were able to resolve your issue and thank you for posting your solution so that others experiencing the same thing can easily reference this! Since the Microsoft Q&A community has a policy that "The question author cannot accept their own answer. They can only accept answers by others ", I'll repost your solution in case you'd like to accept the answer.
Issue: I want to use Pyspark datawrite.write method to write dataframe to sql azure database with linked service. How can I achieve it?
Solution:
Here is the answer I got:
server = 'sql server name'
Port = 1433
Database = "databaseName"
jdbcUrl = f"jdbc:sqlserver://{server}:{Port};databaseName={Database};encrypt=true;trustServerCertificate=false;hostNameInCertificate=*.database.windows.net;loginTimeout=30"
sql_access_token=TokenLibrary.getConnectionString("linked service name")
conn_Prop = {
"driver" : "com.microsoft.sqlserver.jdbc.SQLServerDriver",
"accessToken" : sql_access_token
}
restapiJson.write\
.mode("overwrite")\
.option("truncae","true")\
.option("url",jdbcUrl)\
.option("dbtable",dbtable)\
.jdbc(jdbcUrl, dbtable, properties={"driver" : "com.microsoft.sqlserver.jdbc.SQLServerDriver","accessToken" : sql_access_token})
If I missed anything please let me know and I'd be happy to add it to my answer, or feel free to comment below with any additional information.
Hope this helps. Do let us know if you any further queries.
If this answers your query, do click Accept Answer
and **Yes
**for was this answer helpful. And, if you have any further query do let us know.