mybatis实现mysql point转Java对象

时间: 2024-02-03 15:03:49 浏览: 25
在 MyBatis 中,可以使用自定义 TypeHandler 来实现 MySQL Point 类型转换为 Java 对象。 下面是一个示例代码,使用 MyBatis 的 TypeHandler 将 MySQL Point 类型转换为 Java 对象: 首先,定义一个 Point 类,用于封装 Point 类型的坐标: ```java public class Point { private double x; private double y; public Point(double x, double y) { this.x = x; this.y = y; } public double getX() { return x; } public void setX(double x) { this.x = x; } public double getY() { return y; } public void setY(double y) { this.y = y; } } ``` 接着,实现一个 PointTypeHandler 类,继承自 BaseTypeHandler<Point>,用于将 MySQL Point 类型转换为 Java 对象: ```java import java.sql.*; import org.apache.ibatis.type.*; public class PointTypeHandler extends BaseTypeHandler<Point> { @Override public void setNonNullParameter(PreparedStatement ps, int i, Point parameter, JdbcType jdbcType) throws SQLException { String pointStr = "POINT(" + parameter.getX() + " " + parameter.getY() + ")"; ps.setString(i, pointStr); } @Override public Point getNullableResult(ResultSet rs, String columnName) throws SQLException { String pointStr = rs.getString(columnName); return parsePoint(pointStr); } @Override public Point getNullableResult(ResultSet rs, int columnIndex) throws SQLException { String pointStr = rs.getString(columnIndex); return parsePoint(pointStr); } @Override public Point getNullableResult(CallableStatement cs, int columnIndex) throws SQLException { String pointStr = cs.getString(columnIndex); return parsePoint(pointStr); } private Point parsePoint(String pointStr) { if (pointStr == null) { return null; } pointStr = pointStr.replace("POINT(", "").replace(")", ""); String[] coordinates = pointStr.split("\\s+"); double x = Double.parseDouble(coordinates[0]); double y = Double.parseDouble(coordinates[1]); return new Point(x, y); } } ``` 在这个 TypeHandler 中,重写了 setNonNullParameter()、getNullableResult() 等方法,用于将 Java 对象转换为 MySQL Point 类型,以及将 MySQL Point 类型转换为 Java 对象。在 getNullableResult() 方法中,使用 parsePoint() 方法解析 Point 类型的字符串,并封装为 Point 对象返回。 最后,在 MyBatis 的 Mapper 文件中,将 PointTypeHandler 注册到对应的 resultMap 中即可: ```xml <resultMap id="pointResultMap" type="com.example.Point"> <result column="point_column" property="point" typeHandler="com.example.PointTypeHandler"/> </resultMap> ``` 这样,就可以使用 MyBatis 查询 Point 类型的数据,并转换为 Java 对象了。

相关推荐

最新推荐

recommend-type

MyBatis实现Mysql数据库分库分表操作和总结(推荐)

主要介绍了MyBatis实现Mysql数据库分库分表操作和总结,需要的朋友可以参考下
recommend-type

mybatis中实现枚举自动转换方法详解

在使用mybatis的时候经常会遇到枚举类型的转换,下面这篇文章主要给大家介绍了关于mybatis中实现枚举自动转换的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或工作具有一定的参考学习价值,需要的朋友们...
recommend-type

mybatis连接MySQL8出现的问题解决方法

主要介绍了mybatis连接MySQL8出现的问题解决方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
recommend-type

SpringBoot整合MyBatis实现乐观锁和悲观锁的示例

主要介绍了SpringBoot整合MyBatis实现乐观锁和悲观锁的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

mybatis 实现 SQL 查询拦截修改详解

主要介绍了mybatis 实现 SQL 查询拦截修改详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

list根据id查询pid 然后依次获取到所有的子节点数据

可以使用递归的方式来实现根据id查询pid并获取所有子节点数据。具体实现可以参考以下代码: ``` def get_children_nodes(nodes, parent_id): children = [] for node in nodes: if node['pid'] == parent_id: node['children'] = get_children_nodes(nodes, node['id']) children.append(node) return children # 测试数
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。