解读sqlalchemy的常用数据类型有哪些
作者:现在叫阿汤哥 发布时间:2022-02-19 19:42:17
sqlalchemy的常用数据类型
数据类型 | python数据类型 | 说明 |
Integer | int | 整形 |
String | str | 字符串 |
Float | float | 浮点型 |
DECIMAL | decimal.Decimal | 定点型 |
Boolean | bool | 布尔型 |
Date | datetime.date | 日期 |
DateTime | datetime.datetime | 日期和时间 |
Time | datetime.time | 时间 |
Enum | str | 枚举类型 |
Text | str | 文本类型 |
LongText | str | 长文本类型 |
既然我们知道sqlalchemy常用数据类型有哪些,下面我们就来看看这些数据类型的用法。
首先,打开我们py代码编辑神器(pycharm),因为之前跟大家讲了许多关于数据库基本配置及连接的文章,在这里我就不在阐述了。
而是直接在此基础上讲解sqlalchemy数据类型的用法。
from sqlalchemy import create_engine,Column,Integer
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm.session import sessionmaker
DIALCT = "mysql"
DRIVER = "pymysql"
USERNAME = "root"
PASSWORD = "admin"
HOST = "127.0.0.1"
PORT = "3306"
DATABASE = "test"
DB_URI = "{}+{}://{}:{}@{}:{}/{}?charset=utf8".format(DIALCT,DRIVER,USERNAME,PASSWORD,HOST,PORT,DATABASE)
engine = create_engine(DB_URI)
Base = declarative_base(engine)
session = sessionmaker(engine)()
class Person(Base):
__tablename__ = "person"
id = Column(Integer , primary_key=True , autoincrement=True)
Base.metadata.drop_all()
Base.metadata.create_all()
在讲解前,我们先测试下模型是否能够成功映射到数据库中,运行上述代码
没有报错,我们在打开mysql命令行工具,输入以下命令
嗯,person库表已成功映射到数据库中。
OK,万事俱备。下面我们就逐一来讲类型的用法。
第一种:Integer
我们在Person模型中新增一个age字段
class Person(Base):
__tablename__ = "person"
id = Column(Integer , primary_key=True , autoincrement=True)
age = Column(Integer)
然后向表中插入一条数据
p = Person(age = 22)session.add(p)session.commit()
运行上述代码,然后输入下方命令检查数据是否插入到表中以及该字段是否为int类型
第二种:String
我们先将age字段注释掉,然后从sqlalchemy导入String类型(使用某种数据类型前,记得将该数据类型从sqlalchemy导入,由于篇幅太长,我们下方数据类型省略该步骤),再新增一个name字段(括号中的20表示该字符串最大长度为20)
class Person(Base):
__tablename__ = "person"
id = Column(Integer , primary_key=True , autoincrement=True)
# age = Column(Integer)
name = Column(String(20))
插入一条数据试试
p = Person(name = "tom")
session.add(p)
session.commit()
运行上述代码,然后输入下方命令检查数据是否插入到表中以及该字段是否为string类型(映射到数据库,对应varchar类型)
第三种:Float
什么情况下会用到Float类型?比如存储体重、价格等.....
class Person(Base):
__tablename__ = "person"
id = Column(Integer , primary_key=True , autoincrement=True)
# age = Column(Integer)
# name = Column(String(20))
price = Column(Float)
插入测试数据
p = Person(price = 123.456789)
session.add(p)
session.commit()
运行上述代码,然后输入下方命令检查数据是否插入到表中以及该字段是否为float类型
嗯!!我明明写的是123.456789,但是存储到数据库中却变成了123.457,为什么会这样呢?
原因我之前说过:float单精度类型,单精度数据类型存储到表中容易被丢失。既然我们知道了原因,哪如何解决呢??方法就是用接下来要讲的定点类型(DECIMAL)。
第四种:DECIMAL
DECIMAL可以防止数据jingd
class Person(Base):
__tablename__ = "person"
id = Column(Integer , primary_key=True , autoincrement=True)
# age = Column(Integer)
# name = Column(String(20))
# price = Column(Float)
price = Column(DECIMAL(7,3))
DECIMAL有两个参数,第一个参数用于指定一共多少位数,第二个参数用于指定小数点后最多多少位数
例如:DECIMAL(4,2)表示一共存储4位数字,小数点后最多有两位
如果传入不符合规则数值时会报如下错误:
所以我们在插入数据时一定要遵守参数规则
p = Person(price = 1234.567)
session.add(p)
session.commit()
运行上述代码,然后输入下方命令检查数据是否插入到表中以及该字段是否为decimal类型
第五种:Boolean
class Person(Base):
__tablename__ = "person"
id = Column(Integer , primary_key=True , autoincrement=True)
# age = Column(Integer)
# name = Column(String(20))
# price = Column(Float)
# price = Column(DECIMAL(7,3))
delete = Column(Boolean)
插入数据试试。我们知道,1代表true,0代表false
p = Person(delete = 1)
session.add(p)
session.commit()
运行上述代码,然后输入下方命令检查数据是否插入到表中(存储到数据库中对应tinyint类型)
第六种:Enum
什么情况下会用到枚举类型呢?比如用户填写性别时,固定只能选男或者女,不可能不男不女,对吧!
Enum()括号中为枚举列表,在这个里面可以罗列出可输入的值!
class Person(Base):
__tablename__ = "person"
id = Column(Integer , primary_key=True , autoincrement=True)
# age = Column(Integer)
# name = Column(String(20))
# price = Column(Float)
# price = Column(DECIMAL(7,3))
# delete = Column(Boolean)
sex = Column(Enum("男","女"))
我们先插入一条错误数据试试
p = Person(sex="不男不女")
session.add(p)
session.commit()
运行代码、结果报如下错误:
我们再输入一条正确数据试试
嗯,数据成功插入到表中,且数据类型为enum。
第七种:Date
Date只能存储指定的年月日,不能存储时分秒
说到日期类型,相信大家都熟悉,比如某年某月某日生。嗯、下面咱们就谈谈这个Date类型。
class Person(Base):
__tablename__ = "person"
id = Column(Integer , primary_key=True , autoincrement=True)
# age = Column(Integer)
# name = Column(String(20))
# price = Column(Float)
# price = Column(DECIMAL(7,3))
# delete = Column(Boolean)
# sex = Column(Enum("男","女"))
create_time = Column(Date)
然后从datetime导入datetime这个包,将数据添加至数据库
from datetime import datetime
p = Person(create_time = datetime(2018,8,8))
session.add(p)
session.commit()
datetime()中的数值用于传递指定的年月日
运行并查看数据结果如下:
第八种:DateTime
DateTime存储指定的年月日时分秒
class Person(Base):
__tablename__ = "person"
id = Column(Integer , primary_key=True , autoincrement=True)
# age = Column(Integer)
# name = Column(String(20))
# price = Column(Float)
# price = Column(DECIMAL(7,3))
# delete = Column(Boolean)
# sex = Column(Enum("男","女"))
# create_time = Column(Date)
create_time = Column(DateTime)
添加测试数据
p = Person(create_time = datetime(2018,8,8,16,11,50))
session.add(p)
session.commit()
datetime()括号中传递指定的年月日时分秒
运行并查看数据结果如下:
第九种:Time
Time只能存储时分秒,不能存储年月日
class Person(Base):
__tablename__ = "person"
id = Column(Integer , primary_key=True , autoincrement=True)
# age = Column(Integer)
# name = Column(String(20))
# price = Column(Float)
# price = Column(DECIMAL(7,3))
# delete = Column(Boolean)
# sex = Column(Enum("男","女"))
# create_time = Column(Date)
# create_time = Column(DateTime)
create_time = Column(Time)
插入测试数据,time()后面传递关键字参数,用于指定时分秒
from datetime import datetime,time
p = Person(create_time=time(hour=12,minute=20,second=50))
session.add(p)
session.commit()
运行并查看结果:
第十种:Text
这个没什么好讲的啊,当字符串长度比较长时就可以使用Text类型
class Person(Base):
__tablename__ = "person"
id = Column(Integer , primary_key=True , autoincrement=True)
# age = Column(Integer)
# name = Column(String(20))
# price = Column(Float)
# price = Column(DECIMAL(7,3))
# delete = Column(Boolean)
# sex = Column(Enum("男","女"))
# create_time = Column(Date)
# create_time = Column(DateTime)
# create_time = Column(Time)
content = Column(Text)
插入数据:
p = Person(content = "人最需要的是学习")
session.add(p)
session.commit()
运行并查看结果:
第十一种:LongText
由于Text的存储长度有限,我们就可以使用LongText来存储数据。
由于LongText类型在mysql数据库才有,其它数据库没有该数据类型,在使用前,记得从mysql数据库导入该数据类型
from sqlalchemy.dialects.mysql import LONGTEXT
插入数据:
p = Person(content = "我要给它做广告,让它在人群中最闪耀!")
session.add(p)
session.commit()
运行上述代码并查看结果:
来源:https://blog.csdn.net/aimill/article/details/81531499
猜你喜欢
- 本文的asp xmlhttp类,使用asp的MSXML2.ServerXMLHTTP组件来获取远程音乐文件。类定义 Cls_AspHttp.
- Python语言中import的使用很简单,直接使用 import module_name 语句导入即可。这里我主要写一下"imp
- 为了给你的对像添加一个行级功能,那就定义一个自定义方法。 有鉴于manager经常被用来用一些整表操作(table-wide),模型方法应该
- Python是一门非常简洁的语言,对于数据类型的表示,不像其他语言预定义了许多类型(如:在C#中,光整型就定义了8种),它只定义了六种基本类
- django-allauth是集成的Django应用程序,用于解决网站身份验证,用户的注册登录及账户管理,以及第三方(社交)账户的身份验证。
- Urllib3是一个功能强大,条理清晰,用于HTTP客户端的Python库。许多Python的原生系统已经开始使用urllib3。Urlli
- 工作中,网页设计师经常会遇见这些状况:时间这么短又要出彩、又是要大气要有气氛、风格不明确很难把握、栏目这么多页面又这么长……突然觉得束手无策
- 本文实例讲述了Python开发中爬虫使用代理proxy抓取网页的方法。分享给大家供大家参考,具体如下:代理类型(proxy):透明代理 匿名
- 我们直接先给出输出与预期不同的代码In[28]: a = [1,2,3,4,5,6]In[29]: for i in a: ...: &nb
- CSS对浏览器的兼容性有时让人很头疼,或许当你了解当中的技巧跟原理,就会觉得也不是难事,从网上收集了IE7,6与Fireofx的兼容性处理技
- ---- Oracle是关系型数据库管理系统,它功能强大、性能卓越,在当今大型数据库管理系统中占有重要地位。在我们开发的一MIS
- 使用python生成一个图片验证码,随机的,可以由于验证人机和别的啊,很方便很简单导入模块import randomfrom PIL imp
- 加载模型并查看网络加载模型,以vgg19为例。打开终端> pythonPython 3.7.2 (tags/v3.7.2:9a3ffc
- 需要ocr识别,推荐一个Python免费的验证码识别-ddddocr安装过程:1、镜像安装:pip install ddddocr -i h
- 听说 FaceBook 开放其网站的代码了,期前也算是了解过 FaceBook 的架构,所以重点就是看其代码的质量。可以毫不夸张的说,Fac
- 本文讲述的内容基于 Django 1.11摘要Django 中的中间件(middleware),是一个镶嵌到Django的request/r
- 本文实例展示了PHP实现的格鲁斯卡尔算法(kruscal)的实现方法,分享给大家供大家参考。相信对于大家的PHP程序设计有一定的借鉴价值。具
- 1. *表示匹配任意多个字符 \d*表示匹配任意多个数字字符import retext = "
- 线性插值插值:是根据已知的数据序列(可以理解为你坐标中一系列离散的点),找到其中的规律,然后根据找到的这个规律,来对其中尚未有数据记录的点进
- pytorch定义新的自动求导函数在pytorch中想自定义求导函数,通过实现torch.autograd.Function并重写forwa