会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 133529个问题
JAVA 全系列/第十三阶段:高性能数据处理、NoSQL、分库分表/Redis 8732楼

老师,我总是报下面的错误,该怎么解决,我百度了但是没找到什么有效地方法

# coding=utf-8
"""开发记事本软件,使用面向对象的编程方式"""
from tkinter import *
from tkinter.filedialog import *
from tkinter.colorchooser import *


class Application(Frame):
    def __init__(self, master=None):
        super().__init__(master)
        self.master = master
        self.textPad = None
        self.filename = None
        self.Contextmenu = None
        self.pack()
        self.creatwidget()

    def creatwidget(self):
        # 创建菜单
        menubar = Menu(root)
        menuFile = Menu(menubar)
        menuEdit = Menu(menubar)
        menuHelp = Menu(menubar)

        # 把菜单添加到主菜单中
        menubar.add_cascade(label="文件F", menu=menuFile)
        menubar.add_cascade(label="编辑E", menu=menuEdit)
        menubar.add_cascade(label="帮助H", menu=menuHelp)

        # 在文件菜单下添加选项
        # 都可以通过command参数绑定方法,此处省略
        # accelerator是快捷键参数
        menuFile.add_command(label="新建N", accelerator="ctrl+n")
        menuFile.add_command(label="打开O", accelerator="ctrl+o",
                             command=self.openfile)
        menuFile.add_command(label="保存S", accelerator="ctrl+s",
                             command=self.savefile)
        # 添加一道下滑线
        menuFile.add_separator()
        menuFile.add_command(label="退出", accelerator="ctrl+q",
                             command=self.exit)

        # 添加上下文菜单,即右键快捷菜单
        self.Contextmenu = Menu(self.master)
        self.Contextmenu.add_command(label="选择背景颜色", command=self.choosebgcolor)
        self.master.bind("<Button-3>", self.ms)

        # 把主菜单添加到主窗口
        root.config(menu=menubar)
        self.textPad = Text(self.master, width=300, height=300, bg="gray")
        self.textPad.pack()

        # 绑定快捷键
        root.bind("<Control-o>", self.openfile)
        root.bind("<Control-s>", self.savefile)
        root.bind("<Control-q>", self.exit)
        root.bind("<Control-n>", self.newfile)

    def ms(self, event):
        self.Contextmenu.post(event.x_root, event.y_root)

    def exit(self, event=None):
        self.master.quit()

    def openfile(self, event=None):
        self.textPad.delete(1.0, END)
        with askopenfile(title="打开文本文件", filetypes=[("文本文件", ".txt")]) as file:
            self.filename = file.name
            self.textPad.insert(INSERT, file.read())

    def savefile(self, event=None):
        with open(self.filename, "w") as file:
            c = self.textPad.get(1.0, END)
            file.write(c)

    def newfile(self, event=None):
        self.textPad.delete(1.0, END)
        self.filename = asksaveasfilename(title="新建文件",
                                          initialfile="未命名.txt", filetypes=[(
                "文本文件", ".txt")], defaultextension=".txt")

    def choosebgcolor(self):
        colors = askcolor(color="gray", title="选择背景颜色")
        self.textPad.config(bg=colors[1])


if __name__ == "__main__":
    root = Tk()
    root.geometry('500x500')
    app = Application(root)

    root.mainloop()

image.png

Python 全系列/第二阶段:Python 深入与提高/GUI编程(隐藏) 8733楼
JAVA 全系列/第十一阶段:分布式RPC调用和分布式文件存储/Dubbo 8735楼
JAVA 全系列/第五阶段:网页编程和设计/Jquery(旧) 8736楼

from sqlalchemy.ext.declarative import declarative_base
# 导入常见数据类型
from sqlalchemy import create_engine,Column,Integer,String,Float,DECIMAL,Boolean,\
    Date,DateTime,Time,Text,Enum
from sqlalchemy.dialects.mysql import LONGTEXT

from sqlalchemy.orm import sessionmaker

from sqlalchemy import func,and_,or_,ForeignKey

HOSTNAME = '127.0.0.1'
PORT = '3306'
DATABASE = 'first_sqlalchemy'
USERNAME = 'root'
PASSWORD = '123456'

DB_URI ="mysql+pymysql://{username}:{password}@{host}:{port}/{db}?charset=utf8".format(username=USERNAME,password=PASSWORD,host=HOSTNAME,port=PORT,db=DATABASE)

engine = create_engine(DB_URI)

session = sessionmaker(engine)()
# 1.用`declarative_base`根据`engine`创建一个ORM基类
Base = declarative_base(engine)

# 需求:sqlalchemy中query查询函数可以传递的参数有哪些(3中方式)
'''
1. 模型名。指定查找这个模型中所有的属性(对应查询表为全表查询)。
2. 模型中的属性。可以指定只查找某个模型的其中几个属性。
3. 聚合函数。
    * func.count:统计行的数量。
    * func.avg:求平均值。
    * func.max:求最大值。
    * func.min:求最小值。
    * func.sum:求和。
    `func`上,其实没有任何聚合函数。但是因为他底层做了一些魔术,
    只要mysql中有的聚合函数,都可以通过func调用
'''

# class News(Base):
#     __tablename__='news'
#     id = Column(Integer,primary_key=True,autoincrement=True)
#     title =Column(String(50),nullable=False)
#     price = Column(Integer)
#     content = Column(Text)
#
#     def  __repr__(self):
#         return  "<title:%s,price:%s,content:%s>"%(self.title,self.price,self.content)
# Base.metadata.drop_all()
# Base.metadata.create_all()

# 添加测试数据
# for x in range(1,6):
#     a = News(title="新闻%s"%x,price =random.randint(1,100))
#     session.add(a)
# session.commit()

# 需求:SQLALchemy实现外键及其四种约束讲解

# 主表 / 从表
# user/news
class User(Base):
    __tablename__ = 'user'
    id = Column(Integer,primary_key=True,autoincrement=True)
    uname = Column(String(50),nullable=False)

    def __repr__(self):
        return "<User(uname:%s)>" % self.uname

class News(Base):
    __tablename__ = 'news'
    id = Column(Integer,primary_key=True,autoincrement=True)
    title = Column(String(50),nullable=False)
    content = Column(Text,nullable=False)
    # sqlalchemy实现外键方法:四种约束
    # RESTRICT
    # uid = Column(Integer,ForeignKey("user.id",ondelete='RESTRICT'))
    # NO ACTION
    uid = Column(Integer,ForeignKey("user.id",ondelete='NO ACTION'))
    # NO ACTION
    # uid = Column(Integer, ForeignKey("user.id", ondelete='CASCADE'))
    # NO ACTION
    # uid = Column(Integer, ForeignKey("user.id", ondelete='SET NULL'))

    def __repr__(self):
        return "<News(title:%s,content=%s)>" % (self.title,self.content)

# 创建表
Base.metadata.drop_all()
Base.metadata.create_all()

# 添加测试数据
user = User(uname='momo')
session.add(user)
session.commit()
#
news1= News(title='AAA',content='123',uid=1)
news2= News(title='BBB',content='456',uid=1)
session.add_all([news1,news2])
session.commit()


image.png



image.png

老师,我的代码,好像外键添加不上去,运行sql语句,直接删除了user表中内容。


Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask数据库 8742楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/异常机制 8743楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/IO 流技术(旧) 8744楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637