当前位置: 首页 > news >正文

项目ER图和资料

在这里插入图片描述
在这里插入图片描述

常用的数据类型

在这里插入图片描述

模型类

一对多

from app import db
import datetimeclass BaseModel(db.Model):__abstract__ = Truecreate_time = db.Column(db.DateTime,default=datetime.datetime.now())update_time = db.Column(db.DateTime,default=datetime.datetime.now())class Role(db.Model):__tablename__ = 'roles'id = db.Column(db.Integer, primary_key=True)name = db.Column(db.String(64), unique=True)users = db.relationship('User', backref='role')class User(BaseModel):__tablename__="user"uid = db.Column(db.BigInteger,primary_key=True,comment="用户id")name = db.Column(db.String(100),nullable=False,comment="姓名")password = db.Column(db.String(255))role_id = db.Column(db.Integer, db.ForeignKey('roles.id'))

多对多

article_tag = db.Table('article_tag',db.Column('article_id', db.Integer, db.ForeignKey('article.id'), primary_key=True),db.Column('tag_id', db.Integer, db.ForeignKey('tag.id'), primary_key=True))class Article(db.Model):__tablename__ = 'article'id = db.Column(db.Integer, primary_key=True, autoincrement=True)title = db.Column(db.String(100), nullable=False)tags = db.relationship('Tag', secondary=article_tag, backref=db.backref('articles'))class Tag(db.Model):__tablename__ = 'tag'id = db.Column(db.Integer, primary_key=True, autoincrement=True)name = db.Column(db.String(100), nullable=False)

PYMYSQL

import pymysqlclass DB:def __init__(self) -> None:# 主库用于写入self.conn = pymysql.connect(host='localhost',port=3306,user='root',password='mysql',db='p2p',cursorclass=pymysql.cursors.DictCursor)self.cursor = self.conn.cursor()#更新添加def update(self,sql):self.cursor.execute(sql)self.conn.commit()return self.cursor.lastrowid#获取一条def findOne(self,sql):self.cursor.execute(sql)res = self.cursor.fetchone()return res#获取多条def findAll(self,sql):self.cursor.execute(sql)res = self.cursor.fetchall()return res#提交方法def commit(self):self.conn.commit()#回滚方法def rollback(self):self.conn.rollback()db = DB()

单例模式

保证只创建一个对象,创建时先判断是否存在,如果存在直接返回,如果不存在以会new
class DB:pass
db1 = DB()
from db import DB
db = DB()
db.find...from db import db1
db1.find...

注册登录

在这里插入图片描述
在这里插入图片描述

orm介绍

对象关系映射,对象创建表。优点在于对sql语句进行了封装,用的时候不用关心具体的实现,在安全上解决了sql注入的问题。并且引入的缓存,对数据缓存。缺点性能上有损耗,并且对不支持复杂sql.

常用的约束

在这里插入图片描述

http://www.lryc.cn/news/33969.html

相关文章:

  • 剑指 Offer 20. 表示数值的字符串(java+python)
  • 程序员的逆向思维
  • 吐血整理学习方法,2年多功能测试成功进阶自动化测试,月薪23k+......
  • mysql慢查询:pt-query-digest 分析
  • git的使用整合
  • XCPC第九站———背包问题!
  • 【软考 系统架构设计师】论文范文④ 论基于构件的软件开发
  • spring-integration-redis中分布式锁RedisLockRegistry的使用
  • 城市通电(prim算法)
  • 【动态规划】
  • 秒懂算法 | DP概述和常见DP面试题
  • 【C++提高编程】C++全栈体系(二十五)
  • 【云原生】k8s核心技术—集群安全机制 Ingress Helm 持久化存储-20230222
  • 【Linux】实现简易的Shell命令行解释器
  • 再获认可!腾讯安全NDR获Forrester权威推荐
  • 代码审计之旅之百家CMS
  • ONLYOFFICE中利用chatGPT帮助我们策划一场生日派对
  • Java面试题-线程(一)
  • 一篇普通的bug日志——bug的尽头是next吗?
  • Vue 3 第八章:Watch侦听器
  • GlassFish的安装与使用
  • 【java】Java 重写(Override)与重载(Overload)
  • OpenCV-PyQT项目实战(12)项目案例08:多线程视频播放
  • 面向对象设计模式:结构型模式之装饰器模式
  • Unity iOS 无服务器做一个排行榜 GameCenter
  • 现在招个会自动化测试的人是真难呀~你会个锤子的自动化测试
  • OracleDatabase——数据库表空间dmp导出与导入
  • 20张图带你彻底了解ReentrantLock加锁解锁的原理
  • Dockerfile构建Springboot镜像
  • 从深分页查询到覆盖索引