本文主要是介绍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数据库应用小安利的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!