日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python动态生成数据库表_Python-Flask:动态创建表的示例详解

發布時間:2024/4/13 python 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python动态生成数据库表_Python-Flask:动态创建表的示例详解 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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

代碼如下:

from app_factory import app

from 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)

那么,類似的:

1-如果動態的對已經創建的表格進行增刪查改,那么可以用類似的思想,進行對sql語句進行拼接,insert select delete update

2-判斷是否存在此字段,進去拼接查詢這個字段查出的數據是否為空(count)

3-在原來表的基礎上增加字段,或者修改字段,用alter

以上這篇Python-Flask:動態創建表的示例詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

總結

以上是生活随笔為你收集整理的python动态生成数据库表_Python-Flask:动态创建表的示例详解的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。