python ORM的使用
安装 >pip install sqlalchemy
#coding=utf-8
'''
原始的sql语句
CREATE TABLE user (
id INTEGER NOT NULL AUTO_INCREMENT,
name VARCHAR(32),
password VARCHAR(64),
PRIMARY KEY (id) )
'''
#使用orm代码 import sqlalchemy
from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, String
engine = create_engine("mysql+pymysql://root:123456@192.168.70.129/my", #建立数据库连接
encoding='utf-8', echo=False) #打印echo信息
Base = declarative_base() # 生成orm基类
class User(Base):
__tablename__ = 'user1' # 表名
id = Column(Integer, primary_key=True)
name = Column(String(32))
password = Column(String(64)) def __repr__(self):
return '%s name:%s' % (self.id, self.name) class User2(Base):
__tablename__ = 'user2' # 表名
id = Column(Integer, primary_key=True)
name = Column(String(32))
password = Column(String(64)) def __repr__(self):
return '%s name:%s'%(self.id,self.name) Base.metadata.create_all(engine) # base运行之后就会把继承他的所有子类表创建起来
#另一种不常用的创建方式
'''
from sqlalchemy import Table, MetaData, Column, Integer, String, ForeignKey
from sqlalchemy.orm import mapper
metadata = MetaData()
user = Table('user', metadata,
Column('id', Integer, primary_key=True),
Column('name', String(50)),
Column('fullname', String(50)),
Column('password', String(12))
)
class User(object):
def __init__(self, name, fullname, password):
self.name = name
self.fullname = fullname
self.password = password
mapper(User,
user) # the table metadata is created separately with the Table construct, then associated with the User class via the mapper() function
'''
#————————————————————————增加————————————————————
from sqlalchemy.orm import sessionmaker #操作表要导入这个模块
Session_class = sessionmaker(bind=engine) # 创建与数据库的会话session class ,
# 注意,这里返回给session的是个class,不是实例,与数据库连接绑定bind=engine
Session = Session_class() # 生成session实例 相当于pymysql里面的cursor
# user_obj = User(name="dzz", password="123456") # 生成你要创建的数据对象
# user_obj1 = User(name="asd", password="123456")
# user_obj2 = User2(name="asd", password="123456")
# print(user_obj.name, user_obj.id) # 此时还没创建对象呢,不信你打印一下id发现还是None
# Session.add(user_obj) # 把要创建的数据对象添加到这个session里, 一会统一创建
# Session.add(user_obj2)
# Session.add(user_obj1)
#
# print(user_obj.name, user_obj.id) # 此时也依然还没创建
# Session.commit() # 现此才统一提交,创建数据
# print(user_obj.name, user_obj.id,user_obj.password)
#——————————————查询
data = Session.query(User2).filter_by(name = 'zq').all() #返回一个列表,查一条
print '++>',data[0].name,data[0].password
print '++>',data data = Session.query(User2).filter_by().all() #在User2表的类里面加入了__repr__内置方法,就可显示了
print data data = Session.query(User2).filter(User2.id>1).first() #单条,
print '>>',data data = Session.query(User2).filter(User2.id>1).filter(User2.id<3).first() #多条
print '>>',data #修改——————————
data = Session.query(User2).filter(User2.id>1).filter(User2.id<3).first() #多条件
print '>>',data
data.name = 'rest'
data.password = 'qqqqq'
Session.commit()
data = Session.query(User2).filter(User2.id>1).filter(User2.id<3).all()
print '>>',data
#回滚——————
user_obj4 = User2(name="zte", password="123456")
Session.add(user_obj4)
print '>>>#',Session.query(User2).filter(User2.name.in_(['zte'])).all()
Session.rollback()
print Session.query(User2).filter(User2.name.in_('zte')).all()
#分组统计
data = Session.query(User2).filter(User2.id>1).filter(User2.id<4).count()
print data from sqlalchemy import func #分组需要导入一个模块
data = Session.query(User2.name,func.count(User2.name)).group_by(User2.name).all()
print data #连表查询
print Session.query( User2,User).filter(User2.id == User.id).all()
#print Session.query( User2).join(User).all() #要求两个表有外键关联
#print Session.query( User2).join(User,isouter=True).all()
python ORM的使用的更多相关文章
- python/ORM操作详解
一.python/ORM操作详解 ===================增==================== models.UserInfo.objects.create(title='alex ...
- Django和SQLAlchemy,哪个Python ORM更好?
ORM是什么? 在介绍Python下的两个ORM框架(Django和SQLAlchemy)的区别之前,我们首先要充分了解ORM框架的用途. ORM代表对象关系映射.ORM中的每个单词解释了他们在实际项 ...
- Python ORM框架之 Peewee入门
之前在学Django时,发现它的模型层非常好用,把对数据库的操作映射成对类.对象的操作,避免了我们直接写在Web项目中SQL语句,当时想,如果这个模型层可以独立出来使用就好了,那我们平台操作数据库也可 ...
- python orm框架
#!/usr/bin/python# -*- coding: utf-8 -*-from sqlalchemy import create_enginefrom sqlalchemy import T ...
- MySQL(Python+ORM)
本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb ...
- Python ORM框架之SQLAlchemy
前言: Django的ORM虽然强大,但是毕竟局限在Django,而SQLAlchemy是Python中的ORM框架: SQLAlchemy的作用是:类/对象--->SQL语句--->通过 ...
- Python ORM框架SQLAlchemy学习笔记之数据添加和事务回滚介绍
1. 添加一个新对象 前面介绍了映射到实体表的映射类User,如果我们想将其持久化(Persist),那么就需要将这个由User类建立的对象实例添加到我们先前创建的Session会话实例中: 复制代码 ...
- python ORM - sqlalchemy 操作使用
python操作数据库 使用 ORM - sqlalchemy,pymsql 安装: pip install pymsq pip install sqlalchemy 一. '''连接数据库''' ...
- Python ORM
本章内容 ORM介绍 sqlalchemy安装 sqlalchemy基本使用 多外键关联 多对多关系 表结构设计作业 ORM介绍 如果写程序用pymysql和程序交互,那是不是要写原生sql语句.如果 ...
- python orm / 表与model相互转换
orm英文全称object relational mapping,就是对象映射关系程序,简单来说我们类似python这种面向对象的程序来说一切皆对象,但是我们使用的数据库却都是关系型的,为了保证一致的 ...
随机推荐
- Linux性能优化从入门到实战:13 内存篇:内存指标/工具总结、问题定位和调优
内存性能指标 系统内存指标 已用内存和剩余内存很容易理解,就是已经使用和还未使用的内存. 共享内存是通过 tmpfs 实现的,所以它的大小也就是 tmpfs 使用的内存大小.tmpfs 其实也是一种特 ...
- k8s阅读笔记3-k8s的网络解析
前言 阅读地址https://rootsongjc.gitbooks.io/kubernetes-handbook/content/concepts/flannel.html k8s客户端的启动 顺序 ...
- Windows系统中,循环运行.bat/.exe等文件
一.创建循环运行的run-everySecond.vbs文件[双击次文件即可启动运行] dim a set a=CreateObject("Wscript.Shell") Do # ...
- 【LeetCode】二分 binary_search(共58题)
[4]Median of Two Sorted Arrays [29]Divide Two Integers [33]Search in Rotated Sorted Array [34]Find F ...
- MyBatis体系学习总览
MyBatis特点:MyBatis是面向SQL的,核心是SQL结果和Map的映射.不要求一定与实体对象进行映射. MyBatis 可以使用 XML 或注解进行配置和映射, MyBatis 通过将参数映 ...
- 未能加载文件或程序集 ICSharpCode.SharpZipLib
Ui调用Webservice ,Webservice调用Bl BL中明明有那个dll文件 后来发现是webservice里面没有 在附加调试的时候,断点在bl层中
- 4412 使用usb摄像头拍照YUYV格式
一.内核设置 Linux内核中已经带有很完善的USB摄像头驱动,支持几乎所有的USB摄像头,我们只需要配置内核,选择上相应的Sensor型号即可. 配置内核,支持USB摄像头: Device Driv ...
- Java Web学习笔记之---EL和JSTL
Java Web学习笔记之---EL和JSTL (一)EL (1)EL作用 Expression Language(表达式语言),目的是代替JSP页面中复杂的代码 (2)EL表达式 ${变量名} ( ...
- Linux 系统下文件夹与文件的读写可执行权限问题
linux是一个多用户操作系统,linux对文件系统内的所有文件,实行了严格的权限划分管理.防止没有权限的用户访问某个文件.linux文件或目录的权限分为 读.写.可执行三种权限.文件访问的用户类别分 ...
- Win10真正好用之处
第一步. 关闭无用服务 刚装好Win10的时候,整部电脑响应很慢,有时什么都不做,硬盘灯也能狂闪半天.很明显,这是微软爸爸默认开启的服务未被及时关闭所致. 网上有很多文章指导新手如何关闭系统服务,但 ...