我的编程空间,编程开发者的网络收藏夹
学习永远不晚

解读sqlalchemy的常用数据类型有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

解读sqlalchemy的常用数据类型有哪些

sqlalchemy的常用数据类型

数据类型python数据类型说明
Integerint整形
Stringstr字符串
Floatfloat浮点型
DECIMALdecimal.Decimal定点型
Booleanbool布尔型
Datedatetime.date日期
DateTimedatetime.datetime日期和时间
Timedatetime.time时间
Enumstr枚举类型
Textstr文本类型
LongTextstr长文本类型

既然我们知道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()

运行上述代码并查看结果:

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

解读sqlalchemy的常用数据类型有哪些

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

解读sqlalchemy的常用数据类型有哪些

这篇文章主要介绍了解读sqlalchemy的常用数据类型有哪些,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-03-02

sqlalchemy的常用数据类型怎么使用

本篇内容主要讲解“sqlalchemy的常用数据类型怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“sqlalchemy的常用数据类型怎么使用”吧!sqlalchemy的常用数据类型数据类
2023-07-05

Python常用的数据类型有哪些

本篇内容主要讲解“Python常用的数据类型有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python常用的数据类型有哪些”吧!变量不需要声明Python的变量不需要声明,你可以直接输入:
2023-06-02

常用的PostgreSQL数据类型有哪些

PostgreSQL包含以下常用的数据类型:数值类型:整数(integer)、小数(decimal)、浮点数(float)、双精度浮点数(double precision)、十进制数(numeric)等。字符串类型:字符(character
2023-10-23

java常用的数据类型有哪些

java基本数据类型就8种,记住就好了。除了这些都是引用型的了。 java常用的数据类型介绍:(推荐:java视频教程)java四类八种基本数据类型 第一类:整型 byte short int long 第二类:浮点型 float double 第三
java常用的数据类型有哪些
2022-01-31

MongoDB的常用数据类型有哪些

这篇文章给大家分享的是有关MongoDB的常用数据类型有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。NO.1 MongoDB的常用数据类型 MongoDB中的文档类似json,我们知道,在json中,
2023-06-14

Pythonnumpy有哪些常用数据类型

Numpy提供了两种基本的对象:ndarray(N-dimensionalArrayObject)和ufunc(UniversalFunctionObject)。ndarray是存储单一数据类型的多维数组,而ufunc则是能够对数组进行处理的函数
2023-02-24

java中常用的数据类型有哪些

java中的数据类型分为基本数据类型和引用数据类型。基本数据类型一、4种整型 byte 1字节 -128——127 short 2 字节 -32,768 —— 32,767 int 4 字
java中常用的数据类型有哪些
2017-11-26

PyTorch上的常用数据类型有哪些

这篇文章将为大家详细讲解有关PyTorch上的常用数据类型有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。PyTorch上的常用数据类型如下Data typedtypeCPU tensorGPU te
2023-06-15

了解MySQL的主要数据类型:熟悉常用的数据类型有哪些

MySQL基本数据类型概述:了解常用的数据类型有哪些,需要具体代码示例MySQL是一种常用的关系型数据库管理系统,它支持多种数据类型。了解这些数据类型对于正确的数据库设计和数据存储至关重要。本文将介绍MySQL中常用的数据类型,并提供具体
了解MySQL的主要数据类型:熟悉常用的数据类型有哪些
2024-01-29

c#常见的数据类型有哪些

c# 数据类型分为两种:值类型和引用类型。值类型直接存储数据,包括整型、浮点数、字符、布尔型和枚举。引用类型存储对堆中对象的引用,包括类、结构、数组、字符串、异常和接口。根据存储大小、性能、精度和用途选择合适的数据类型至关重要。C# 中的常
c#常见的数据类型有哪些
2024-04-04

数据库常用的索引类型有哪些

常用的数据库索引类型包括:1. B-树索引:B-树(Balanced Tree)是一种平衡的多路搜索树,常用于关系型数据库中的索引结构。B-树索引适用于范围查询和等值查询。2. 哈希索引:哈希索引是通过使用哈希函数将索引值映射到哈希表中的存
2023-09-05

常见Flex数据类型有哪些

这篇文章主要介绍常见Flex数据类型有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Flex数据类型说明基元数据类型包括Boolean、int、Null、Number、String、uint和void。Actio
2023-06-17

mysql中常见的数据类型有哪些?

mysql 提供多种数据类型来存储不同类型的数据,包括整数类型、浮点数类型、定点类型、字符类型、时间和日期类型以及其他类型。这些数据类型具有不同的特性和用途,用于满足不同数据的存储需求。MySQL 中常见的数据类型MySQL 提供多种数据
mysql中常见的数据类型有哪些?
2024-04-26

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录