python連接sql server數據庫實現增刪改查


python連接sql server數據庫實現增刪改查

  簡述

  python連接微軟的sql server數據庫用的第三方模塊叫做pymssql(document:http://www.pymssql.org/en/stable/index.html)。在官方文檔可以看到,pymssql是基於_mssql模塊做的封裝,是為了遵守python的DBAPI規范接口. 兩者之間的關系如下圖:

  1.使用pymssql連接sql server數據庫並實現數據庫基本操作(官方api http://www.pymssql.org/en/stable/ref/pymssql.html )

1)基本語法

復制代碼
import pymssql 

server = "187.32.43.13"    # 連接服務器地址
user = "root"         # 連接帳號
password = "1234"      # 連接密碼

conn = pymssql.connect(server, user, password, "連接默認數據庫名稱")  #獲取連接
cursor = conn.cursor() # 獲取光標

# 創建表 cursor.execute(""" IF OBJECT_ID('persons', 'U') IS NOT NULL DROP TABLE persons CREATE TABLE persons ( id INT NOT NULL, name VARCHAR(100), salesrep VARCHAR(100), PRIMARY KEY(id) ) """)  

# 插入多行數據 cursor.executemany( "INSERT INTO persons VALUES (%d, %s, %s)", [(1, 'John Smith', 'John Doe'), (2, 'Jane Doe', 'Joe Dog'), (3, 'Mike T.', 'Sarah H.')]) # 你必須調用 commit() 來保持你數據的提交如果你沒有將自動提交設置為true conn.commit()
# 查詢數據 cursor.execute('SELECT * FROM persons WHERE salesrep=%s', 'John Doe')

# 遍歷數據(存放到元組中) 方式1 row = cursor.fetchone() while row: print("ID=%d, Name=%s" % (row[0], row[1])) row = cursor.fetchone()
# 遍歷數據(存放到元組中) 方式2
for row in cursor:
print('row = %r' % (row,))


# 遍歷數據(存放到字典中)
# cursor = conn.cursor(as_dict=True) # # cursor.execute('SELECT * FROM persons WHERE salesrep=%s', 'John Doe') # for row in cursor: # print("ID=%d, Name=%s" % (row['id'], row['name'])) # # conn.close()
# 關閉連接
conn.close()

# 注:在任何時候,在一個連接下,一次正在執行的數據庫操作只會出現一個cursor對象

復制代碼

2)同時,如果你可以使用另一種語法:with 來避免手動關閉cursors和connection連接

復制代碼
import pymssql 

server = "187.32.43.13"    # 連接服務器地址
user = "root"         # 連接帳號
password = "1234"      # 連接密碼

with pymssql.connect(server, user, password, "你的連接默認數據庫名稱") as conn:
    with conn.cursor(as_dict=True) as cursor:   # 數據存放到字典中
        cursor.execute('SELECT * FROM persons WHERE salesrep=%s', 'John Doe')
        for row in cursor:
            print("ID=%d, Name=%s" % (row['id'], row['name']))
復制代碼

3)調用存儲過程:

復制代碼
with pymssql.connect(server, user, password, "tempdb") as conn:
    with conn.cursor(as_dict=True) as cursor:
        cursor.execute("""
        CREATE PROCEDURE FindPerson
            @name VARCHAR(100)
        AS BEGIN
            SELECT * FROM persons WHERE name = @name
        END
        """)
        cursor.callproc('FindPerson', ('Jane Doe',))
        for row in cursor:
            print("ID=%d, Name=%s" % (row['id'], row['name']))
復制代碼

 

    2.使用_mssql連接sql server數據庫並實現操作(官方api  http://www.pymssql.org/en/stable/ref/_mssql.html)

1)基本語法:

復制代碼
import _mssql
# 創建連接
conn = _mssql.connect(server='SQL01', user='user', password='password', \
    database='mydatabase')
print(conn.timeout)
print(conn.login_timeout) # 創建table conn.execute_non_query('CREATE TABLE persons(id INT, name VARCHAR(100))') # insert數據 conn.execute_non_query("INSERT INTO persons VALUES(1, 'John Doe')") conn.execute_non_query("INSERT INTO persons VALUES(2, 'Jane Doe')") # 查詢操作 conn.execute_query('SELECT * FROM persons WHERE salesrep=%s', 'John Doe') for row in conn: print "ID=%d, Name=%s" % (row['id'], row['name']) #查詢數量count() numemployees = conn.execute_scalar("SELECT COUNT(*) FROM employees") # 查詢一條數據 employeedata = conn.execute_row("SELECT * FROM employees WHERE id=%d", 13) # 帶參數查詢的幾個例子: conn.execute_query('SELECT * FROM empl WHERE id=%d', 13) conn.execute_query('SELECT * FROM empl WHERE name=%s', 'John Doe') conn.execute_query('SELECT * FROM empl WHERE id IN (%s)', ((5, 6),)) conn.execute_query('SELECT * FROM empl WHERE name LIKE %s', 'J%') conn.execute_query('SELECT * FROM empl WHERE name=%(name)s AND city=%(city)s', \ { 'name': 'John Doe', 'city': 'Nowhere' } ) conn.execute_query('SELECT * FROM cust WHERE salesrep=%s AND id IN (%s)', \ ('John Doe', (1, 2, 3))) conn.execute_query('SELECT * FROM empl WHERE id IN (%s)', (tuple(xrange(4)),)) conn.execute_query('SELECT * FROM empl WHERE id IN (%s)', \ (tuple([3, 5, 7, 11]),)) #關閉連接 conn.close()
復制代碼

 

pymssql托管在Github上:https://github.com/pymssql


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM