sqlalchemy数据库分层操作

Posted 金色旭光

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sqlalchemy数据库分层操作相关的知识,希望对你有一定的参考价值。

 在学习sqlalchemy操作中,最常见的就是如下的示例,一个文件基本上包含了数据库的增删改查。sqlalchemy的具体操作我就不再详细说明了。流程大概是:

  1. 定义表
  2. 创建数据库引擎
  3. 创建表
  4. 插入数据
  5. 查询数据
 1 #coding:utf-8
 2 
 3 from sqlalchemy import Column,String,create_engine,MetaData
 4 from sqlalchemy.orm import sessionmaker
 5 from sqlalchemy.ext.declarative import declarative_base
 6 from sqlalchemy.dialects.mysql import INTEGER,CHAR
 7 
 8 Base = declarative_base()
 9 
10 meta = MetaData()
11 
12 
13 #定义User对象
14 class User(Base):
15     __tablename__ = user_one
16 
17     id = Column(String(20),primary_key=True)
18     name = Column(String(20))
19 
20 #初始数据库连接
21 engine = create_engine(mysql+mysqldb://root:[email protected]:3306/test)
22 
23 #创建DBsession
24 DBSession = sessionmaker(bind=engine)
25 
26 #创建session会话,数据库操作的基石。
27 session = DBSession()
28 
29 #在数据库中创建表user
30 User.metadata.create_all(bind=engine)
31 
32 #插入数据
33 new_user = User(id=1,name=kiit)
34 
35 #提交数据到session
36 session.add(new_user)
37 
38 #提交到数据库
39 session.commit()
40 
41 #查询User表
42 user_data = session.query(User).all()
43 
44 #关闭session连接
45 session.close()
46 
47 #循环将返回的数据打印
48 for i in user_data:
49     print i.id,i.name

 

 

而在实际的生产环境中根本不可能使用一个文件完成数据的这么多的操作。数据库的操作大体分为:增、删、改、查 。那么就分为这四个部分去完成数据的操作

1、定义数据库

models.py

 1 #coding:utf-8
 2 
 3 from sqlalchemy import Column,CHAR,INTEGER
 4 from sqlalchemy.ext.declarative import declarative_base
 5 
 6 Base = declarative_base()
 7 
 8 class User(Base):
 9     __tablename__ = "user"
10 
11     id = Column(CHAR(20),primary_key = True)
12     name = Column(CHAR(20))
13 
14 
15 class Solary(Base):
16     __tablename__ = "solary"
17  
18     id = Column(INTEGER,primary_key = True)
19     name = Column(CHAR(20))
20     num =  Column(CHAR(20)) 

 

2、创建数据库

sql_create.py

 1 #coding:utf-8
 2 
 3 from sqlalchemy import create_engine
 4 from models import *
 5 
 6 engine = create_engine(mysql+mysqldb://root:[email protected]:3306/test)
 7 
 8 def create_table(table_name):
 9     table_name.metadata.create_all(engine)
10     print "创建成功"

 

3、插入数据

sql_insert.py

 1 #coding:utf-8
 2 
 3 from sqlalchemy.orm import sessionmaker
 4 from sqlalchemy.ext.declarative import declarative_base
 5 from sqlalchemy.dialects.mysql import INTEGER,CHAR
 6 from sqlalchemy import create_engine,Column
 7 
 8 
 9 def insert(new_data):
10 
11     Base = declarative_base()   
12     engine = create_engine(mysql+mysqldb://root:[email protected]:3306/test)
13     print "创建数据库引擎"
14 
15     DBSession = sessionmaker(bind=engine)
16     session = DBSession()
17     print "创建session对象"
18         
19     session.add(new_data)
20     print "添加数据到session"
21 
22     session.commit()
23     print "提交数据到数据库"
24 
25     session.close()
26     print "关闭数据库连接"
27 
28 if __name__ == "__main__":
29     insert(User)

 

 4、查询数据

sql_select.py

 1 #coding:utf-8
 2 
 3 from sqlalchemy.orm import sessionmaker
 4 from sqlalchemy import create_engine
 5 from models import *
 6 
 7 def select(table_name):
 8     engine = create_engine("mysql+mysqldb://root:[email protected]:3306/test")
 9     print "初始化数据库引擎"
10 
11     DBSession = sessionmaker(bind=engine)
12     session = DBSession()
13     print "创建session对象"
14 
15     table_data = session.query(User).all()
16     print "查询"
17 
18     session.close()
19 
20     return table_data
21 
22 
23 if __name__ == "__main__":
24     select_fun(User)

 

 5、使用增,删,改函数

test.py

 1 #coding:utf-8
 2 
 3 from models import *
 4 from sql_create import * 
 5 from sql_select import *
 6 
 7 
 8 create_table(Solary)
 9 
10 new_user = User(id="8",name="miko")
11 
12 insert(new_user)
13 print "产生新的用户"
14 
15 
16 data = select(User)
17 
18 for i in data:
19     print i.id,i.name

 

函数化操作的好处就是避免重复代码,并且能够解开耦合。想要查询数据库时不需要先定义table,想要删除数据库时不需要再创建引擎。以上代码经过多次测试,亲测可用。

以上是关于sqlalchemy数据库分层操作的主要内容,如果未能解决你的问题,请参考以下文章

SqlAlchemy操作

SQLAlchemy 递归查询结果集排序

Django ORM和SQLAlchemy类比

python SQLAlchemy

了解 SQLAlchemy

Python SQLAlchemy基本操作和常用技巧