Python Mysql ORM框架SQLAlchemy以及web后端实现

Python

  • 说明

  • python作为一种解释性语言,有着其独特的优势。有时候我们会用python写一些简单的http接口或者脚本来提供一些服务,以下介绍下 python操作mysql的一款ORM框架SQLAlchemy 的使用。

  • 首先 我们先建立个配置类,用来做一些配置性的东西,类似于java的properties文件,只不过这里把他作为一个类来管理起来

  • 代码样例

    • mysql的配置类

    class BaseConfig():
      #以下是我个人常用的配置类,仅做参考
      #Mysql 配置
      SQLALCHEMY_DATABASE_URI="mysql+pymysql://user:passwd@**.**.***.**:3306/dataBaseName"
      SQLALCHEMY_TRACK_MODIFICATIONS = False #如果设置成 True (默认情况),Flask-SQLAlchemy 将会追踪对象的修改并且发送信号。这需要额外的内存, 如果不必要的可以禁用它
      #以下配置不常用
      SQLALCHEMY_POOL_SIZE = 5 #数据库连接池的大小。默认是数据库引擎的默认值 (通常是 5)。
      SQLALCHEMY_POOL_TIMEOUT = 10 #指定数据库连接池的超时时间。默认是 10
      SQLALCHEMY_MAX_OVERFLOW = 2 #控制在连接池达到最大值后可以创建的连接数。当这些额外的 连接回收到连接池后将会被断开和抛弃
      SQLALCHEMY_POOL_RECYCLE = 2 #动回收连接的秒数。这对 MySQL 是必须的,默认 情况下 MySQL 会自动移除闲置 8 小时或者以上的连接。 需要注意地是如果使用 MySQL 的话,Flask-SQLAlchemy 会自动地设置这个值为2小时
      #Mongo配置
      MONGODB_PORT = 27017
      MONGODB_HOST = "**.**.**"
      MONGODB_DB = "dbName"
      MONGODB_USERNAME = "dbuser"
      MONGODB_PASSWORD = "dbpasswd"
      #MQ配置 rabbitmq
      MQ_USER_NAME = 'name'
      MQ_USER_PAWD = 'pwd'
      MQ_URL = 'host'
      MQ_HOST = 5672
      #初始化app
      app = Flask('dbclient') 因为我们做的是web服务所以这里用到了python的web框架         FLask 有兴趣的可以了解下
      #初始化mysqldb
      app.config.from_object(BaseConfig)  这里用我们的配置类去初始化mysql连接
      db = SQLAlchemy(app)
    
  • 建立两个数据库映射的实体类

    • 用户表

    from config.Config import db  #这里我们引用配置类中初始化好的db
       
      #建立数据库和实体类的映射
      class User(db.Model):
          #表名
          __tablename__ = 'user_info' 
          #字段属性
          id = db.Column(db.Integer, primary_key=True)
          user_name = db.Column(db.String(100))
          user_pswd = db.Column(db.String(100))
          user_token = db.Column(db.String(100))
          usercname = db.Column(db.String(100))
       
          #__init__方法为python类的构造方法
          def __init__(self,user_name, user_pswd, user_token,usercname):  # 这里实现以下构造,将其作为插入新值的方法
              print("User 构成函数被调用")
              # self.id = id
              self.user_name = user_name
              self.user_pswd = user_pswd
              self.user_token = user_token
              self.usercname = usercname
       
          #这个方法作为对象的打印方法,类似于java类中 自己重写的 toString()方法,实现这个方法后,print(类) 将会执行这个方法进行打印
          def __repr__(self):
              # 输出对象
              return '<User %i %r %r %r %r>' % (self.id,self.user_name,self.user_token,self.user_pswd,self.usercname)
    
    • token表

        from config.Config import db
      class Token(db.Model):
          __tablename__ = 'token_info'
          id = db.Column(db.Integer, primary_key=True)
          token_id = db.Column(db.String(100))
          user_cname = db.Column(db.String(100))
          user_id = db.Column(db.String(100))
       
          def __init__(self, token_id, user_cname,user_id):  # 插入新值的方法
              print("Token构成函数被调用")
              # self.id = id
              self.token_id = token_id
              self.user_cname = user_cname
              self.user_id = user_id
       
          def __repr__(self):
              # 输出对象
              return '<Token %i %r %r %r>' % (self.id,self.token_id,self.user_cname,self.user_id)
    
  • 建立数据库操作类,主要用于封装数据库操作的方法。

    • 代码如下:

        class UserInfo():
          # 全表查询
          def findAll(self):
              return User.query.all()
          #根据ID主键查询
          def getUserInfoById(self,id):
              return User.query.get(id)
          #自定义查询条件
          def getUserInfoByUserName(self,userName):
              return  User.query.filter_by(usercname = userName).all()
       
      class TokenInfo():
          def findAll(self):
              return Token.query.all()
          def getTokenInfoById(self,id):
              return Token.query.get(id)
       
      #复杂查询以及多表关联查询DEMO展示
      class UtilsQuery():
          @timelog    #这里的timelog是我自己的写的装饰器,目前实现的功能类似于java的aop切面,对方法进行环绕增强,在方法执行前后计算方法的执行时间用
          def find(self):
              #这里通过关联User和Token两张表进行关联查询
              return User.query.filter(User.id == Token.user_id).filter(Token.user_cname == 'XXXX').all()
              # return db.session.query(User).filter(User.id == Token.user_id).filter(Token.user_cname=='XXXX').all()
          @timelog
          def findByPage(self,pageNum,size):
              #这里展示分页查询
              if pageNum < 1:
                  pageNum = 1
              if size < 1:
                  size = 2
              start = (pageNum - 1)*size
              end = pageNum*size
              return User.query.slice(start,end).all()
    
  • 建立controller层,提供web调用

    • DEMO代码如下:

      @app.route('/controllertest',methods=['GET','POST'])
      def hello_world():
          print('接受到请求')
          returnData = {}
          returnData['data'] = "success"
       
          userInfoDto = UserInfo()
          print('\nid查询')
          print(userInfoDto.getUserInfoById(1))
          print('\n条件查询')
          print(userInfoDto.getUserInfoByUserName("XXXX"))
          print('\n全表查询')
          print(TokenInfo().findAll())
          print('\n分页查询')
          print(UtilsQuery().findByPage(1,2))
          return json.dumps(returnData, ensure_ascii=False)
    
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容