Oracle/MySQL/Java数据类型对应表

文章目录

  • 数据类型对照表
  • MySQL 的 int、bigint、mediumint、smallint、tinyint 的对比
  • 关于 MySQL 整型显示位数的问题
  • 关于 MySQL 的 timestamp
  • 关于 JDBC 类型

数据类型对照表

MysqlOracleJava
BIGINTNUMBER(19,0)java.lang.Long
BITRAWbyte[]
BLOBBLOB RAWbyte[]
CHARCHARjava.lang.String
DATEDATEjava.sql.Date
DATETIMEDATEjava.sql.Timestamp
DECIMALFLOAT (24)java.math.BigDecimal
DOUBLEFLOAT (24)java.lang.Double
DOUBLE PRECISIONFLOAT (24)java.lang.Double
ENUMVARCHAR2java.lang.String
FLOATFLOATjava.lang.Float
INTNUMBER(10,0)java.lang.Integer
INTEGERNUMBER(10,0)java.lang.Integer
LONGBLOBBLOB RAWbyte[]
LONGTEXTCLOB RAWjava.lang.String
MEDIUMBLOBBLOB RAWbyte[]
MEDIUMINTNUMBER(7,0)java.lang.Integer
MEDIUMTEXTCLOB RAWjava.lang.String
NUMERICNUMBER
REALFLOAT (24)
SETVARCHAR2java.lang.String
SMALLINTNUMBER(5,0)java.lang.Integer
TEXTVARCHAR2 CLOBjava.lang.String
TIMEDATEjava.sql.Time
TIMESTAMPDATEjava.sql.Timestamp
TINYBLOBRAWbyte[]
TINYINTNUMBER(3,0)java.lang.Boolean
TINYTEXTVARCHAR2java.lang.String
VARCHARVARCHAR2 CLOBjava.lang.String
YEARNUMBERjava.sql.Date

MySQL 的 int、bigint、mediumint、smallint、tinyint 的对比

在这里插入图片描述

关于 MySQL 整型显示位数的问题

int(M),tinyint(M),bigint(M),mediumint(M)、smallint(M)后面的 M 不代表占用空间容量(即存储的字符数),而是代表最小显示位数。也就是说int(1)和int(11)占用的是4个字节,tinyint(1)和tinyint(4)占用的是1个字节,和M值没有关系。
当存储的数值表面长度小于M值时,只有设置了zerofill(表示用0来填充),才能够看到效果,换句话就是说,没有zerofill,M值就是无用的。

举例子:

mysql> desc test;
+-------+------------+------+-----+---------+-------+
| Field | Type       | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| id1   | tinyint(2) | YES  |     | NULL    |       |
| id2   | tinyint(1) | YES  |     | NULL    |       |
+-------+------------+------+-----+---------+-------+
2 rows in set (0.04 sec)

id1是tinyint(2),我插入123,行不行?

mysql> insert into test(id1,id2) values(123,2);
Query OK, 1 row affected (0.00 sec)mysql> select * from test;
+------+------+
| id1  | id2  |
+------+------+
|  123 |    2 |
+------+------+
1 row in set (0.00 sec)

可见是可以正常插入的。
tinyint(2)的2到底有啥意义?我们插入5看下效果:

mysql> insert into test values(5,10);
Query OK, 1 row affected (0.00 sec)mysql> select * from test;
+------+------+
| id1  | id2  |
+------+------+
|  123 |    2 |
|    5 |   10 |
+------+------+
2 rows in set (0.00 sec)

有没有发现,不论插入的数字表面位数超过2还是小于2,都没有任何影响,纳闷了,到底设置2,干啥子呢?这就是奇葩了,想要看到效果,就必须用到zerofill指令,如下:


mysql> alter table test modify id1 tinyint(2) zerofill; // 必须告诉数据库,显示位数不足2位时,前面要补0 
Query OK, 2 rows affected (0.01 sec)
Records: 2  Duplicates: 0  Warnings: 0mysql> select * from test;
+------+------+
| id1  | id2  |
+------+------+
|  123 |    2 |
|   05 |   10 |
+------+------+
2 rows in set (0.00 sec)

这样就看到5这个数值最后显示成05了,这个意义大不大?不大,没啥意思!!!
如果不指定显示位数,MySQL数据库对于整数型默认分配的显示位数如下:
int(11)、tinyint(4)、smallint(6)、mediumint(9)、bigint(20),但是默认情况下没啥意义,因为我们创建数据库的时候相关字段根本没有设定zerofill,所以就毫无效果!

关于 MySQL 的 timestamp

如果不给 timestamp 类型的字段赋值或者赋值 null,则默认保存当前系统时间

关于 JDBC 类型

ResultSet 对象中获取列的值的方法:

int id = rs.getInt("id");
String name = rs.getString("name");
int job_id = rs.getInt("job_id");
int mgr = rs.getInt("mgr");
Date hiredate = rs.getDate("hiredate");
// salary 在数据库中的类型是 decimal
BigDecimal salary = rs.getBigDecimal("salary");
// bonus 在数据库中的类型是 decimal
BigDecimal bonus = rs.getBigDecimal("bonus");
int dept_id = rs.getInt("dept_id");

PreparedStatement 对象中的设置预编译 SQL 语句参数值的方法:

setByte​(int parameterIndex, byte x)
setBlob​(int parameterIndex, Blob x)
setDouble​(int parameterIndex, double x)

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

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

相关文章

java10个基础错误_我们处理了10亿个Java记录的错误-这是导致97%的错误的原因

java10个基础错误97%的记录错误是由10个唯一错误引起的 在2016年,一件事在30年内没有改变。 开发和运营团队仍依靠日志文件对应用程序问题进行故障排除。 由于某些未知原因,我们隐式信任日志文件,因为我们认为事实隐藏在其中。 如…

MySQL的索引学习

文章目录索引自动创建索引手动创建索引删除索引使用索引单列索引PRIMARYNORMALUNIQUEFULLTEXT组合索引(复合索引/联合索引)索引不足之处索引使用注意事项索引方式 Hash 和 BTree 比较删除索引索引 数据库的索引就像一本书的目录,能够加快数据…

aptx与ldac音质区别_蓝牙协议LDAC和aptx的区别?

LDAC技术的功能介绍LDAC是索尼研发的一种无线音频编码技术,它最早在2015年的CES消费电子设备大展上亮相。在当时,索尼表示比起标准的蓝牙编码、压缩系统,LDAC技术要高效三倍之多。这样一来,那些高解析度的音频文件在进行无线传输的…

【音视频安卓开发 (九)】使用AudioRecord录制PCM音频

1.需要添加权限 <uses-permission android:name"android.permission.CAMERA" /><uses-permission android:name"android.permission.FLASHLIGHT" /><uses-permission android:name"android.permission.CAMERA" /><uses-per…

结果集 tostring_关于避免对toString()结果进行解析或基于逻辑的美德

结果集 tostring使用Java或我使用过的其他编程语言&#xff0c;我发现有时候可以用该语言完成某些事情&#xff0c;但通常不应该这样做。 通常&#xff0c;这些误用语言似乎无害&#xff0c;当开发人员首次使用它们时可能是有益的&#xff0c;但后来同一位开发人员或另一位开发…

3制造数据集_基于MBD的产品设计制造技术研究

本篇节选自论文《基于MBD的产品设计制造技术研究》&#xff0c;发表于《中国电子科学研究院学报》第8卷第6期&#xff0c;作者为中国电子科技集团公司第14研究所专家朱建军。本文经授权转载自公众号学术plus&#xff0c;版权归原作者所有。作者&#xff1a;中国电子科技集团公司…

JSP文件如何转换成Java文件?

文章目录jsp 文件如何转换成 java 文件jsp 何时开始编译jsp 编译后的文件存储目录jsp 文件如何转换成 java 文件 html ----> service(),使用 out.write()输出。 java代码片段 <% %> ----> service(),照…

【WebRTC---源码篇】(九)媒体协商

1.媒体协商的过程 2. 重要的接口类 3.时序图 4.几个关键点 5.code if (InitializePeerConnection()) {peer_id_ = peer_id;//参数1:观察者,创建成功后回调OnSuccess//参数2:消息类型,自动推导peer_connection_->CreateOffer(this, webrtc::PeerConnectionInterface::RTCOff…

jpa 使用jdbc_在JPA和JDBC中使用存储过程。 嗯,只要使用jOOQ

jpa 使用jdbcJava杂志的当前版本由Josh Juneau撰写了有关JDBC和JPA的大数据最佳实践的文章&#xff1a; http : //www.javamagazine.mozaicreader.com/MayJune2016 本文介绍了如何在JDBC中使用存储过程&#xff08;不幸的是&#xff0c;请注意如何关闭资源。即使在Java Magazi…

JSP文件中Java代码的几种形式(JSP脚本)

文章目录第一种形式&#xff08;Java 代码片段&#xff09;第二种形式&#xff08;JSP 表达式&#xff09;第三种形式&#xff08;JSP 声明&#xff09;第四种形式&#xff08;JSP 指令&#xff09;第一种形式&#xff08;Java 代码片段&#xff09; 原样复制到 service() 方法…

【WebRTC---源码篇】(七)NACK的处理流程

NACK调用栈 从分发器接收Packet包 void RtpVideoStreamReceiver::ReceivePacket(const RtpPacketReceived& packet) {if (packet.payload_size() == 0) {// Padding or keep-alive packet.// TODO(nisse): Could drop empty packets earlier, but need to figure out how…

java实现资源监视器_实现Java监视的12个步骤程序存在缺陷

java实现资源监视器Java监视的当前状态最大的问题是什么&#xff1f; 生产中的错误很像喝醉的短信。 您只有在事情已经发生之后才意识到出了点问题。 发短信日志通常比应用程序错误日志更有趣&#xff0c;但是……两者可能同样难以修复。 在本文中&#xff0c;我们将执行一个…

QT之QML布局相关总结

使用QML有助于提高界面编写效率&#xff0c;对付界面开发来说&#xff0c;页面如何布局是一个绕不开的点&#xff0c;本文总结一下QML中常用的一些和布局相关的内容。 目录 1.手动定位 2.坐标绑定定位 3.锚定位 4.布局定位器 5.布局管理器 6.其他布局相关 6.1 弹簧功能…

bpmn2 vue 设计器_vue项目中使用bpmn-基础篇

后退前进下载style"display: inline-block;":file-list"fileList"class"upload-demo"action"":auto-upload"false":show-file-list"false":http-request"httpRequest":on-change"handleOnchangeFi…

JSP的隐含对象/隐藏对象/内置对象介绍

文章目录outJspWriter 和 PrintWriter 的区别requestresponsesessionapplicationexceptionconfigpageContextpageContext 的作用绑订数据获得其它几个隐含对象page四个 JSP 域对象访问范围比较out out 对象是 javax.servlet.jsp.JspWriter 类的实例&#xff0c;用来在 respons…

hystrix应用 博客_使用Hystrix DSL创建弹性骆驼应用程序

hystrix应用 博客Apache Camel是一个成熟的集成库&#xff08;到现在已有9年的历史了&#xff09;&#xff0c;它实现了Enterprise Integration Patterns一书中的所有模式。 但是Camel不仅是EIP实现库&#xff0c;它还是一个不断发展&#xff0c;添加新模式并适应行业变化的现代…

notebook打开外部文件_CAD外部参照真是个好东西!

好课推荐&#xff1a;零基础CAD&#xff1a;点我CAD室内&#xff1a;点我 周站长CAD&#xff1a;点我CAD机械&#xff1a;点我 Bim教程&#xff1a;点我CAD建筑&#xff1a;点我CAD三维&#xff1a;点我全屋定制&#xff1a;点我 ps教程&#xff1a;点我苹果版CAD:点我 3dmax教…

JSP动作元素/活动元素

文章目录jsp:forwardjsp:includejsp:paramjsp:useBeanjsp:setPropertyjsp:setProperty name"" property"" value""jsp:setProperty name"" property"" param""jsp:setProperty name"" property"*&…

【数论系列】任意角的三角函数

角度转为弧度 import math math.radians(x) 弧度转为角度 import math math.degrees(x) 正弦函数 import math math.sin(弧度) 余弦函数 import math math.cos(弧度) 正切函数 import math math.tan(弧度)