当前位置: 首页 > news >正文

JayDeBeApi对数据类型的支持

JayDeBeApi对数据类型的支持

常用的数据类型如下:

字符类型

内置字符类型包括:char, nchar, varchar, nvarchar 和lvarchar
CHARACTER(n) 和 CHARACTER VARYING(n)这样的别名同样支持
参考代码:test_string_type.py

    create = """create table tab_string(col1 char(32767),col2 nchar(32767),col3 varchar(255),col4 nvarchar(255),col5 lvarchar(32739))"""cursor.execute(create)insert = """insert into tab_string(col1, col2, col3, col4, col5) values('字符字段char类型','本地化字符字段nchar类型','可变长度字符字段varchar类型','本地化可变长度字符字段nvarchar类型','扩展可变长度字符字段lvarchar类型')"""cursor.execute(insert)select = "select * from tab_string"cursor.execute(select)rows = cursor.fetchall()for result in rows :print("字段1的字节长度为:{} ,值为:\"{}\"". format(len(result[0].encode('utf8')),result[0]))print("字段2的字节长度为:{} ,值为:\"{}\"". format(len(result[1].encode('utf8')),result[1]))print("字段3的字节长度为:{} ,值为:\"{}\"". format(len(result[2].encode('utf8')),result[2]))print("字段4的字节长度为:{} ,值为:\"{}\"". format(len(result[3].encode('utf8')),result[3]))print("字段5的字节长度为:{} ,值为:\"{}\"". format(len(result[4].encode('utf8')),result[4]))

数值类型

内置的数值类型包括:
整型:smallint, integer, int8, bigint
自增长整型:serial, serial8, bigserail
浮点型:smallfloat, float, decimal
精确值型:decimal(P,S)
货币类型:money(P,S)
DEC(p,s)、NUMERIC(p,s)、INT和DOUBLE PRECISION这样的别名同样支持
注意:JayDeBeApi无法解析decimal§ 类型,结果显示异常
参考代码:test_numeric_type.py

    create = """create table tab_numeric(col1 serial not null,col2 smallint,col3 int,col4 int8,col5 bigint,col6 smallfloat,col7 float,col8 decimal(32,20),col9 decimal(32),colx money(32,20))"""cursor.execute(create)insert = """insert into tab_numeric(col1, col2, col3, col4, col5, col6, col7, col8, col9, colx) values(0,32767,2147483647,9223372036854775807,9223372036854775807,1234567890,12345678901234567890,123456789012.123456789,12345678901234567890123456789012,123456789012.123456789)"""cursor.execute(insert)select = "select * from tab_numeric"cursor.execute(select)data = cursor.fetchall()for result in data:print("字段 1的类型serail         ,值为:{}" . format(result[0]))print("字段 2的类型samllint       ,值为:{}" . format(result[1]))print("字段 3的类型integer        ,值为:{}" . format(result[2]))print("字段 4的类型int8           ,值为:{}" . format(result[3]))print("字段 5的类型bigint         ,值为:{}" . format(result[4]))print("字段 6的类型smallfloat     ,值为:{}" . format(result[5]))print("字段 7的类型float          ,值为:{}" . format(result[6]))print("字段 8的类型decimal(32,20) ,值为:{}" . format(result[7]))print("字段 9的类型decimal(32)    ,值为:{}" . format(result[8]))print("字段10的类型money(32,20)   ,值为:{}" . format(result[9]))

日期时间型

日期型:date
日期时间型:datetime [first to last]
间隔类型:interval [first to list]
TIMESTAMP(n)这样的别名在部分版本中支持

    create = """create table tab_datetime(col1 serial not null,col2 date,col3 datetime year to day,col4 datetime year to second,col5 datetime year to fraction(5),col6 interval day to second)"""cursor.execute(create)prepare = """insert into tab_datetime(col1,col2,col3,col4,col5,col6) values(0,?,?,?,?,?)"""cursor.execute(prepare,['2023-03-24','2023-03-24','2023-03-24 12:34:56','2023-03-24 12:34:56.98765','-3 12:13:14'])select = "select col1,col2,col3,col4,col5,col6 from tab_datetime"cursor.execute(select)data = cursor.fetchall()for result in data:print("字段 1的类型serail                  ,值为:{}" . format(result[0]))print("字段 2的类型date                    ,值为:{}" . format(result[1]))print("字段 3的类型datetime Y-m-d          ,值为:{}" . format(result[2]))print("字段 4的类型datetime Y-m-d H:M:S    ,值为:{}" . format(result[3]))print("字段 5的类型datetime Y-m-d H:M:S.F5 ,值为:{}" . format(result[4]))print("字段 6的类型interval d H:M          ,值为:{}" . format(result[5]))

布尔类型

布尔类型:boolean
取值范围:‘t’/1, ‘f’/0, null(None)
参考代码:test_boolean_type.py

    create = """create table tab_boolean(col1 serial not null,col2 boolean)"""cursor.execute(create)prepare = """insert into tab_boolean(col1,col2) values(0,?)"""cursor.execute(prepare,(True,))cursor.execute(prepare,(False,))cursor.execute(prepare,(None,))select = "select * from tab_boolean"cursor.execute(select)rows = cursor.fetchall()for row in rows :print("字段 1的类型serail   ,值为:{}" . format(row[0]))print("字段 2的类型boolean  ,值为:{}" . format(row[1]))

扩展类型LIST

LIST类型:list(TYPE not null)
参考代码:test_list_type.py

    create = """create table tab_list(col1 serial not null,col2 LIST(varchar(20) not null))"""cursor.execute(create)prepare = """insert into tab_list(col1,col2) values(0,?)"""col2_list = "LIST{'aaaa','bbbb','cccc'}"cursor.execute(prepare, (col2_list,))select = "select * from tab_list"cursor.execute(select)data = cursor.fetchall()for result in data:print("字段 1的类型serail   ,值为:{}" . format(result[0]))print("字段 2的类型list     ,值为:{}" . format(result[1]))

JSON和BSON类型

JSON类型:以字符形式存储
BSON类型:可以以字符形式或者二进制形式存储
注:不能对bson类型进行转换
参考代码:test_json_bson_type.py

    create = """create table tab_json_bson(col1 serial not null,col2 bson,col3 json)"""cursor.execute(create)prepare = "insert into tab_json_bson(col1,col2,col3) values(0,?,?)"col2_bson = "bson类型输入"col3_json = "json类型输入"cursor.execute(prepare,(col2_bson,col3_json))select = "select col1,col2,col3 from tab_json_bson"cursor.execute(select)rows = cursor.fetchall()for row in rows:print("字段1的值为:{}".format(row[0]))print("字段2的值为:{}".format(""))print("字段3的值为:{}".format(row[2]))

大对象类型

包含:
text和byte
参考代码:test_byte_text_type.py

    create = """create table tab_lob(col1 serial not null,col2 byte,col3 text)"""cursor.execute(create)prepare = "insert into tab_lob(col1,col2,col3) values(0,?,?)"col2_byte = bytes('byte类型输入', encoding='UTF-8')col3_text = 'text类型输入'cursor.execute(prepare,(col2_byte,col3_text))select = "select col1,col2,col3 from tab_lob"cursor.execute(select)rows = cursor.fetchall()for row in rows:print("字段1的值为:", row[0])print("字段2的值为:", row[1])print("字段3的值为:", row[2])

智能大对象类型

包含:
blob和clob
两种类型均只可以插入,查询时无法转换
参考代码:test_blob_clob_type.py

    create = """create table tab_lob(col1 serial not null,col2 blob,col3 clob)"""cursor.execute(create)blob_str  = 'blob类型输入,最大支持4TB'clob_str  = 'clob类型输入,最大支持4TB'prepare = "insert into tab_lob(col1,col2,col3) values(0,?,?)"cursor.execute(prepare,(blob_str,clob_str))if(os.path.isfile('blob_file.txt')):os.remove('blob_file.txt')if(os.path.isfile('clob_file.txt')):os.remove('clob_file.txt')select = "select col1,col2,col3 from tab_lob"cursor.execute(select)rows = cursor.fetchall()for row in rows :print("字段1的值为:", row[0])print("字段2的值为:", row[1])print("字段3的值为:", row[2])

参考代码:
test_JayDeBeApi.tar.gz

相关文章:

JayDeBeApi对数据类型的支持

JayDeBeApi对数据类型的支持 常用的数据类型如下: 字符类型 内置字符类型包括:char, nchar, varchar, nvarchar 和lvarchar CHARACTER(n) 和 CHARACTER VARYING(n)这样的别名同样支持 参考代码:test_string_type.py create ""&…...

一文盘点 Zebec 生态几大利好,让 ZBC 近期“狂飙”

近期,ZBC通证迎来了新一轮上涨趋势,我们看到其从3月11日左右的低点$0.0115上涨至$0.0175,这也是近期的最大涨幅之一。我们看到,推动ZBC上涨的主要因素,是Zebec生态近期频繁的布局所带来的系列利好推动。 本文将对近期的…...

【数据结构】栈和队列(笔记总结)

👦个人主页:Weraphael ✍🏻作者简介:目前学习C和算法 ✈️专栏:数据结构 🐋 希望大家多多支持,咱一起进步!😁 如果文章对你有帮助的话 欢迎 评论💬 点赞&…...

【Java】自定义注解和AOP切面的使用

前言 我们在开发的过程中,一般都需要对方法的入参进行打印,或者Debug调试的时候我们要查看方法入参的参数是否数量和数据正确性。 一般我们需要知道请求的参数、接口路径、请求ip等 但是考虑以后项目上线BUG排查的问题,最好的方式就是使用…...

前后台协议联调拦截器

前后台协议联调&拦截器4,前后台协议联调4.1 环境准备4.2 列表功能4.3 添加功能4.4 添加功能状态处理4.5 修改功能4.6 删除功能5,拦截器5.1 拦截器概念5.2 拦截器入门案例5.2.1 环境准备5.2.2 拦截器开发步骤1:创建拦截器类步骤2:配置拦截器类步骤3:S…...

【还在传统绑骨骼动画?】让AI助力你实现2D游戏角色动画流程

思路(让3D模型替代动作) 一、利用MJ或者SD生成你需要的游戏角色(获取原图像) 需要的知识: 会调关键词chatGpt(看小红书、抖音、B站、Youtube、Telegrame等等都行,别傻忽忽跑到知识星球被收割…...

动态规划+例题

适用场景 题目链接&#xff1a;数字三角形 /*正推DP&#xff0c;可能数据比较小&#xff0c;这个正推不太麻烦可以AC*/ #include<bits/stdc.h> using namespace std; int r; int a[1005][1005],f[1005][1005];int main(){cin>>r;for(int i1;i<r;i){for(int j1…...

快商通荣获多个政府科技、人才奖项

近日&#xff0c;快商通与快商通首席科学家李海洲教授荣获由厦门市科学技术局、厦门市委人才办等多部门发布的“2022年度厦门市科学技术奖”、“2022厦门十大成长性人才企业”、“2022厦门战略性新兴产业十大创新人才”等多个 政府科技、人才奖项 &#xff0c;并进行全网公示。…...

Linux的基本命令的使用

文章目录一、初识LinuxLinux目录结构二、如何拥有一个Linux环境&#xff1f;三、Linux命名Linux命令基础lscd pwd特殊路径符clearmkdirtouch cat morecp mv rmsuwhich findgrep wc 管道符ehco tail 重定向符psnetstatvi vim一、初识Linux 我们的计算机由硬件和软件两部分组成&…...

RecycleView小结

RecycleView四级缓存 一级缓存&#xff1a;用于存放当前屏幕可显示区域的ViewHolder&#xff0c;目的是为了方便更新数据&#xff0c;以及对View操作时更加快捷二级缓存&#xff1a;用于缓存最近滑动出屏幕的ViewHolder&#xff0c;目的是为了当用户将该View滑出屏幕外时又突然…...

【Python】如何实现Redis构造简易客户端(教程在这)

文章目录前言一、准备二、原理剖析三、编写简易Redis客户端总结前言 Redis 是我们在开发过程中经常会用到的内存数据库&#xff0c;尤其是在Python的第三方模块Redis-py的支持下&#xff0c;在Python中使用Redis及其方便。 但是在有些情况下&#xff0c;我们无法使用像Redis-…...

326. 3 的幂 ——【Leetcode每日一题】

326. 3 的幂 给定一个整数&#xff0c;写一个函数来判断它是否是 3 的幂次方。如果是&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 整数 n 是 3 的幂次方需满足&#xff1a;存在整数 x 使得 n3xn 3^xn3x。 示例 1&#xff1a; 输入&#xff1a;n 27 …...

UE4 Sequence学习

1.常用轨道 1.1 Camera轨道 Camera轨道可以理解为Camera Cuts轨道和Camera Actor轨道&#xff0c;一般点击Sequencer上的摄像机图标可以自动创建&#xff1a; Camera Cuts轨道&#xff0c;可以进行不同相机机位的切换&#xff0c;一般会随着Camera Actor轨道自动创建&#x…...

总结MySQL、Redis的优化措施与使用 mysql_upgrade升级数据结构

目录 一.MySQL数据库优化 二.Redis优化 三.MySQL创建测试账号报错 一.MySQL数据库优化 遵循MySQL层优化的五个原则: 减少数据访问&#xff0c;返回更少的数据&#xff0c;减少交互次数减少服务器CPU开销&#xff0c;利用更多资源。理解SQL优化原理并进行SQL优化&#xff0c…...

C++11线程库

C11线程库 本质是对不同平台的线程库进行封装。因为windows和linux下各有自己的接口&#xff0c;这使得代码的可移植性比较差。C11中最重要的特性就是对线程进行支持了&#xff0c;使得C在并行编程时不需要依赖第三方库&#xff0c;而且在原子操作中还引入了原子类的概念。要使…...

智能化生产,提高效率!使用关键词采集工具助力企业数字化转型

关键词采集工具在企业数字化转型中的优势和作用进行阐述。 随着信息技术的不断发展&#xff0c;企业数字化转型已经成为了企业发展的必然趋势。 对于各种规模的企业而言&#xff0c;数字化转型可以提升企业的生产效率、降低成本、提高产品质量等方面带来更多的发展机遇。 而关…...

浅谈自动化测试用例创建和文档

通过自动创建测试用例和文档&#xff0c;探索自然语言处理 (NLP) 在革新软件测试方面的变革力量。 技术的快速发展导致对高效和有效的软件测试方法的需求增加。该领域最有前途的进步之一是自然语言处理 (NLP) 技术的集成。NLP 是人工智能(AI)的一个子集&#xff0c;专注于通过…...

[Java Web]AJAX Axios | 一种结合HTML来取代传统JSP的技术

⭐作者介绍&#xff1a;大二本科网络工程专业在读&#xff0c;持续学习Java&#xff0c;努力输出优质文章 ⭐作者主页&#xff1a;逐梦苍穹 ⭐所属专栏&#xff1a;Java Web 目录1、AJAX1.1、简介1.2、作用1.3、同步和异步1.4、代码实现1.4.1、服务端1.4.2、客户端1.4.2.1、完善…...

【C++】多态问答题

前言 本篇仅整理一些比较偏的多态的问答题 文章目录前言一. 内联与虚函数二. 静态函数与虚函数三. 构造函数与虚函数四. 虚函数与普通函数结束语一. 内联与虚函数 内联函数可以是虚函数吗&#xff1f; 首先我们看一下语法有没有问题 我们看到&#xff0c;程序成功运行了&#…...

【设计模式】适配器模式

一&#xff0c;定义适配器模式&#xff1a;结构型模式之一&#xff0c;适配器提供客户类需要的接口&#xff0c;适配器的实现就是把客户类的请求转化为对适配者的相应接口的调用。也就是说:当客户类调用适配器的方法时&#xff0c;在适配器类的内部将调用适配者类的方法&#x…...

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…...

【根据当天日期输出明天的日期(需对闰年做判定)。】2022-5-15

缘由根据当天日期输出明天的日期(需对闰年做判定)。日期类型结构体如下&#xff1a; struct data{ int year; int month; int day;};-编程语言-CSDN问答 struct mdata{ int year; int month; int day; }mdata; int 天数(int year, int month) {switch (month){case 1: case 3:…...

以下是对华为 HarmonyOS NETX 5属性动画(ArkTS)文档的结构化整理,通过层级标题、表格和代码块提升可读性:

一、属性动画概述NETX 作用&#xff1a;实现组件通用属性的渐变过渡效果&#xff0c;提升用户体验。支持属性&#xff1a;width、height、backgroundColor、opacity、scale、rotate、translate等。注意事项&#xff1a; 布局类属性&#xff08;如宽高&#xff09;变化时&#…...

linux 错误码总结

1,错误码的概念与作用 在Linux系统中,错误码是系统调用或库函数在执行失败时返回的特定数值,用于指示具体的错误类型。这些错误码通过全局变量errno来存储和传递,errno由操作系统维护,保存最近一次发生的错误信息。值得注意的是,errno的值在每次系统调用或函数调用失败时…...

Springcloud:Eureka 高可用集群搭建实战(服务注册与发现的底层原理与避坑指南)

引言&#xff1a;为什么 Eureka 依然是存量系统的核心&#xff1f; 尽管 Nacos 等新注册中心崛起&#xff0c;但金融、电力等保守行业仍有大量系统运行在 Eureka 上。理解其高可用设计与自我保护机制&#xff0c;是保障分布式系统稳定的必修课。本文将手把手带你搭建生产级 Eur…...

uniapp微信小程序视频实时流+pc端预览方案

方案类型技术实现是否免费优点缺点适用场景延迟范围开发复杂度​WebSocket图片帧​定时拍照Base64传输✅ 完全免费无需服务器 纯前端实现高延迟高流量 帧率极低个人demo测试 超低频监控500ms-2s⭐⭐​RTMP推流​TRTC/即构SDK推流❌ 付费方案 &#xff08;部分有免费额度&#x…...

GC1808高性能24位立体声音频ADC芯片解析

1. 芯片概述 GC1808是一款24位立体声音频模数转换器&#xff08;ADC&#xff09;&#xff0c;支持8kHz~96kHz采样率&#xff0c;集成Δ-Σ调制器、数字抗混叠滤波器和高通滤波器&#xff0c;适用于高保真音频采集场景。 2. 核心特性 高精度&#xff1a;24位分辨率&#xff0c…...

【数据分析】R版IntelliGenes用于生物标志物发现的可解释机器学习

禁止商业或二改转载&#xff0c;仅供自学使用&#xff0c;侵权必究&#xff0c;如需截取部分内容请后台联系作者! 文章目录 介绍流程步骤1. 输入数据2. 特征选择3. 模型训练4. I-Genes 评分计算5. 输出结果 IntelliGenesR 安装包1. 特征选择2. 模型训练和评估3. I-Genes 评分计…...

基于Java+MySQL实现(GUI)客户管理系统

客户资料管理系统的设计与实现 第一章 需求分析 1.1 需求总体介绍 本项目为了方便维护客户信息为了方便维护客户信息&#xff0c;对客户进行统一管理&#xff0c;可以把所有客户信息录入系统&#xff0c;进行维护和统计功能。可通过文件的方式保存相关录入数据&#xff0c;对…...

安卓基础(Java 和 Gradle 版本)

1. 设置项目的 JDK 版本 方法1&#xff1a;通过 Project Structure File → Project Structure... (或按 CtrlAltShiftS) 左侧选择 SDK Location 在 Gradle Settings 部分&#xff0c;设置 Gradle JDK 方法2&#xff1a;通过 Settings File → Settings... (或 CtrlAltS)…...