#encoding: utf-8

from sqlalchemy import create_engine,Column,Integer,String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker HOSTNAME = '127.0.0.1' PORT = 3306 DATABASE = 'first_sqlalchemy' USERNAME = 'root' PASSWORD = '' #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) engine = create_engine(DB_URI) Base = declarative_base(engine)
# Session = sessionmaker(engine)
# session = Session() session = sessionmaker(engine)()#这里要解释下,学习python都是类里面的流程是__new__,类实例化一个空对象,__init__,为空对象构造属性,__call__,把对象变成一个函数调用
class sessionmaker(_SessionClassMethods):
  
def __init__(self, bind=None, class_=Session, autoflush=True,
autocommit=False,
expire_on_commit=True,
info=None, **kw):
#这一步就是sessionmaker(engine)干的事,实例化一个对象,后面加个括号是干嘛呢?,就是对象调用加括号调用了__call__方法。
def __call__(self, **local_kw):
"""Produce a new :class:`.Session` object using the configuration
established in this :class:`.sessionmaker`. In Python, the ``__call__`` method is invoked on an object when
it is "called" in the same way as a function:: Session = sessionmaker()
session = Session() # invokes sessionmaker.__call__() """
for k, v in self.kw.items():
if k == 'info' and 'info' in local_kw:
d = v.copy()
d.update(local_kw['info'])
local_kw['info'] = d
else:
local_kw.setdefault(k, v)
return self.class_(**local_kw) #返回了 self.class_(**local_kw) , self.class_ = Session(**local_kw)
#
 Session = sessionmaker(engine)() #其实就是 session = Session(**local_kw) 就是Session的对象

python前面,面向对象

class DistanceForm(object):
  def __init__(self, origin):
    self.origin = origin
    print "origin :"+str(origin)
  def __call__(self, x):
    print "x :"+str(x)
p = DistanceForm(100)
p(2000) 输出: origin :100
x :2000 ---------------------
#创建出来一个类关系映射到数据库
class Person(Base):
__tablename__ = 'person'
id = Column(Integer,primary_key=True,autoincrement=True)
name = Column(String(50))
age = Column(Integer)
country = Column(String(50)) def __str__(self):
return "<Person(name:%s,age:%s,country:%s)>" % (self.name,self.age,self.country)
Base.metadata.create_all() #把类的数据类型映射到数据库
#这里的__str__要不要解释呢,还是解释下吧!
class Person:

    def __init__(self,name):
self.name = name def __str__(self):
return self.name #这个__repr__是用来干嘛的
def __repr__(self):
return '每天都有好心情' p = Person('xiaowu') print(p) #当打印对象p时,
# 会默认调用__str__,如果类中没有,就会打印对象的内存地址 #Python中这个_repr_函数,对应repr(object)这个函数,返回一个可以用来表示对象的可打印字符串: '''
尝试生成这样一个字符串,将其传给 eval()可重新生成同样的对象 ; 否则,生成用尖括号包住的字符串,包含类型名和额外的信息(比如地址) ; 一个类(class)可以通过 __repr__() 成员来控制repr()函数作用在其实例上时的行为。
''' print(repr(p)) #来看下eval()的用法
#eval() 函数用来执行一个字符串表达式,并返回表达式的值。
#eval(expression[, globals[, locals]])
'''
expression -- 表达式。
globals -- 变量作用域,全局命名空间,如果被提供,则必须是一个字典对象。
locals -- 变量作用域,局部命名空间,如果被提供,可以是任何映射对象。
'''
#案例:
'''
>>>x = 7
>>> eval( '3 * x' )
21
>>> eval('pow(2,2)')
4
>>> eval('2 + 2')
4
>>> n=81
>>> eval("n + 4")
85
''' #案例演示: class Person: def __init__(self,name):
self.name = name def __str__(self):
return self.name #这个__repr__是用来干嘛的
def __repr__(self):
return "{}".format({"name":"xiaowu"}) p1 = Person('xiaohong') P = repr(p1) print(P) print(eval(P))

增加:

def add_data():
p1 = Person(name='zhiliao1',age=19,country='china')
p2 = Person(name='zhiliao2',age=20,country='china')
session.add_all([p1,p2])
session.commit()

查:

# 查
def search_data():
#获取所有的对象,query类型
# all_person = session.query(Person).all()
# for p in all_person:
# print(p)
# print(p.name)
# all_person = session.query(Person).filter_by(name='zhiliao').all()
# for x in all_person:
# print(x)
# all_person = session.query(Person).filter(Person.name=='zhiliao').all()
# print(all_person) # [<__main__.Person object at 0x0000015BCE1B4630>]
# for x in all_person:
# print(x)
person = session.query(Person).first()
print(person)

改:

# 改
def update_data():
person = session.query(Person).first()
person.name = 'ketang'
session.commit()

删:

# 删
def delete_data():
person = session.query(Person).first()
session.delete(person)
session.commit()

### 用session做数据的增删改查操作:
1. 构建session对象:所有和数据库的ORM操作都必须通过一个叫做`session`的会话对象来实现,通过以下代码来获取会话对象:
```python
from sqlalchemy.orm import sessionmaker

engine = create_engine(DB_URI)
session = sessionmaker(engine)()
```
2. 添加对象:
* 创建对象,也即创建一条数据:
```python
p = Person(name='zhiliao',age=18,country='china')
```
* 将这个对象添加到`session`会话对象中:
```python
session.add(p)
```
* 将session中的对象做commit操作(提交):
```python
session.commit()
```
* 一次性添加多条数据:
```python
p1 = Person(name='zhiliao1',age=19,country='china')
p2 = Person(name='zhiliao2',age=20,country='china')
session.add_all([p1,p2])
session.commit()
```
3. 查找对象:
```python
# 查找某个模型对应的那个表中所有的数据:
all_person = session.query(Person).all()
# 使用filter_by来做条件查询
all_person = session.query(Person).filter_by(name='zhiliao').all()
# 使用filter来做条件查询
all_person = session.query(Person).filter(Person.name=='zhiliao').all()
# 使用get方法查找数据,get方法是根据id来查找的,只会返回一条数据或者None
person = session.query(Person).get(primary_key)
# 使用first方法获取结果集中的第一条数据
person = session.query(Person).first()
```
4. 修改对象:首先从数据库中查找对象,然后将这条数据修改为你想要的数据,最后做commit操作就可以修改数据了。
```python
person = session.query(Person).first()
person.name = 'ketang'
session.commit()
```
5. 删除对象:将需要删除的数据从数据库中查找出来,然后使用`session.delete`方法将这条数据从session中删除,最后做commit操作就可以了。
```python
person = session.query(Person).first()
session.delete(person)
session.commit()

sqlalchemy基本的增删改查的更多相关文章

  1. SQLAlchemy的使用---增删改查

    #通过SQLAlchemy对数据库进行增删改查 # 想要操作数据库 先要打开数据库连接 from create_table import engine # 创建会话 - 打开数据库连接 from sq ...

  2. sqlalchemy 单表增删改查

    1.连接数据库,并创建session from sqlalchemy.orm import sessionmaker from sqlalchemy import create_engine engi ...

  3. SQLAlchemy表操作和增删改查

    一.SQLAlchemy介绍 SQLAlchemy是一个基于Python实现的ORM框架.该框架建立在 DB API之上,使用关系对象映射进行数据库操作,简言之便是:将类和对象转换成SQL,然后使用数 ...

  4. SQLAlchemy 增删改查 一对多 多对多

    1.创建数据表 # ORM中的数据表是什么呢? # Object Relation Mapping # Object - Table 通过 Object 去操纵数据表 # 从而引出了我们的第一步创建数 ...

  5. SQLAlchemyの增删改查

    用a*my写原味sql from sqlalchemy.ext.declarative import declarative_base from sqlalchemy import Column, I ...

  6. 13,SQLAlchemy 增删改查 一对多 多对多

    今天来聊一聊 Python 的 ORM 框架 SQLAlchemy Models 是配置和使用比较简单,因为他是Django自带的ORM框架,也正是因为是Django原生的,所以兼容性远远不如SQLA ...

  7. SQLAlchemy 增删改查 一对一 多对多

    首先要导入SQLAIchemy模块 from sqlalchemy.ect.declaative import declarative_base 创建orm基类 Base = declarative_ ...

  8. SQLAlchemy的增删改查 一对多 多对多

    Models只是配置和使用比较简单,因为是Django自带的ORM框架,所以兼容性不行,所以出现了SQLAlchemy,SQLAlchemy是比较全面的ORM框架,它可以在任何使用SQL查询时使用 以 ...

  9. SQLAlchemy02 /SQLAlchemy对数据的增删改查操作、属性常用数据类型详解

    SQLAlchemy02 /SQLAlchemy对数据的增删改查操作.属性常用数据类型详解 目录 SQLAlchemy02 /SQLAlchemy对数据的增删改查操作.属性常用数据类型详解 1.用se ...

随机推荐

  1. 【Winform-自定义控件】自定义控件学习+一个笑脸控件例子

    1.CompositeControls组合控件:在原有控件的基础上根据需要进行组合 2.ExtendedControls 扩展控件:继承自原有控件,添加一些新的属性和方法,绘制一些新元素 当每个But ...

  2. [Python之路] 多种方式实现并发Web Server

    下面我们使用Python来实现并发的Web Server,其中采用了多进程.多线程.协程.单进程单线程非阻塞的方式. 一.使用子进程来实现并发Web Server 参照 https://www.cnb ...

  3. laravel 视图流程控制,if switch for loop

    流程控制 除了模板继承和数据显示之外,Blade 还为常用的 PHP 流程控制提供了便利操作,例如条件语句和循环,这些快捷操作提供了一个干净.简单的方式来处理 PHP 的流程控制,同时保持和 PHP ...

  4. vueCli和脚手架

    vue CLI相当于一个基于vue开发的框架:可以用来快速开发vue项目:   1.安装 由于需要用到npm命令,所以要先安装node.js:     node.js下载地址:https://node ...

  5. 类中定义成员方法。加不加public有什么区别?

    class Trangle{ double sideA, sideB, sideC, area, length; boolean flag; Trangle(double a, double b, d ...

  6. Vue_(组件)实例生命周期钩子

    Vue生命周期中文文档 传送门 Vue生命周期:Vue实例从创建到销毁的过程,称为Vue的生命周期: Vue生命周期钩子:又称为Vue生命周期钩子方法/函数,是Vue为开发者提供的方法,我们可以通过这 ...

  7. $\LaTeX$数学公式大全11

    $11\ Other\ Styles\ (math\ mode\ only)$ $Caligraphic\ letters:$ \mathcal{A}$etc.:\mathcal{ABCDEFGHIJ ...

  8. [译]Webpack 4 — 神秘的SplitChunksc插件

    原文链接:Webpack 4 - Mysterious SplitChunks Plugin 官方发布了 webpack 4,舍弃了之前的 commonChunkPlugin,增加了 SplitChu ...

  9. elasticsearch与kibana安装过程(linux)

    elasticsearch与kibana安装 下载 Elasticsearch 官网:https://www.elastic.co/,elastic search应用本质就是一个jvm进程,所以需要J ...

  10. pure-ftpd搭建简单的Ubuntu FTP服务器

    Linux下的ftpd很多,Ubuntu下常用vsftpd, proftpd和pure-ftpd,当初使用的就是proftpd. 不过前两者有个致命的问题就是内码转换,它们默认使用UTF-8编码,而W ...