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调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及