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获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达