PostgreSQL:所有支持的数据类型及建表语句实例

news2024/11/17 0:56:35

哈喽,大家好,我是木头左!

一、引言

在当今这个数据驱动的时代,数据库已经成为了企业和个人不可或缺的工具。而在众多数据库产品中,PostgreSQL以其强大的功能和高度的可扩展性,受到了越来越多开发者的青睐。那么,PostgreSQL支持哪些数据类型呢?本文将为大家详细解析,并通过建表语句举例说明。让一起揭开PostgreSQL神秘的面纱吧!

二、PostgreSQL支持的数据类型

1. 数值型数据类型

(1) 整型数据类型
(2) 浮点型数据类型

2. 字符型数据类型

  • char:固定长度的字符串,长度范围为1到10个字符
  • varchar:可变长度的字符串,长度范围为1到1048576个字符
  • text:最长可达到1GB的文本数据

3. 日期和时间型数据类型

  • date:日期类型,格式为’YYYY-MM-DD’
  • time:时间类型,格式为’HH:MI:SS’或’HH:MM:SS AM’/‘PM’
  • timestamp:时间戳类型,表示从’1970-01-01 00:00:00+00’到指定时间的秒数(精确到纳秒)
  • interval:间隔类型,表示两个日期或时间之间的时间间隔(以天、小时、分钟、秒为单位)

4. 布尔型数据类型

  • boolean:布尔类型,只有两个值:true和false

5. 复合数据类型

PostgreSQL支持复合数据类型,可以将多个数据类型组合在一起。例如,数组(array)、记录(record)、结构体(struct)等。这些复合数据类型的定义和使用方式较为复杂,需要根据实际需求进行选择和使用。

三、建表语句实例

1. 创建一个用户表(user)

CREATE TABLE user (
    id SERIAL PRIMARY KEY, -- 主键ID,自增序列
    name VARCHAR(50) NOT NULL, -- 用户名,长度为50个字符,不能为空
    email VARCHAR(100) NOT NULL, -- 邮箱,长度为100个字符,不能为空
    age INTEGER, -- 年龄,整数类型
    created_at TIMESTAMP NOT NULL DEFAULT current_timestamp, -- 创建时间,默认为当前时间戳
    updated_at TIMESTAMP NOT NULL DEFAULT current_timestamp ON UPDATE current_timestamp -- 更新时间,默认为当前时间戳,自动更新为当前时间戳
);

2. 创建一个订单表(order)

CREATE TABLE order (
    id SERIAL PRIMARY KEY, -- 主键ID,自增序列
    user_id INTEGER REFERENCES user(id), -- 用户ID,外键关联用户表的id字段
    product_name VARCHAR(100) NOT NULL, -- 产品名称,长度为100个字符,不能为空
    quantity INTEGER NOT NULL, -- 数量,整数类型,不能为空
    total_price DECIMAL(10, 2) NOT NULL -- 总价,十进制数类型,保留两位小数,不能为空
);

3. 创建一个商品表(product)和订单详情表(order_detail)

CREATE TABLE product (
    id SERIAL PRIMARY KEY, -- 主键ID,自增序列
    name VARCHAR(100) NOT NULL, -- 商品名称,长度为100个字符,不能为空
    price DECIMAL(10, 2) NOT NULL -- 价格,十进制数类型,保留两位小数,不能为空
);

CREATE TABLE order_detail (
    id SERIAL PRIMARY KEY, -- 主键ID,自增序列
    order_id INTEGER REFERENCES order(id), -- 订单ID,外键关联订单表的id字段
    product_id INTEGER REFERENCES product(id), -- 商品ID,外键关联商品表的id字段
    quantity INTEGER NOT NULL -- 数量,整数类型,不能为空
);

我是木头左,感谢各位童鞋的点赞、收藏,我们下期更精彩!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1574886.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

FreeRTOSFreeRTOS列表和列表项

FreeRTOS列表和列表项 今天继续跟着正点原子学习FreeRTOS列表和列表项的内容。列表和列表项这个知识点用到了C语言链表的知识点。所以必须对C语言中的链表这个数据结构才能更好的理解这部分内容。TIPS:正点原子这节课内容讲的特别好,强烈推荐&#xff1…

《QT实用小工具·十八》高亮发光按钮控件

1、概述 源码放在文章末尾 该项目实现了高亮发光按钮控件 可设置文本,居中显示。可设置文本颜色。可设置外边框渐变颜色。可设置里边框渐变颜色。可设置背景色。可直接调用内置的设置 绿色、红色、黄色、黑色、蓝色 等公有槽函数。可设置是否在容器中可移动&#…

2024 抖音欢笑中国年(二):AnnieX互动容器创新玩法解析

本文基于24年抖音春节活动业务背景,介绍了字节跨端容器AnnieX在游戏互动套件上的探索,致力于提升容器在游戏互动场景的优化能力。 业务背景 AnnieX作为字节一方游戏统一容器,服务字节内部电商、直播、UG等跨端场景业务。在字节一方游戏互动场…

YOLOv8模型剪枝实战:Network Slimming网络瘦身方法

课程链接:YOLOv8模型剪枝实战:Network Slimming网络瘦身方法_在线视频教程-CSDN程序员研修院 YOLOv8是一个当前非常流行的目标检测器,本课程使用Network Slimming(网络瘦身)剪枝方法对YOLOv8进行模型剪枝,…

springboot国际化多语言

1,新建国际化多语言文件 在resources目录下新建 messages.properties 其他语言的文件 编辑messages.properties文件,下方从text切换到Resource Bundle ,即可对照着编辑多语言文件 (如果没有找到Resource Bundle,先在settings->plugins中安装Resource Bundle Editor) 2,配…

学习 MongoDB:打开强大的数据库技术大门

一、基本概念 MongoDB 是一个基于分布式文件存储的文档数据库,由 C 语言编写。它旨在为 Web 应用提供可扩展的高性能数据存储解决方案。 相信MySQL我们非常的熟悉,那么MySQL的表结构与MongoDB的文档结构进行类比的话可能更好理解MongoDB。 MySQL的数据…

Spyder无法载入(load)或者闪退问题

在Anaconda prompt中直接输入spyder,报错如下 Traceback (most recent call last):File "C:\Users\user\.conda\envs\KB\Scripts\spyder-script.py", line 10, in sys.exit(main())File "C:\Users\user\.conda\envs\KB\lib\site-packages\spyder\a…

baseline SE SP YI是什么?

SE、SP和YI是评估分类模型性能时常用的几个统计指标,特别是在医学影像处理、疾病诊断等领域,这些指标帮助了解模型对于正负类样本的识别能力。 SE (Sensitivity),也称为真正率(True Positive Rate, TPR)或召回率&#…

泛型(java学习)

目录 1.泛型介绍: 2.泛型的好处: 3.泛型的语法 4.泛型的细节 5.自定义泛型 6.自定义泛型接口 8.泛型的继承和通配符 1.泛型介绍: 1)泛型又称参数化类型,解决数据类型的安全性问题。 2)在类声明或实例…

5.3 用栈翻转数组,动态规划求斐波那契数列

5.3 用栈翻转数组,动态规划求斐波那契数列 1. 用栈翻转数组 assume cs:code,ds:data,ss:stack data segmentarr dw 1111h,2222h,3333h,4444h,5555h,6666h,7777h,8888hres db 800 dup(0) data endsstack segmentdb 100 dup(0) stack endscode segmentstart:mov ax,…

计算机视觉入门:开启图像理解之旅

🧑 作者简介:阿里巴巴嵌入式技术专家,深耕嵌入式人工智能领域,具备多年的嵌入式硬件产品研发管理经验。 📒 博客介绍:分享嵌入式开发领域的相关知识、经验、思考和感悟,欢迎关注。提供嵌入式方向的学习指导…

【算法篇】三道题理解算法思想——认识BFS

BFS(宽搜) 宽度优先遍历和深度优先遍历组成了大家熟悉的搜索算法,这两种算法也是蓝桥杯之类竞赛题的常考思想,正巧马上蓝桥杯临近,博主也是刷了很多BFS相关的题型,在这篇文章中会从力扣上选取三道简单的宽搜…

小象超市(原美团买菜) 的大屏图表

文章目录 概要技术细节技术名词解释小结 概要 20203年12月1日,美团旗下自营零售品牌“美团买菜”升级为全新品牌“小象超市”。 ,“小象超市”坚持美团自营零售模式,通过在社区设立的集存储、分拣、配送为一体的便民服务站,为社区…

关于16:9和4:3的有关知识,看这篇文章就差不多了

序言 在你拍照或录制视频之前,你需要考虑使用哪个纵横比。最常见的两种纵横比是16:9和4:3,但哪一种最适合你? 16:9的纵横比最适合视频,因为宽度比高度宽78%,这使你更容易在水平方向上适应更多画面,同时优化视频以适应现代屏幕。 同时,4:3的纵横比更适合摄影,因为宽度…

书籍《笔记的方法》读后感

读完《笔记的方法》有几周的时间,书里有些记录的内容,觉得非常有价值的,自己的观点,当下读书,其实并没有那么高大尚,就是存粹陶冶下情操,读书还是有一定作用的,毕竟看书只能慢慢来&a…

【PDF-XSS攻击】Java项目-上传文件-解决PDF文件XSS攻击

文章目录 背景解决pdfbox依赖控制器代码PdfUtils工具类 验证最后源码参考 背景 上传xss-pdf造成存储型xss因为在浏览器直接预览的PDF,而不是预览,所以安全部门认为会有XSS漏洞 解决 安全部门修复建议 1、根据白名单的标签和属性对数据进行过滤&#…

C++后端程序员如何在缺乏相关外包项目中寻找赚取外快的途径

作为一位专业的C后端程序员,你拥有扎实的技术功底和丰富的编程经验,然而在寻求外包项目的道路上,可能时常会发现市场上的项目并不都与C直接相关。但这并不意味着你就无法利用自己的技能来获取额外收入。本文将为你揭示一些即使在当前环境下&a…

力扣热题100_链表_138_随机链表的复制

文章目录 题目链接解题思路解题代码 题目链接 138. 随机链表的复制 给你一个长度为 n 的链表,每个节点包含一个额外增加的随机指针 random ,该指针可以指向链表中的任何节点或空节点。 构造这个链表的 深拷贝。 深拷贝应该正好由 n 个 全新 节点组成&a…

【算法】动态规划练习(一)

目录 1137. 第 N 个泰波那契数 分析 代码 面试题 08.01. 三步问题 分析 代码 746. 使用最小花费爬楼梯 分析 代码 泰波那契序列 Tn 定义如下: T0 0, T1 1, T2 1, 且在 n > 0 的条件下 Tn3 Tn Tn1 Tn2 给你整数 n,请返回第 n 个泰波…

软件测试人员如何避免成为“背锅侠”

作为一名软件测试工程师,我们的角色可以算是“战场上的后勤”,战役的胜败和所有团队人员都息息相关。 但是难免碰到战役失败后,很多团队互相推脱的局面,而测试人员就是所有团队中的弱势群体,自然是首当其冲的背锅侠&a…