内容简介:数据库,web开发中总是离不开这个核心应用,可以说web开发的核心就是数据库。但数据库是一个泛称,通常我们说的 数据库是指关系型数据库,此外还有非关系型数据库。在这篇文章中,我们单指关系型数据库。相信大家都看过excel表格,在PostgreSQL中,每个数据库包含多个schema,每个schema中可以包含多个表,而这个表, 就好比是我们平时见到的excel表格,但是它的特点是列数是固定的,行数是可变的。当然,列也可以通过关系型数据库管理系统 来更改。什么叫做关系型数据库管理系统呢?我们要这样想,数据库
数据库,web开发中总是离不开这个核心应用,可以说web开发的核心就是数据库。但数据库是一个泛称,通常我们说的 数据库是指关系型数据库,此外还有非关系型数据库。在这篇文章中,我们单指关系型数据库。
相信大家都看过excel表格,在PostgreSQL中,每个数据库包含多个schema,每个schema中可以包含多个表,而这个表, 就好比是我们平时见到的excel表格,但是它的特点是列数是固定的,行数是可变的。当然,列也可以通过关系型数据库管理系统 来更改。什么叫做关系型数据库管理系统呢?
我们要这样想,数据库是用来管理数据的,数据是要存储在操作系统的磁盘上的,而我们平常所说的数据库,实际上就是帮我们 管理这些文件(以及其他相关东西)的管理系统。而我们操纵数据库便是通过 SQL 来完成的。
常见的关系型数据库管理系统(以下简称数据库)有SQLite,MySQL,Postgesql等。他们各有特点,例如 SQLite 一般用于移动设备, 而 MySQL 和PostgreSQL则用于服务器。
在日常开发中有一个必须要搞清楚的概念,就是 表的连接 如果你去面试, 那么将会有很大概率被问到:什么是内连接,什么是外连接。。。等等。
SQLAlchemy
在日常开发中,一般我们很少直接写SQL,一般都会用ORM:Object-relational mapping,通过ORM我们可以把类和数据库中的表 对应起来,例如 Python 中ORM的黄金标准便是 SQLAlchemy 。
学习SQLAlchemy我推荐阅读官方的教程: http://docs.sqlalchemy.org/en/latest/orm/tutorial.html
我们来看一个SQLAlchemy的例子,声明一个表:
from sqlalchemy.ext.declarative import declarative_base from sqlalchemy import Column, Integer, String Base = declarative_base() class User: __tablename__ = 'users' id = Column(Integer, primary_key=True) name = Column(String(32)) fullname = Column(String(32)) nickname = Column(String(64), nullable=False) passwd = Column(String(128), nullable=False)
而查询,则是类似这样:
>>> session.query(User).filter( User.id == 1 ).first()
SQLAlchemy会自动把上述的Python代码翻译成SQL,执行,然后映射成User类的示例,于是结果便可以 user.name
这样用。
migration工具
用SQLAlchemy的时候我们还能获得一个好处,便是我们可以很方便的知道表是怎么定义的,此外,我们还可以借助 alembic 来做数据库变更记录,但是用alembic的时候我们也许不想手动 写变更,想让alembic自己生成,那么我们要好好地组织SQLAlchemy的代码,让SQLAlchemy的metadata可以记录下所有的表,然后 在alembic的配置里引入这个metadata,便可以通过alembic生成。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- (关系型)数据库优化总结
- PipelineDB 0.9.8 发布,关系数据库
- 微服务和数据库到底是什么关系?
- 基于关系数据库的数据库功能依赖性
- 如何将传统关系数据库的数据导入Hadoop?
- 原创 社交系统中用户好友关系数据库设计
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数学建模算法与应用
司守奎、孙玺菁 / 国防工业出版社 / 2011-8 / 49.00元
《数学建模算法与应用》主要内容简介:作者司守奎、孙玺菁根据多年数学建模竞赛辅导工作的经验编写《数学建模算法与应用》,涵盖了很多同类型书籍较少涉及的新算法和热点技术,主要内容包括时间序列、支持向量机、偏最小二乘面归分析、现代优化算法、数字图像处理、综合评价与决策方法、预测方法以及数学建模经典算法等内容。《数学建模算法与应用》系统全面,各章节相对独立。《数学建模算法与应用》所选案例具有代表性,注重从不......一起来看看 《数学建模算法与应用》 这本书的介绍吧!