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

相关文章

JSONArray在Java中的应用操作实例

《JSONArray在Java中的应用操作实例》JSONArray是org.json库用于处理JSON数组的类,可将Java对象(Map/List)转换为JSON格式,提供增删改查等操作,适用于前后端... 目录1. jsONArray定义与功能1.1 JSONArray概念阐释1.1.1 什么是JSONA

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

Python包管理工具pip的升级指南

《Python包管理工具pip的升级指南》本文全面探讨Python包管理工具pip的升级策略,从基础升级方法到高级技巧,涵盖不同操作系统环境下的最佳实践,我们将深入分析pip的工作原理,介绍多种升级方... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过