#-*-coding:utf-8-*-
#__author__ = "logan.xu" import sqlalchemy
from sqlalchemy import create_engine,funcfrom sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column,Integer,String
from sqlalchemy.orm import sessionmaker engine=create_engine("mysql+pymysql://root:12345678@localhost/news",encoding='utf-8',echo=True)
Base=declarative_base() class User(Base):
__tablename__='user'
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) #创建表结构 Session_class=sessionmaker(bind=engine)
#创建与数据库的会话session class,注意,这里返回给session的是这个class,不是实例
Session=Session_class() #生成session实例 #查询
#data=Session.query(User).filter(User.id>2).all() #filter可以写大于,filter_by不可用写大于
#data=Session.query(User).filter(User.id>1).filter(User.id<3).all() #列取多个条件查询
#data=Session.query(User).filter_by(id=2).all()
#data=Session.query(User).filter(User.id==2).all()
#data=Session.query(User).filter_by().first() #列出一个
#print(data) #修改
#data=Session.query(User).filter(User.id>1).filter(User.id<4).first()
#print(data)
#data.name="Jack Liu"
#data.passwod="Shit happens" #回滚
#fake_user=User(name='Rain',password='12345')
#Session.add(fake_user)
#print(Session.query(User).filter(User.name.in_(['Jack','rain'])).all())
#
#Session.rollback() #此时你rollback一下
#print("after rollback")
#
#print(Session.query(User).filter(User.name.in_(['Jack','rain'])).all())
#Session.commit() #现在才统一提交,创新数据 #分组统计
fake_user=User(name='Rain',password='12345')
Session.add(fake_user) print(Session.query(User.name,func.count(User.name)).group_by(User.name).all())
Session.commit() #现在才统一提交,创新数据

最新文章

  1. 微框架spark--api开发利器
  2. js与java正则表达式处理字符串问题
  3. History lives on in this distinguished Polish city II 2017/1/5
  4. array_filter函数
  5. extjs ajax java简单精美验证码实现 有图
  6. DP ZOJ 2745 01-K Code
  7. ASP.NET导入导出
  8. JSON Viewer
  9. 从K近邻算法谈到KD树、SIFT+BBF算法
  10. 为在MyEclipse中配置Tomcat服务器郁闷的朋友们解决郁闷
  11. redis ltrim命令
  12. Visio中添加、移动或删除形状上的连接点的方法
  13. Maven常用插件配置和使用
  14. hide the navigationBar and tabBar
  15. PHP爬虫百度图片
  16. Socket实例
  17. contourf和contour用法区别
  18. 【译】AI 让科技公司变得更强大吗
  19. private,protected,public和default的区别
  20. Nodejs学习笔记(七)—Node.js + Express 构建网站简单示例

热门文章

  1. PostgreSQL数据库结构
  2. 第十篇 -- 学习C++宝典2005版
  3. macOS下将可执行文件索引位置增添到PATH中
  4. java try_catch 分析
  5. 电脑软件安装过程文档.BA
  6. python语法入门
  7. KMP算法的详细解释
  8. 编程熊讲解LeetCode算法《二叉树》
  9. 小知识get:利用单臂路由实现不同vlan间路由
  10. HCNA Routing&amp;Switching之地址转换技术NAT