您当前的位置:首页 > 电脑百科 > 数据库 > SQL Server

python如何操作SQL Server数据库?

时间:2023-08-15 16:39:45  来源:今日头条  作者:运维开发木子李

当使用Python/ target=_blank class=infotextkey>Python与SQL Server进行交互时,可以使用不同的库和模块。以下是25个示例代码,用于演示如何使用Python与SQL Server进行连接、查询、插入、更新和删除等操作:

使用pyodbc库连接到SQL Server:

import pyodbc

conn = pyodbc.connect('Driver={SQL Server};'
                      'Server=server_name;'
                      'Database=database_name;'
                      'UID=username;'
                      'PWD=password')

cursor = conn.cursor()

查询数据库中的所有表:

cursor.execute("SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_TYPE='BASE TABLE'")

tables = cursor.fetchall()

for table in tables:
    print(table.TABLE_NAME)

查询表中的所有列:

cursor.execute("SELECT COLUMN_NAME FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME='table_name'")

columns = cursor.fetchall()

for column in columns:
    print(column.COLUMN_NAME)

执行SELECT查询并获取结果:

cursor.execute("SELECT * FROM table_name")

rows = cursor.fetchall()

for row in rows:
    print(row)

执行带有参数的SELECT查询:

param = 'example'

cursor.execute("SELECT * FROM table_name WHERE column_name=?", param)

rows = cursor.fetchall()

for row in rows:
    print(row)

插入新记录:

cursor.execute("INSERT INTO table_name (column1, column2) VALUES (?, ?)", value1, value2)

conn.commit()

更新记录:

cursor.execute("UPDATE table_name SET column1=? WHERE column2=?", new_value, condition_value)

conn.commit()

删除记录:

cursor.execute("DELETE FROM table_name WHERE column=? AND column2=?", value1, value2)

conn.commit()

使用事务进行批量插入:

data = [('value1', 'value2'), ('value3', 'value4')]

cursor.execute("BEGIN TRANSACTION")

try:
    for row in data:
        cursor.execute("INSERT INTO table_name (column1, column2) VALUES (?, ?)", row)

    conn.commit()
    print("插入成功")
except:
    conn.rollback()
    print("插入失败")

创建新表:

cursor.execute("CREATE TABLE table_name (column1 datatype, column2 datatype)")

conn.commit()

删除表:

cursor.execute("DROP TABLE table_name")

conn.commit()

使用事务进行多个操作:

cursor.execute("BEGIN TRANSACTION")

try:
    # 执行多个SQL语句
    # ...

    conn.commit()
    print("操作成功")
except:
    conn.rollback()
    print("操作失败")

执行存储过程:

cursor.execute("{CALL stored_procedure_name}")

rows = cursor.fetchall()

for row in rows:
    print(row)

获取查询结果的列名:

columns = [column[0] for column in cursor.description]

print(columns)

使用pandas库将查询结果转换为DataFrame:

import pandas as pd

df = pd.read_sql_query("SELECT * FROM table_name", conn)

print(df)

使用WHERE子句进行条件查询:

param = 'example'

cursor.execute("SELECT * FROM table_name WHERE column_name=?", param)

rows = cursor.fetchall()

for row in rows:
    print(row)

使用ORDER BY对结果进行排序:

cursor.execute("SELECT * FROM table_name ORDER BY column_name ASC")

rows = cursor.fetchall()

for row in rows:
    print(row)

使用LIMIT限制查询结果的数量:

cursor.execute("SELECT * FROM table_name LIMIT 10")

rows = cursor.fetchall()

for row in rows:
    print(row)

使用JOIN进行表的连接查询:

cursor.execute("SELECT * FROM table1 INNER JOIN table2 ON table1.column = table2.column")

rows = cursor.fetchall()

for row in rows:
    print(row)

使用GROUP BY进行分组查询:

cursor.execute("SELECT column, COUNT(*) FROM table_name GROUP BY column")

rows = cursor.fetchall()

for row in rows:
    print(row)

使用HAVING进行分组后的条件筛选:

cursor.execute("SELECT column, COUNT(*) FROM table_name GROUP BY column HAVING COUNT(*) > 10")

rows = cursor.fetchall()

for row in rows:
    print(row)

使用SUM、AVG、MIN、MAX等聚合函数:

cursor.execute("SELECT SUM(column), AVG(column), MIN(column), MAX(column) FROM table_name")

rows = cursor.fetchall()

for row in rows:
    print(row)

执行事务中的ROLLBACK:

conn.rollback()

关闭游标和数据库连接:

cursor.close()
conn.close()Python

处理异常错误:

try:
    # 执行SQL语句
    # ...
except Exception as e:
    print("发生错误:", e)

这些示例代码展示了如何使用Python与SQL Server进行交互的一些常见操作。您可以根据自己的需求和具体情况进行修改和扩展。



Tags:SQL Server   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
使用 Python 连接 SQL Server 数据库并实时读取数据?
实时读取SQL Server数据库表并进行处理是一个常见的需求。在Python中,可以使用pyodbc库来连接SQL Server数据库,并使用pandas库来进行数据处理。下面是一个实战示例,演示如何实...【详细内容】
2023-12-28  Search: SQL Server  点击:(91)  评论:(0)  加入收藏
数据库迁移:从 SQL Server 到 PostgreSQL
作者 | 何蔚一、背景在这个数字化时代,企业的复杂业务逻辑运转需要依赖复杂的业务服务来完成。这些业务服务通常会经历变更、拆分、合并和上云等过程,最终与一些商业软件和云...【详细内容】
2023-11-29  Search: SQL Server  点击:(235)  评论:(0)  加入收藏
SQL Server 百万数据查询优化技巧三十则
互联网时代的进程越走越深,使用MySQL的人也越来越多,关于MySQL的数据库优化指南很多,而关于SQL SERVER的T-SQL优化指南看上去比较少,近期有学习SQLSERVER的同学问到SQL SERVER数...【详细内容】
2023-11-28  Search: SQL Server  点击:(338)  评论:(0)  加入收藏
如何解决SQL Server数据库备份过程中检测到的日志损坏问题
译者 | 李睿日志损坏问题通常发生在对事务日志进行备份的时候。其错误是这样描述的:“消息26019,级别16,状态1,第1行BACKUP在数据库日志中检测到损坏。有关详细信息,请查看错误日...【详细内容】
2023-11-08  Search: SQL Server  点击:(289)  评论:(0)  加入收藏
如何在 SQL Server 中备份和恢复数据库
在SQL Server中,数据库可以存储在不同的文件和文件组中。如果您的数据库较小(100 MB 或更少),则无需过多担心文件和文件组。但如果您有一个大型数据库(数 GB 或 TB),将数据分离到不...【详细内容】
2023-09-05  Search: SQL Server  点击:(267)  评论:(0)  加入收藏
linux上SQL Server 配置管理器的使用
概述我们知道Windows平台上的SQL Server 配置管理器是一个图形工具,用于管理与 SQL Server 关联的服务、配置 SQL Server 使用的网络协议以及管理 SQL Server 客户端计算机的...【详细内容】
2023-08-24  Search: SQL Server  点击:(306)  评论:(0)  加入收藏
Linux 上 SQL Server 配置管理器的使用
概述我们知道Windows平台上的SQL Server 配置管理器是一个图形工具,用于管理与 SQL Server 关联的服务、配置 SQL Server 使用的网络协议以及管理 SQL Server 客户端计算机的...【详细内容】
2023-08-21  Search: SQL Server  点击:(124)  评论:(0)  加入收藏
python如何操作SQL Server数据库?
当使用Python与SQL Server进行交互时,可以使用不同的库和模块。以下是25个示例代码,用于演示如何使用Python与SQL Server进行连接、查询、插入、更新和删除等操作:使用pyodbc库...【详细内容】
2023-08-15  Search: SQL Server  点击:(296)  评论:(0)  加入收藏
SQL Server关系数据库在Linux系统上安装及配置
SQL Server是由Microsoft开发的关系型数据库管理系统(RDBMS)。它是一种可靠、安全且高性能的数据库解决方案,用于存储、管理和处理大量结构化数据。SQL Server支持标准的SQL查...【详细内容】
2023-08-15  Search: SQL Server  点击:(242)  评论:(0)  加入收藏
SQL Server数据库常见操作及命令
创建数据库:CREATE DATABASE database_name;删除数据库:DROP DATABASE database_name;创建表:CREATE TABLE table_name ( column1 datatype, column2 datatype, ...);删除...【详细内容】
2023-08-15  Search: SQL Server  点击:(229)  评论:(0)  加入收藏
▌简易百科推荐
SQL Server 百万数据查询优化技巧三十则
互联网时代的进程越走越深,使用MySQL的人也越来越多,关于MySQL的数据库优化指南很多,而关于SQL SERVER的T-SQL优化指南看上去比较少,近期有学习SQLSERVER的同学问到SQL SERVER数...【详细内容】
2023-11-28  数据库干货铺  微信公众号  Tags:SQL Server   点击:(338)  评论:(0)  加入收藏
如何解决SQL Server数据库备份过程中检测到的日志损坏问题
译者 | 李睿日志损坏问题通常发生在对事务日志进行备份的时候。其错误是这样描述的:“消息26019,级别16,状态1,第1行BACKUP在数据库日志中检测到损坏。有关详细信息,请查看错误日...【详细内容】
2023-11-08    51CTO  Tags:SQL Server   点击:(289)  评论:(0)  加入收藏
聊聊SQL中的排名问题
今天给大家介绍一下SQL Server排名中经常用到的ROW_NUMBER(),RANK(),DENSE_RANK(),NTILE()这四个好兄弟。 我们先创建一个测试数据表ScoresWITH t AS(SELECT 1 StuID,70 ScoreU...【详细内容】
2023-10-26  SQL数据库开发  微信公众号  Tags:SQL   点击:(176)  评论:(0)  加入收藏
数据库批量插入数据方法
SQL Server 批量插入数据常用方法:一、普通的Insert插入二、拼接BatchInsert插入三、SqlBulkCopy插入 以上3种方法插入数据的速度比较:(ms:毫秒,1000 毫秒 = 1秒)由于电脑硬件情况...【详细内容】
2023-10-17      Tags:数据库   点击:(252)  评论:(0)  加入收藏
如何在 SQL Server 中备份和恢复数据库
在SQL Server中,数据库可以存储在不同的文件和文件组中。如果您的数据库较小(100 MB 或更少),则无需过多担心文件和文件组。但如果您有一个大型数据库(数 GB 或 TB),将数据分离到不...【详细内容】
2023-09-05  祺印说信安  微信公众号  Tags:SQL Server   点击:(267)  评论:(0)  加入收藏
linux上SQL Server 配置管理器的使用
概述我们知道Windows平台上的SQL Server 配置管理器是一个图形工具,用于管理与 SQL Server 关联的服务、配置 SQL Server 使用的网络协议以及管理 SQL Server 客户端计算机的...【详细内容】
2023-08-24    雪竹频道  Tags:SQL Server   点击:(306)  评论:(0)  加入收藏
Linux 上 SQL Server 配置管理器的使用
概述我们知道Windows平台上的SQL Server 配置管理器是一个图形工具,用于管理与 SQL Server 关联的服务、配置 SQL Server 使用的网络协议以及管理 SQL Server 客户端计算机的...【详细内容】
2023-08-21  雪竹聊技术  今日头条  Tags:SQL Server   点击:(124)  评论:(0)  加入收藏
python如何操作SQL Server数据库?
当使用Python与SQL Server进行交互时,可以使用不同的库和模块。以下是25个示例代码,用于演示如何使用Python与SQL Server进行连接、查询、插入、更新和删除等操作:使用pyodbc库...【详细内容】
2023-08-15  运维开发木子李  今日头条  Tags:SQL Server   点击:(296)  评论:(0)  加入收藏
SQL Server关系数据库在Linux系统上安装及配置
SQL Server是由Microsoft开发的关系型数据库管理系统(RDBMS)。它是一种可靠、安全且高性能的数据库解决方案,用于存储、管理和处理大量结构化数据。SQL Server支持标准的SQL查...【详细内容】
2023-08-15  运维开发木子李  今日头条  Tags:SQL Server   点击:(242)  评论:(0)  加入收藏
SQL Server数据库常见操作及命令
创建数据库:CREATE DATABASE database_name;删除数据库:DROP DATABASE database_name;创建表:CREATE TABLE table_name ( column1 datatype, column2 datatype, ...);删除...【详细内容】
2023-08-15  运维开发木子李  今日头条  Tags:SQL Server   点击:(229)  评论:(0)  加入收藏
站内最新
站内热门
站内头条