Python数据库应用小安利

2024-03-20 20:58
文章标签 python 应用 数据库 安利

本文主要是介绍Python数据库应用小安利,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Python结合数据库开发

与几个主流数据库连接

1.SQL Server

// 需要pymssql包,注意pycharm中该包的版本可能要选择低一些的
# -*- coding: utf-8 -*-
import pymssql
con = pymssql.connect(host='localhost',user='sa',password='123456',database='Teach')   # 连接到数据库,注意sql中MSSQLSERVER协议启动TCP/IP(重新启动生效),数据库sql身份登录,设置密码
cur = con.cursor()    #创建游标
sql = 'SELECT * FROM S;'  #查询语句注意表的选择
cur.execute(sql)
data= cur.fetchall()    #需要将结果返回
print(data)            #输出数据

几个链接Sqlserver的问题:
注意con = pymssql.connect(host=‘localhost’,user=‘sa’,password=‘123456’,database=‘Teach’)
1.如果采用上述语句中sql身份登录,要进行设置,方法是右键对象资源管理器中引擎—>属性中的安全性进行身份验证模式–>对象资源管理器中的安全性—>找到登录账号–>SQL Server身份验证–>密码设置(注意取消强制实施密码策略)
2.需要对sql中MSSQLSERVER协议启动TCP/IP,该过程在SQL Server配置管理器设置(注意该过程重新启动生效)
3.部分系统需要对SQL BROWSER启动,在SQL Server Configuration Manager,即SQL Server配置管理器中启动,这里需要注意的是部分系统启动不了,需要右键此电脑–>管理–>服务–>SQL BROWSER启动
4.链接不上可能还存在几个原因:
(1) localhost->127.0.0.1
(2)链接语句后面添加charset=‘utf-8’ 或 charset=’‘CP936’

2.Oracle

//需要cx_Oracle包,注意pycharm中该包的版本可能要选择低一些的
import cx_Oracle                     
​# 第一块 连接数据库 , 参数为'账号/密码/@ip:端口/库名'
con=cx_Oracle.connect('user/password@host/databases') 
cur=con.cursor()                      
sql = 'SELECT * FROM S;'
cur.execute(sql)
data= cur.fetchall()    #需要将结果返回
print(data)            #输出数据

3.MySql

//需要pymysql包,注意pycharm中该包的版本
import pymysql
​
# 第一步:连接到数据库
con = pymysql.connect(host="test.lemonban.com",  # 数据库的地址,本地可以localuser='xxxxx',               # 登录数据库的账号password="xxxxx",           # 登录数据库的密码port=3306,                  # 端口地址,需要查看MySQL端口号,默认3306database='xxxxx',           # 数据库名称)
cur = con.cursor()
sql = 'SELECT * FROM S;'
cur.execute(sql)
data= cur.fetchall()    #需要将结果返回
print(data)            #输出数据

4.SQLite

//需要sqlite3包,您不需要单独安装该模块,因为 Python 2.5.x 以上版本默认自带了该模块,细节参见https://www.runoob.com/sqlite/sqlite-python.html
import sqlite3
conn = sqlite3.connect('test.db')   #连接数据库test.db,如果该数据库不存在,那么它就会被创建,最后将返回一个数据库对象。
cur = conn.cursor()
print("Opened database successfully")
sql = 'SELECT * FROM S;'
cur.execute(sql)
data= cur.fetchall()    #需要将结果返回
print(data)            #输出数据
conn.close()       #注意关闭

典型案例

// 转载 https://www.shuzhiduo.com/A/kmzL3WQBdG/
from tkinter import *
from tkinter import ttk
# import pymssql
from tkinter import messageboxclass Basedesk():   #基准框模块def __init__(self, master):self.root = masterself.root.config()self.root.title('学生管理系统')self.width = 380  # 界面宽self.height = 300  # 界面高# 获取屏幕尺寸以计算布局参数,使窗口居屏幕中央self.screenwidth = self.root.winfo_screenwidth()  # 屏幕宽self.screenheight = self.root.winfo_screenheight()  # 屏幕高self.alignstr = '%dx%d+%d+%d' % (self.width, self.height, (self.screenwidth - self.width) / 2, (self.screenheight - self.height) / 2)self.root.geometry(self.alignstr)self.R = Register(self.root)self.R.reigister(self.root)class Register():def __init__(self, master):self.root = master# 基准框架 """以下三行需根据个人实际修改"""self.ip = 'local'      # 填入个人ip地址self.id = 'sa'         # 填入个人使用的SqlServer的账号self.pd = '123456'     # 填入SqlServer账号对应密码def reigister(self, master):   #登录模块# 账号密码输入框self.initface = LabelFrame(self.root, text='学生管理系统登录', font=('微软雅黑', 14))self.initface.grid(padx=85, pady=30, )self.people = Label(self.initface, text='账号')  # 账号self.people.grid(row=1, column=0, padx=10, pady=10)self.password = Label(self.initface, text='密码')  # 密码self.password.grid(row=2, column=0, padx=10, pady=10)self.var1 = StringVarself.var2 = StringVarself.entry_people = Entry(self.initface, textvariable=self.var1)  # 账号输入框self.entry_people.grid(row=1, column=1, padx=10, pady=10)self.entry_password = Entry(self.initface, textvariable=self.var2, show='*')  # 密码输入框self.entry_password.grid(row=2, column=1, padx=10, pady=10)self.button_into = Button(self.initface, text='登录', command=self.conn)  # 登录按钮self.button_into.grid(row=3, column=0, padx=20, pady=20)self.button_into = Button(self.initface, text='退出', command=self.root.quit)  # 退出按钮self.button_into.grid(row=3, column=1, padx=20, pady=20)def conn(self):self.connect = pymssql.connect(self.ip, self.id, self.pd, 'student_Mis1')  # 服务器名,账户,密码,数据库名self.cursor = self.connect.cursor()if self.connect:print('连接成功')self.sql = "select Students.学号,Students.密码 from Students"self.cursor.execute(self.sql)self.result = self.cursor.fetchone()self.man = self.entry_people.get()# self.pd = self.entry_password.get()while self.result:print('%s|%s' % (self.result[0], self.result[1]))if self.result[0] == self.entry_people.get() and self.result[1] == self.entry_password.get():print('账号密码正确')self.initface.destroy()  # 销毁initfaceself.check()breakelse:self.result = self.cursor.fetchone()else:# 账号或密码错误清空输入框self.entry_people.delete(0, END)self.entry_password.delete(0, END)messagebox.showinfo(title='提示', message='账号或密码输入错误\n请重新输入?')# breakself.cursor.close()self.connect.close()def check(self):  #功能选择模块self.frame_checkbutton = LabelFrame(self.root, text='功能选择', font=('微软雅黑', 14))self.frame_checkbutton.grid(padx=60, pady=30)# 查询成绩按钮self.button_success = Button(self.frame_checkbutton, text='查询成绩', width=10, height=2, command=self.success)self.button_success.grid(row=0, column=0, padx=20, pady=20)# 修改密码按钮self.button_revise = Button(self.frame_checkbutton, text='修改密码', width=10, height=2, command=self.revise)self.button_revise.grid(row=0, column=1, padx=20, pady=20)def success(self):self.connect = pymssql.connect(self.ip, self.id, self.pd, 'student_Mis1')  #连接数据库( 服务器名,账户,密码,数据库名)if self.connect:print('连接成功')print(self.man)# 查询语句search_sql = "select  convert(nvarchar(20), 姓名) ,Students.学号,convert(nvarchar(20), 课程名) ,成绩 from  Students, Report, Course " \"where Students.学号=Report.学号 and Report.课程号=Course.课程号 and Students.学号=%s" % self.manself.cursor1 = self.connect.cursor()      # 创建游标self.cursor1.execute(search_sql)self.row = self.cursor1.fetchone()  # 读取查询结果# 表格框root = Tk()  # 初始框的声明root.geometry('500x400+100+100')root.title('成绩查询系统')columns = ("姓名", "学号", "课程", "成绩")self.treeview = ttk.Treeview(root, height=18, show="headings", columns=columns)self.treeview.column("姓名", width=150, anchor='center')  # 表示列,不显示self.treeview.column("学号", width=100, anchor='center')self.treeview.column("课程", width=150, anchor='center')self.treeview.column("成绩", width=100, anchor='center')self.treeview.heading("姓名", text="姓名")  # 显示表头self.treeview.heading("学号", text="学号")self.treeview.heading("课程", text="课程")self.treeview.heading("成绩", text="成绩")self.treeview.pack(side=LEFT, fill=BOTH)# 界面上插入读取的数据while self.row:self.treeview.insert('', 0, values=(self.row[0], self.row[1], self.row[2], self.row[3]))self.row = self.cursor1.fetchone()  # 读取查询结果,self.cursor1.close()self.connect.close()root.mainloop()def revise(self):   #密码修改模块self.window = Tk()  # 初始框的声明self.window.geometry('400x200+100+100')self.window.title('密码修改管理')self.frame_revise = LabelFrame(self.window)self.frame_revise.grid(padx=60, pady=60)self.label_revise = Label(self.frame_revise, text='新密码:')self.label_revise.grid(row=0, column=0, padx=10, pady=10)self.var3 = StringVarself.entry_revise = Entry(self.frame_revise, textvariable=self.var3)self.entry_revise.grid(row=0, column=1, padx=10, pady=10)self.button_ok = Button(self.frame_revise, text='确定', command=self.ok)self.button_ok.grid(row=1, column=0)self.button_resive = Button(self.frame_revise, text='取消', command=self.resive)self.button_resive.grid(row=1, column=1)self.button_quit = Button(self.frame_revise, text='退出', command=self.window.destroy)self.button_quit.grid(row=1, column=2)def ok(self):           # 连接数据库self.connect = pymssql.connect(self.ip, self.id, self.pd, 'student_Mis1')  # 服务器名,账户,密码,数据库名self.cursor2 = self.connect.cursor()  # 创建游标sql_revise = "update Students set 密码=%s where 学号=%s" % (self.entry_revise.get(), self.man)if self.connect:print('连接成功')print(self.man)self.cursor2.execute(sql_revise)self.connect.commit()print(self.entry_revise.get())messagebox.showinfo(title='提示', message='密码修改成功!')self.cursor2.close()self.connect.close()def resive(self):self.entry_revise.delete(0, END)
if __name__ == '__main__':root = Tk()Basedesk(root)mainloop()

这篇关于Python数据库应用小安利的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/830702

相关文章

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

Python中的Walrus运算符分析示例详解

《Python中的Walrus运算符分析示例详解》Python中的Walrus运算符(:=)是Python3.8引入的一个新特性,允许在表达式中同时赋值和返回值,它的核心作用是减少重复计算,提升代码简... 目录1. 在循环中避免重复计算2. 在条件判断中同时赋值变量3. 在列表推导式或字典推导式中简化逻辑

python处理带有时区的日期和时间数据

《python处理带有时区的日期和时间数据》这篇文章主要为大家详细介绍了如何在Python中使用pytz库处理时区信息,包括获取当前UTC时间,转换为特定时区等,有需要的小伙伴可以参考一下... 目录时区基本信息python datetime使用timezonepandas处理时区数据知识延展时区基本信息

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1

使用Python和Pyecharts创建交互式地图

《使用Python和Pyecharts创建交互式地图》在数据可视化领域,创建交互式地图是一种强大的方式,可以使受众能够以引人入胜且信息丰富的方式探索地理数据,下面我们看看如何使用Python和Pyec... 目录简介Pyecharts 简介创建上海地图代码说明运行结果总结简介在数据可视化领域,创建交互式地