zoukankan      html  css  js  c++  java
  • sqlacodegen 的使用

    Python利用sqlacodegen自动生成ORM实体类

    sqlacodegen 是命令级别,添加模型类以及构建拓展类 可以结合 subprocess 或 os 模块进行脚本化操作

    sqlacodegen --outfile project/models.py mysql://user_name:pwd@IP:PORT/db

    常用配置, 具体的配置 sqlacodegen--help 查看需要的配置

    --schema SCHEMA load tables from an alternate schema
    指定表,默认是全部的表 
    --tables TABLES tables to process (comma-separated, default: all)
    --noviews ignore views
    --noclasses don't generate classes, only tables
    指定生成模型类文件
    --outfile OUTFILE file to write output to (default: stdout)

    1 安装:

    pip install sqlacodegen

    2 测试数据库链接 , postgresql 为例

    from sqlalchemy import create_engine, MetaData
    from sqlalchemy.orm import sessionmaker, scoped_session
    from sqlalchemy.ext.declarative import declarative_base
    from sqlalchemy.pool import QueuePool
    
    HOSTNAME = '127.0.0.1'
    PORT = '5432'
    DATABASE = '**'  
    USERNAME = '**'
    PASSWORD = '**'
    #mysql dialect+driver://username:password@host:port/database
    #DB_URI = "mysql+pymysql://{username}:{password}@{host}:{port}/{db}?charset=utf8".format(username=USERNAME,password=PASSWORD,host=HOSTNAME,port=PORT,db=DATABASE)
    #postgresql
    DB_URI =postgresql://user:password@ip:port/db
    # 1 创建引擎
    engine = create_engine(DB_URI, echo=True, pool_size=100, pool_recycle=3600, poolclass=QueuePool, max_overflow=10)
    # 2判断是否连接成功
    conn = engine.connect() result = conn.execute('select 1') print(result.fetchone())
    # 3创建会话
      pass

    成功打印:

    2020-02-22 21:45:21,353 INFO sqlalchemy.engine.base.Engine SHOW VARIABLES LIKE ''
    2020-02-22 21:45:21,353 INFO sqlalchemy.engine.base.Engine {}
    2020-02-22 21:45:21,368 INFO sqlalchemy.engine.base.Engine SHOW VARIABLES LIKE 'lower_case_table_names'
    2020-02-22 21:45:21,368 INFO sqlalchemy.engine.base.Engine {}
    2020-02-22 21:45:21,372 INFO sqlalchemy.engine.base.Engine SELECT DATABASE()
    2020-02-22 21:45:21,372 INFO sqlalchemy.engine.base.Engine {}
    2020-02-22 21:45:21,374 INFO sqlalchemy.engine.base.Engine show collation where `Charset` = 'utf8mb4' and `Collation` = 'utf8mb4_bin'
    2020-02-22 21:45:21,374 INFO sqlalchemy.engine.base.Engine {}
    2020-02-22 21:45:21,386 INFO sqlalchemy.engine.base.Engine SELECT CAST('test plain returns' AS CHAR(60)) AS anon_1
    2020-02-22 21:45:21,386 INFO sqlalchemy.engine.base.Engine {}
    2020-02-22 21:45:21,394 INFO sqlalchemy.engine.base.Engine SELECT CAST('test unicode returns' AS CHAR(60)) AS anon_1
    2020-02-22 21:45:21,395 INFO sqlalchemy.engine.base.Engine {}
    2020-02-22 21:45:21,395 INFO sqlalchemy.engine.base.Engine SELECT CAST('test collated returns' AS CHAR CHARACTER SET utf8mb4) COLLATE utf8mb4_bin AS anon_1
    2020-02-22 21:45:21,395 INFO sqlalchemy.engine.base.Engine {}
    2020-02-22 21:45:21,400 INFO sqlalchemy.engine.base.Engine select 1
    2020-02-22 21:45:21,400 INFO sqlalchemy.engine.base.Engine {}
    (1,)

    链接失败报错

    链接出现报错:

    No module named 'psycopg2'

    解决方案:

    pip install psycopg2

    出现报错:

    Collecting psycopg2
      Using cached psycopg2-2.8.4.tar.gz (377 kB)
        ERROR: Command errored out with exit status 1:
         command: /home/wang/.pyenv/versions/3.6.4/envs/flask_zhiliao/bin/python3.6 -c 'import sys, setuptools, tokenize; sys.argv[0] = '"'"'/tmp/pip-install-9pbzr1ah/psycopg2/setup.py'"'"'; __file__='"'"'/tmp/pip-install-9pbzr1ah/psycopg2/setup.py'"'"';f=getattr(tokenize, '"'"'open'"'"', open)(__file__);code=f.read().replace('"'"'
    '"'"', '"'"'
    '"'"');f.close();exec(compile(code, __file__, '"'"'exec'"'"'))' egg_info --egg-base /tmp/pip-install-9pbzr1ah/psycopg2/pip-egg-info
             cwd: /tmp/pip-install-9pbzr1ah/psycopg2/
        Complete output (7 lines):
        running egg_info
        creating /tmp/pip-install-9pbzr1ah/psycopg2/pip-egg-info/psycopg2.egg-info
        writing /tmp/pip-install-9pbzr1ah/psycopg2/pip-egg-info/psycopg2.egg-info/PKG-INFO
        writing dependency_links to /tmp/pip-install-9pbzr1ah/psycopg2/pip-egg-info/psycopg2.egg-info/dependency_links.txt
        writing top-level names to /tmp/pip-install-9pbzr1ah/psycopg2/pip-egg-info/psycopg2.egg-info/top_level.txt
        writing manifest file '/tmp/pip-install-9pbzr1ah/psycopg2/pip-egg-info/psycopg2.egg-info/SOURCES.txt'
        Error: b'You need to install postgresql-server-dev-X.Y for building a server-side extension or libpq-dev for building a client-side application.
    '
        ----------------------------------------
    ERROR: Command errored out with exit status 1: python setup.py egg_info Check the logs for full command output.

    解决方案:

    sudo apt-get install libpq-dev python-dev
    pip install psycopg2

     生成表:

    import os
    import subprocess
    
    def run():
        args = 'sqlacodegen --noviews --outfile ./models/model.py postgresql://postgres:postgres@192.168.1.1:5432/db_one'
        os.system(args)
        print('写入完成')
        # 拓展类定义 TODO
    
    if __name__ == '__main__':
        run()

    查看 model.py

    # coding: utf-8
    from sqlalchemy import Column, Date, ForeignKey, Integer, String, Text, text
    from sqlalchemy.dialects.postgresql import UUID
    from sqlalchemy.orm import relationship
    from sqlalchemy.ext.declarative import declarative_base
    
    Base = declarative_base()
    metadata = Base.metadata
    
    
    class Guide(Base):
        __tablename__ = 'guide'
    
        id = Column(UUID, primary_key=True, server_default=text("uuid_generate_v4()"))
        remark = Column(Text)
        status = Column(Integer, server_default=text("0"))
        addtime = Column(Date, server_default=text("now()"))
        enter_id = Column(UUID)
        filename = Column(String(255))
    
    class GuideCount(Base):
        __tablename__ = 'guide_count'
    
        id = Column(UUID, primary_key=True, server_default=text("uuid_generate_v4()"))
        downloader_id = Column(UUID)
        down_time = Column(Date, server_default=text("now()"))
        guide_id = Column(ForeignKey('guide.id'))
        counts= Column(Integer, server_default=text("0"))
    
        guide = relationship('Guide')
  • 相关阅读:
    再见,我的二零一七
    Tomcat 源码分析(二)——Request处理全过程
    帅案之上——作为开发者的远见与卓识
    Tomcat 源码分析(一)——启动与生命周期组件
    从代码质量谈起
    Java设计模式(四)——再谈观察者模式
    你所不了解的五条面试忠告
    见微知著——从自定义类型的operator==说起
    编码、散列与加解密
    数据结构与算法(c++)——双缓存队列
  • 原文地址:https://www.cnblogs.com/wxbn/p/12346443.html
Copyright © 2011-2022 走看看