mysql中tinyint(1)对应java中的boolean问题及解决方案(jdbc查询)

1 篇文章 0 订阅
1 篇文章 0 订阅

首先展示下我的问题,可以看见id为66,64,63对应的month_age分别为1,1,0,但是数据库中这三条记录对应的month_age应该是11,5,0
在这里插入图片描述
在这里插入图片描述
造成这个错误的原因是我们在设计数据库时,将month_age这个字段的类型设为tinyint(1),而tinyint(1)对应java中的boolean类型,0对应false,非0对应true
在这里插入图片描述
然后由于我代码是这样写的

public DataList getChildVisitAndExaminList(Integer personId, Integer... createAgencyId) throws SQLException {
        ArrayList<Object> condition = new ArrayList<>();
        condition.add(personId);
        Connection connection = JDBCUtils.getConnection();
        String sqlStr = "select id,month_age,visit_date,doctor_id,doctor,next_date,create_agency,create_agencyid from" +
                " tbl_children_visit where is_delete != 1 and person_id = ?";
        if (createAgencyId.length > 0) {
            sqlStr += " and create_agencyid = ?";
            condition.add(createAgencyId[0]);
        }
        sqlStr += " order by id desc";
        PreparedStatement ps = connection.prepareStatement(sqlStr);
        for (int i = 0; i < condition.size(); i++) {
            ps.setObject(i + 1, condition.get(i));
        }
        ResultSet rs = ps.executeQuery();
        ResultSetMetaData md = rs.getMetaData();
        int columnCount = md.getColumnCount();
        Map<String, Object> rowData = new HashMap<>();
        List<ChildrenListRes> list = new ArrayList<>();
        while (rs.next()) {
           for (int i = 1; i <= columnCount; i++) {
                if (md.getColumnLabel(i).equals("visit_date") || md.getColumnLabel(i).equals("next_date")) {
                    rowData.put(md.getColumnLabel(i),TimeUtil.timeStamp2Date(rs.getObject(i,Long.class)));
                } else {
                    rowData.put(md.getColumnLabel(i), rs.getObject(i));
                }
            }
            String jsonStr = JSONObject.toJSONString(rowData);
            ChildrenListRes childrenListRes = JSONObject.parseObject(jsonStr, ChildrenListRes.class);
            list.add(childrenListRes);
        }
        // 拼接photo
        ChildrenDao.getChildrenPhotoPath(list);
        JDBCUtils.release(connection, ps, rs);
        return new DataList(list);
    }

在这里插入图片描述

rs.getObject(i)由于定义的是object类型,他这里拿到false就会转成0,true就会转成1

解决方案:
法一:改数据库字段类型
将tinyint(1)改为tinyint(4),mysql的tinyint默认为tinyint(4)
关于tinyint与java中类型对应关系可参考此链接
法二:修改代码,多添加一个判断,如下(这种情况针对数据库字段里面没用bit类型)

在这里插入图片描述

由于数据库不能轻易改动,所以我选择了法二,下面看下查询结果,成功解决
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MySQL字段类型长度和Java类型有以下对应关系: 1. 字符串类型: - CHAR(n):Java类型为String,长度为n。 - VARCHAR(n):Java类型为String,长度为n。 - TEXT:Java类型为String。 2. 数值类型: - INTJava类型int。 - BIGINTJava类型为long。 - DECIMAL(p, s):Java类型为BigDecimal,其p表示总位数,s表示小数位数。 3. 日期和时间类型: - DATE:Java类型java.sql.Date。 - TIME:Java类型java.sql.Time。 - DATETIME:Java类型java.sql.Timestamp。 4. 布尔类型: - BOOL、BOOLEANJava类型boolean。 5. 二进制类型: - BLOB:Java类型为byte[]。 需要注意的是,Java的数据类型MySQL的字段类型并不完全一致,因此在进行数据类型转换时需要注意类型匹配。在使用JDBC连接MySQL进行数据操作时,可以根据需要使用ResultSet的get方法和PreparedStatement的set方法来进行数据类型的转换。同时,在设计数据库表结构时也需要根据实际需求选择合适的MySQL字段类型,以确保数据的存储和查询效率,并防止数据溢出或损失。 ### 回答2: MySQL的字段类型长度和Java类型对应如下: 1. 字符串类型(VARCHAR、CHAR): - VARCHAR(n) 对应 Java 的 String 类型,表示一个可变长度的字符串,最大长度为 n,例如:VARCHAR(50) 对应 Java 的 String。 - CHAR(n) 对应 Java 的 String 类型,表示一个固定长度的字符串,长度为 n,例如:CHAR(20) 对应 Java 的 String。 2. 数值类型INT、BIGINT、FLOAT、DOUBLE、DECIMAL): - INT 对应 Javaint 类型。 - BIGINT 对应 Java 的 long 类型。 - FLOAT 对应 Java 的 float 类型。 - DOUBLE 对应 Java 的 double 类型。 - DECIMAL(precision, scale) 对应 Java 的 BigDecimal 类型,其 precision 表示总长度,scale 表示小数点后的位数,例如:DECIMAL(10, 2) 对应 Java 的 BigDecimal。 3. 日期和时间类型(DATE、TIME、DATETIME、TIMESTAMP): - DATE 对应 Java 的 LocalDate 类型。 - TIME 对应 Java 的 LocalTime 类型。 - DATETIME 和 TIMESTAMP 都对应 Java 的 LocalDateTime 类型。 4. 布尔类型BOOLEAN、BIT): - BOOLEAN 对应 Javaboolean 类型。 - BIT(n) 对应 Java 的 byte[] 类型。 5. 其他类型: - BLOB 对应 Java 的 byte[] 类型,用于存储二进制数据。 - TEXT 对应 Java 的 String 类型,用于存储大文本数据。 需要注意的是,MySQL的字段类型长度和Java类型对应是一种常见的映射方式,但不是唯一的方式。在不同的数据库和编程语言,可能会有一些差异或变化。此外,还可以使用数据库连接工具或框架进行字段类型Java类型的自动映射。 ### 回答3: MySQL字段类型的长度和Java类型对应关系如下: 1. 数值类型: - TINYINTJava类型为byte,长度为1字节。 - SMALLINTJava类型为short,长度为2字节。 - MEDIUMINTJava类型int,长度为3字节。 - INTJava类型int,长度为4字节。 - BIGINTJava类型为long,长度为8字节。 - FLOAT:Java类型为float,长度为4字节。 - DOUBLE:Java类型为double,长度为8字节。 - DECIMAL:Java类型为BigDecimal,长度可自定义。 2. 字符串类型: - CHAR:Java类型为String,长度可自定义,最大为255字节。 - VARCHAR:Java类型为String,长度可自定义,最大为65535字节。 - TEXT:Java类型为String,长度可自定义,最大为65535字节。 - BLOB:Java类型为byte[],长度可自定义,最大为65535字节。 3. 日期和时间类型: - DATE:Java类型java.sql.Date,长度为3字节。 - TIME:Java类型java.sql.Time,长度为3字节。 - DATETIME:Java类型java.sql.Timestamp,长度为8字节。 - TIMESTAMP:Java类型java.sql.Timestamp,长度为4字节。 - YEAR:Java类型java.util.Date,长度为1字节。 4. 其他类型: - BOOLEANJava类型boolean,长度为1字节。 - ENUM:Java类型为String,长度可自定义。 需要注意的是,MySQL的字段类型长度可能会受到存储引擎和字符编码的影响,所以实际长度可能有所不同。对于字符串类型,长度指的是字符数,而不是字节数。另外,为了更准确地处理日期和时间类型,建议使用对应Java日期时间类。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值