亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Python > 正文

Python-Flask:動態創建表的示例詳解

2024-09-09 19:02:41
字體:
來源:轉載
供稿:網友

今天小編從項目的實際出發,由于項目某一個表的數據達到好幾十萬條,此時數據的增刪查改會很慢;為了增加提高訪問的速度,我們引入動態創建表。

代碼如下:

from app_factory import appfrom sqlalchemy import Column, String, Integer class ProjectModel(app.db.model, app.db.Mixin):   tablename = 'Project_'   ID = Column(String(50), name='ID', doc='id')  PROJECTNUMBER = Column(String(100), name='PROJECTNUMBER', doc='項目編號')  ......    @staticmethod  def create_table(project_number)    table_name = ProjectModel.tablename + projectnumber    structs = [      {'fieldname': 'id', 'type': 'varchar2(50)', 'primary': True, 'default': ''},      {'fieldname': 'PROJECTNUMBER', 'type': 'varchar2(50)', 'default': 0, 'isnull':                 True},      .......    ]    app.db.create_table(table_name, structs)

那么,內層函數是如何創建的呢?其實就是拼接sql語句create table ....

代碼如下:

class SQLAlchemyDB(SQLAlchemy):  def __init__(self, app)    super(SQLAlchemyDB, self).__init__(app)    self.__app = app    self.engine.echo = False    self.conn = self.engine.connect()    self.Model.to_dict() = lambda self:{c.name:getattr(self, c.name, None) for c in self.__table__.columns}    self.Session = sessionmaker(bind=self.engine)    self.ScopedSession = lambda: scoped_session(self.Session)   # 釋放碎片空間  def free_idle_space(self):    return self.execute('purge recyclebin')    def connstatus(self):    return self.engine.pool.status()    def close(self):    self.conn.close()    self.engine.dispose()   # 非返回數據的記錄語句  def execute(self, sqlexpr)    try:      ret = self.conn.execute(sqlalchemy.text(sqlexpr))    except Exception as err:      return False, str(err)    except sqlalchemy.exc.InvalidRequestError as err:      return False, str(err)     return True, ''   # 動態拼接sql語句, 創建表  def create_table(self, tablename, structs):    fieldinfos = []    for struct in structs:      defaultvalue = struct.get('default')      if defaultvalue :        defaultvalue = "'{0}'".format(defaultvalue) if type(defaultvalue) == 'str' else str(defaultvalue)      fieldinfos.append('{0} {1} {2} {3} {4}'.format(struct['fieldname'], struct['type'], 'primary key' if struct.get('primary') else '', ('default' + defaultvalue) if defaultvalue else '', '' if struct.get('isnull') else 'not null'))    sql = 'create table {0} ({1})'.format(tablename, ','.join(fieldinfos))    ret, err = self.execute(sql)    if ret:      self.__app.sync_record(tablename, 'sql_createtable', {}, sql)    return ret, err   # 動態判斷表是否存在   def existtable(self, tablename):    ret, err = self.GetRecordCount("user_all_table", "TABLE_NAME='" + tablename +"'")    return ret>0, err    def GetRecordCount(self, tablename, where= None):    sql = 'select count(*) as num from {0} {1}'.format(tablename,('where' + where)) if where != None else '')    recs, err = self.query(sql)    if recs:      for rec in recs:        return rec['num'], ''     return -1 , err    # 查詢數據記錄  def query(self, sqlexpr):    try:      recs = self.conn.execute(sqlalchemy.text(sqlexpr)      return recs, ''    expect Exception as err:      return None, str(err)      expect sqlalchemy.exc.InvalidRequestError as err:      return None, str(err)   
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产91在线高潮白浆在线观看| 欧美日韩国产精品一区二区不卡中文| 国产中文日韩欧美| 欧美一级高清免费播放| 国产亚洲精品久久久久久777| 欧美国产精品人人做人人爱| 国产成人精品久久二区二区91| 日韩成人免费视频| 91免费看国产| 欧美乱大交做爰xxxⅹ性3| 日韩av电影手机在线| 国产欧美va欧美va香蕉在| 色黄久久久久久| 九九九热精品免费视频观看网站| 国产一区私人高清影院| 国产一区二区三区在线视频| 久久久久久久久电影| 国产精品视频久久久| 久久久亚洲天堂| 5278欧美一区二区三区| 欧美中文字幕视频在线观看| 免费97视频在线精品国自产拍| 亚洲欧洲高清在线| 久久这里只有精品视频首页| 亚洲精品国产欧美| 最近2019好看的中文字幕免费| 国产精品人人做人人爽| 久久亚洲综合国产精品99麻豆精品福利| 欧美午夜精品久久久久久浪潮| 欧美日韩午夜视频在线观看| 97香蕉久久超级碰碰高清版| 91爱视频在线| 日韩少妇与小伙激情| 国产性猛交xxxx免费看久久| 国产一区二区三区高清在线观看| 亚洲人精品午夜在线观看| 国产精品对白刺激| 久久精品国产成人精品| 中文字幕在线看视频国产欧美在线看完整| 亚洲人成在线免费观看| 日韩av一区在线观看| 国产91精品在线播放| 亚洲第一男人av| 中文字幕亚洲综合久久| 日韩激情av在线播放| 欧美激情xxxxx| 97热精品视频官网| 国产精品aaaa| 美女撒尿一区二区三区| 亚洲xxx自由成熟| 国产999精品视频| 欧美第一黄色网| 国产精品美女久久久久久免费| 精品国产一区二区三区久久久| 日本精品va在线观看| 91日本视频在线| 亚洲一区二区三区777| 欧美高清不卡在线| 成人伊人精品色xxxx视频| 97免费在线视频| 亚洲第一黄色网| 精品亚洲一区二区三区四区五区| 色偷偷av一区二区三区| 欧美日韩国产一区二区| 国产综合在线视频| 日本视频久久久| 亚洲精品天天看| 狠狠久久五月精品中文字幕| 日韩专区在线观看| 亚洲第一免费播放区| 久久在精品线影院精品国产| 亚洲精品一区二区网址| 精品国产一区av| 亚洲精品日韩久久久| 91久久国产综合久久91精品网站| 中文字幕国产亚洲| xvideos国产精品| 日本国产高清不卡| 亚洲成人久久一区| 日韩福利伦理影院免费| 亚洲久久久久久久久久久| 成人av电影天堂| 九九热精品视频国产| 欧美大片在线影院| 不卡av在线网站| 日韩免费高清在线观看| 亚洲美女精品成人在线视频| 国产精品欧美一区二区三区奶水| 日韩**中文字幕毛片| 色偷偷av一区二区三区乱| 色哟哟入口国产精品| 欧美激情视频一区二区三区不卡| 日产精品99久久久久久| 97在线精品视频| 欧美视频在线视频| 亚洲成人久久久| 日本精品视频网站| 色综合久久88色综合天天看泰| 精品久久久一区二区| 亚洲色图色老头| 久久久久久久香蕉网| 日韩中文字幕在线视频播放| 中文字幕一精品亚洲无线一区| 亚洲综合大片69999| 日韩一中文字幕| 久久成人国产精品| 欧美人在线观看| 久久99精品国产99久久6尤物| 国产精品人成电影在线观看| 欧美插天视频在线播放| 欧美xxxx做受欧美.88| 亚洲bt天天射| 国产一区二区视频在线观看| 成人精品视频在线| 亚洲综合最新在线| 欧美华人在线视频| 5566日本婷婷色中文字幕97| 欧美怡红院视频一区二区三区| 久久久精品欧美| 91免费高清视频| 亚洲色图综合网| 久久视频免费观看| 538国产精品一区二区免费视频| 国产精品精品一区二区三区午夜版| 一区二区欧美日韩视频| 欧美视频二区36p| 久久99精品久久久久久青青91| 成人精品视频99在线观看免费| 亚洲精品美女久久久| 国产一区欧美二区三区| 最近2019好看的中文字幕免费| 久久久国产影院| 2019中文字幕免费视频| 日韩精品亚洲视频| 91夜夜揉人人捏人人添红杏| 亚洲人成免费电影| 欧美日韩综合视频| 91成人天堂久久成人| 97欧美精品一区二区三区| 久久精品国产91精品亚洲| 这里只有精品视频在线| 欧美成人剧情片在线观看| 欧美精品成人91久久久久久久| 久久人人97超碰精品888| 久久97久久97精品免视看| 国产成+人+综合+亚洲欧美丁香花| 精品亚洲夜色av98在线观看| 精品无人区太爽高潮在线播放| 国产日韩欧美91| 国产精品久久久久久久久久久久| 成人久久精品视频| 国产精品揄拍一区二区| 97精品一区二区视频在线观看| 久久久久久中文字幕| 成人xxxx视频| 日韩av网站大全| 久热国产精品视频| 亚洲乱码国产乱码精品精| 欧美激情国内偷拍| 国产精品av在线播放| 国产精品美女无圣光视频| 在线日韩欧美视频| 欧美激情精品久久久| 亚洲午夜av久久乱码|