今天写SQLAlchemy数据库

首先介绍ORM的概念:

ORM,Object类,Relationship:关系,Mapping:映射,也就是模型关系映射

flask-sqlalchemy是一套ORM框架

ORM的好处:可以让我们操作数据库跟操作对象一样,非常方便,因为一个表就抽象成一个类,一条数据就抽象成该类的一个对象;把高层的面向对象操作转换成低层的数据库指令

### Flask-SQLAlchemy的使用:
1. 初始化和设置数据库配置信息:
* 使用flask_sqlalchemy中的SQLAlchemy进行初始化:
```
from flask_sqlalchemy import SQLAlchemy
app = Flask(__name__)
db = SQLAlchemy(app)
```
2. 设置配置信息:在`config.py`文件中添加以下配置信息:
```
# dialect+driver://username:password@host:port/database
DIALECT = '数据库类型'
DRIVER = 'pymysql'(python2.7是mysqldb)
USERNAME = '用户名'
PASSWORD = '密码'
HOST = '127.0.0.1'
PORT = '3306'
DATABASE = '数据库名称'

SQLALCHEMY_DATABASE_URI = "{}+{}://{}:{}@{}:{}/{}?charset=utf8".format(DIALECT,DRIVER,USERNAME,PASSWORD,HOST
,PORT,DATABASE)

SQLALCHEMY_TRACK_MODIFICATIONS = False
```

3. 在主`app`文件中,添加配置文件:
```
app = Flask(__name__)
app.config.from_object(config)
db = SQLAlchemy(app)
```
4. 做测试,看有没有问题:
```
db.create_all()
```
如果没有报错,说明配置没有问题,如果有错误,可以根据错误进行修改。

### 使用Flask-SQLAlchemy创建模型与表的映射:
1. 模型需要继承自`db.Model`,然后需要映射到表中的属性,必须写成`db.Column`的数据类型。
2. 数据类型:
* 'db.Integer'代表的是整形.
* 'db.String'代表的是'varchar',需要指定最长的长度。
* `db.Text`代表的是`text`。
3. 其他参数:
* `primary_key`:代表的是将这个字段设置为主键。
* `autoincrement`:代表的是这个主键为自增长的。
* `nullable`:代表的是这个字段是否可以为空,默认可以为空,可以将这个值设置为`False`,在数据库中,这个值就不能为空了。
4. 最后需要调用`db.create_all`来将模型真正的创建到数据库中。

数据库的增删改查:

主app文件代码如下:

  1. from flask import Flask
  2. from flask_sqlalchemy import SQLAlchemy
  3. import config
  4.  
  5. app = Flask(__name__)
  6. app.config.from_object(config)
  7.  
  8. db = SQLAlchemy(app)
  9.  
  10. # article表:
  11. # create table article(
  12. # id int primary key autoincrement,
  13. # title varchar(100) not null,
  14. # content text not null,
  15. # )
  16. class Article(db.Model):
  17. __tablename__ = 'article'
  18. id = db.Column(db.Integer,primary_key=True,autoincrement=True)
  19. title = db.Column(db.String(100),nullable=False)
  20. content = db.Column(db.Text,nullable=False)
  21.  
  22. db.create_all()
  23.  
  24. @app.route('/')
  25. def hello_world():
  26. # #增加:
  27. article1 = Article(title='aaa',content='bbb')
  28. db.session.add(article1)
  29. #事务
  30. db.session.commit()
  31.  
  32. # #查
  33. # # select * from article where title='aaa';
  34. # result = Article.query.filter(Article.title =='aaa').all()
  35. # article1 = result[0]
  36. # print(article1.title,article1.content)
  37.  
  38. # #改:
  39. # #1.先把你要更改的数据查找出来
  40. # article1 = Article.query.filter(Article.title == 'aaa').first()
  41. # #2.把这条数据,按你需要的地方进行修改
  42. # article1.title = 'new title'
  43. # #3.做事务的提交
  44. # db.session.commit()
  45.  
  46. # #删:
  47. # #1.把需要删除的数据查找出来
  48. # article1 = Article.query.filter(Article.content == 'bbb').first()
  49. # #2.把这条数据删除掉
  50. # db.session.delete(article1)
  51. # #3.做事务提交
  52. # db.session.commit()
  53.  
  54. return 'Hello World!'
  55.  
  56. if __name__ == '__main__':
  57. app.run()

### Flask-SQLAlchemy数据的增、删、改、查:
1. 增:
```
# 增加:
article1 = Article(title='aaa',content='bbb')
db.session.add(article1)
# 事务
db.session.commit()
```

注意,这里数据库的操作都在主视图函数里执行,因此只有在打开网页的情况下,数据库的操作才能被执行

2. 查:
```
# 查
# select * from article where article.title='aaa';
article1 = Article.query.filter(Article.title == 'aaa').first()
print 'title:%s' % article1.title
print 'content:%s' % article1.content
```
3. 改:
```
# 改:
# 1. 先把你要更改的数据查找出来
article1 = Article.query.filter(Article.title == 'aaa').first()
# 2. 把这条数据,你需要修改的地方进行修改
article1.title = 'new title'
# 3. 做事务的提交
db.session.commit()
```
4. 删:
```
# 删
# 1. 把需要删除的数据查找出来
article1 = Article.query.filter(Article.content == 'bbb').first()
# 2. 把这条数据删除掉
db.session.delete(article1)
# 3. 做事务提交
db.session.commit()
```

Flask web开发之路七的更多相关文章

  1. Flask web开发之路九

    flask_scripts介绍 项目结构如下: flask_script_demo.py文件: from flask import Flask app = Flask(__name__) @app.r ...

  2. Flask web开发之路一

    之前学过一段时间的flask,感觉还是挺好用的,自己的专利挖掘项目也想这个web框架来搭建,于是重新开始基础学习 环境:win10,python3.6,pycharm2017,虚拟环境virtuale ...

  3. Flask web开发之路十四

    今天开始Flask的实战,创建一个项目,实现包括用户登录.注册.注销.发表博客.评论以及检索等功能 首先给出项目结构: 1.config.py文件: 存放各种配置信息 import os # dial ...

  4. Flask web开发之路十三

    g对象 ### 保存全局变量的g属性:g:global1. g对象是专门用来保存用户的数据的.2. g对象在一次请求中的所有的代码的地方,都是可以使用的. 项目结构: g_demo.py文件代码: f ...

  5. Flask web开发之路十二

    ge请求和post请求 ### get请求和post请求:1. get请求: * 使用场景:如果只对服务器获取数据,并没有对服务器产生任何影响,那么这时候使用get请求. * 传参:get请求传参是放 ...

  6. Flask web开发之路十一

    首先写一下cookie和session的概念,然后是Flask中session的工作机制以及操作session ### cookie: 1. `cookie`出现的原因:在网站中,http请求是无状态 ...

  7. Flask web开发之路十

    首先介绍循环引用的问题: 当一个模块需要引用另一个模块的类,而另一个模块又需要引用这个模块的类时,就出现了循环引用,而没法导入类,这时候可以切断其中一条引用路径,增加一个模块 项目结构: models ...

  8. Flask web开发之路八

    今天写Flask_SQLAlchemy的外键及其关系 ### Flask-SQLAlchemy外键及其关系: 主app文件代码: from flask import Flask from flask_ ...

  9. Flask web开发之路六

    紧接着上篇文档,写模板继承和block,URL链接和加载静态文件 模板继承和block 项目结构 主app文件代码: from flask import Flask,render_template a ...

随机推荐

  1. Javascript框架的自定义事件(转)

    很多 javascript 框架都提供了自定义事件(custom events),例如 jquery.yui 以及 dojo 都支持“document ready”事件.而部分自定义事件是源自回调(c ...

  2. 如何生成唯一的server Id,server_id为何不能重复?

    我们都知道MySQL用server-id来唯一的标识某个数据库实例,并在链式或双主复制结构中用它来避免sql语句的无限循环.这篇文章分享下我对server-id的理解,然后比较和权衡生成唯一serve ...

  3. javascript中的数据结构

    Javascript中的关键字   abstract     continue      finally      instanceof      private       this boolean ...

  4. 安装配置OSA运维管理平台

    1.下载完整包V1.0.2wget http://www.osapub.com/download/OSA_BETA_V1.0.2.tar.gzV1.0.5wget http://www.osapub. ...

  5. C# 版本的24点实现

    C# 版本的24点实现. 已经实现基本功能,可以正确的算 3, 3, 8, 8 这类组合. 稍加修改就可以支持任意数目的操作数和操作符组合形成的四则运算表达式,不限于24点. 代码还比较简单粗糙,晚一 ...

  6. stale element reference: element is not attached to the page document 异常

    在执行脚本时,有时候引用一些元素对象会抛出如下异常 org.openqa.selenium.StaleElementReferenceException: stale element referenc ...

  7. [na][dhcp]dhcp细枝末节&dhcp防攻

    回顾了下,真是以前是一种感觉以后是一种感觉. 特点: 1.dhcp服务器上的配置的网关不一定要有这个ip 2.dhcp服务只是个类似数据库而已(如果不在一个lan). 3. 如果dhcp不在一个lan ...

  8. Forward+ Shading架构

    Forward+ = Tile based Light Culling + Tile based Forward Rendering 整体渲染架构分为如下3大步骤: 1.PrePass将场景的min ...

  9. IDEA的maven项目中 静态文件编译的问题

    IDEA的maven项目中,默认源代码目录下的xml等资源文件并不会在编译的时候一块打包进classes文件夹,而是直接舍弃掉. 如果使用的是Eclipse,Eclipse的src目录下的xml等资源 ...

  10. Android Gallery实现3D相册(附效果图+Demo源码)

    今天因为要做一个设置开机画面的功能,主要是让用户可以设置自己的开机画面,应用层需要做让用户选择开机画面图片的功能.所以需要做一个简单的图片浏览选择程序.最后选用Gallery作为基本控件.加入了一些炫 ...