基于达梦数据库开发-Java篇

文章目录

  • 前言
  • 一、示例展示
    • 1.环境准备
    • 2.采用基础的jdbc调用
    • 3.采用扩展的mybatis调用
  • 二、注意事项
    • 1.使用路径注解
    • 2.数据库对象的准确引用
  • 三、可能异常
    • 1.无效的表或视图名
    • 2.无效的表或视图名
    • 3.网络通信异常
  • 总结


前言

达梦提供了JDBC方式的驱动以便进行Java开发。默认情况下相关Jar包可在部署的数据库安装目录 /dmdbms/drivers/jdbc中获取,一般情况下 在JDK8环境下采用DmJdbcDriver18.jar 进行相关的达梦数据库开发。本文讲述基于IDEA开发工具,使用SpringBoot框架进行简单的达梦开发示例,并讨论可能遇到的问题。


一、示例展示

1.环境准备

  1. 搭建一个达梦数据库,并建立相关账户及数据库对象(本例建立用户TESTDM,并在该用户下建立表TEST_BLOCK_T)
  2. 在安装目录 /dmdbms/drivers/jdbc中复制文件DmJdbcDriver18.jar到本地
  3. 在IDEA中搭建SpringBoot工程并引入文件DmJdbcDriver18.jar(本例工程中建立lib文件夹,并在文件夹中引入文件DmJdbcDriver18.jar)

2.采用基础的jdbc调用

使用jdbc方式调用达梦数据库的核心操作包含以下几步:

  • 在pom文件配置相关jar包信息,其中达梦包引用本地路径
        <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId></dependency><dependency><groupId>com.dm</groupId><artifactId>Dm8JdbcDriver</artifactId><version>1.8</version><scope>system</scope><systemPath>${project.basedir}/lib/DmJdbcDriver18.jar</systemPath></dependency>
  • 配置application.properties
spring.datasource.driverClassName=dm.jdbc.driver.DmDriver
spring.datasource.url=jdbc:dm://10.1.29.113:5236
spring.datasource.username=TESTDM
spring.datasource.password=123456
  • 添加控制类文件DbController.java
@RestController
public class DbController {@Autowiredprivate JdbcTemplate jdbcTemplate;@GetMapping("/queryDbVersion")public List queryDbVersion() {System.out.println("test ok111");return jdbcTemplate.queryForList("SELECT block_id,block_name  FROM TEST_BLOCK_T");}
}

运行后正常情况下在浏览器输入 http://localhost:8080/queryDbVersion 会展示如下结果
在这里插入图片描述

3.采用扩展的mybatis调用

使用扩展的mybatis方式调用达梦数据库的核心操作包含以下几步:

  • 在pom文件配置相关jar包信息,其中达梦包引用本地路径
        <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.1</version></dependency><dependency><groupId>com.dm</groupId><artifactId>Dm8JdbcDriver</artifactId><version>1.8</version><scope>system</scope><systemPath>${project.basedir}/lib/DmJdbcDriver18.jar</systemPath></dependency>
  • 配置application.properties(与jdbc调用的配置方式相同)
  • 添加实体类文件Block.java
@TableName(value = "TEST_BLOCK_T")
public class Block {private static final long serialVersionUID = 1L;@TableIdprivate String blockId;private String blockName;public String getBlockId() {return blockId;}public void setBlockId(String blockId) {this.blockId = blockId;}public String getBlockName() {return blockName;}public void setBlockName(String blockName) {this.blockName = blockName;}}
  • 添加映射接口文件BlockMapper.java
@Mapper
public interface BlockMapper extends BaseMapper<Block> {
}
  • 添加控制类文件BlockController.java
@RestController
@RequestMapping("/hello")
public class BlockController {@Autowiredprivate BlockMapper blockMapper;@GetMapping("/list")@ResponseBodypublic List index() {//直接调用BaseMapper封装好的CRUD方法,就可实现无条件查询数据List<Block> list = blockMapper.selectList(null);//循环获取用户数据for (Block block:list){//获取用户名称System.out.println(block.getBlockName());}return list;

运行后正常情况下在浏览器输入 http://localhost:8080/queryDbVersion 会展示与jdbc调用相同的结果

二、注意事项

1.使用路径注解

示例讲述的工程是以标准路径方式建立的,其文件结构如下所示
在这里插入图片描述
有时候因特殊情况,我们建立的工程可能并不是规范的路径,例如工程路径如下所示

在这里插入图片描述

这时候需要在相关的启动文件中添加@ComponentScan与@MapperScan注解信息,类似如下所示

@SpringBootApplication
@MapperScan("com.mapper")
@ComponentScan("com.controller")
public class demo  {public static void main(String[] args) {SpringApplication.run(demo.class, args);}}

2.数据库对象的准确引用

在之前调用示例中我们使用账户TESTDM登录时对象TEST_BLOCK_T只在模式TESTDM中存在,如果该对象在多个模式下存在,则需要做相应处理,以下为两种处理方式:

  • 调整application.properties
spring.datasource.driverClassName=dm.jdbc.driver.DmDriver
spring.datasource.url=jdbc:dm://10.1.29.113:5236/TESTDM
spring.datasource.username=TESTDM
spring.datasource.password=123456

在spring.datasource.url中明确指出调用的模式

  • 增加对象的模式节点引用
    修改实体类文件Block.java注解为
@TableName(value = "TESTDM.TEST_BLOCK_T")

三、可能异常

1.无效的表或视图名

在运行工程中如果出现如下类似错误

2024-04-16 15:27:43.466 ERROR 1120 --- [nio-8080-exec-1] o.a.c.c.C.[.[.[/].[dispatcherServlet]    : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is org.springframework.dao.DataIntegrityViolationException:
### Error querying database.  Cause: dm.jdbc.driver.DMException: 第1 行附近出现错误:
无效的表或视图名[TEST_BLOCK_T]

可能数据库账号默认模式中没有相关表,需要准确引用

2.无效的表或视图名

2024-04-17 14:20:00.878 ERROR 25116 --- [nio-8080-exec-1] o.a.c.c.C.[.[.[/].[dispatcherServlet]    : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.exceptions.PersistenceException:
### Error querying database.  Cause: org.springframework.jdbc.CannotGetJdbcConnectionException: Failed to obtain JDBC Connection; nested exception is dm.jdbc.driver.DMException: 用户名或密码错误

可能数据库账号或密码的不对,有可能为大小写不一致导致

3.网络通信异常

2024-04-17 14:22:25.803 ERROR 41240 --- [nio-8080-exec-1] o.a.c.c.C.[.[.[/].[dispatcherServlet]    : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.exceptions.PersistenceException:
### Error querying database.  Cause: org.springframework.jdbc.CannotGetJdbcConnectionException: Failed to obtain JDBC Connection; nested exception is dm.jdbc.driver.DMException: 网络通信异常

可能spring.datasource.url配置的IP无法访问,也可能相关的端口无法访问

总结

本文简述了两种使用Java连接数据库的工作方式,并阐述了一些需要注意的细节以及一些可能出现的异常情况。相关完整代码请见JAVA-SpringBoot-达梦-IDEA-连接访问示例

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

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

相关文章

Unity Editor编辑器扩展之创建脚本

前言 既然你看到这篇文章了&#xff0c;你是否也有需要使用代码创建脚本的需求&#xff1f;使用编辑器扩展工具根据不同的表格或者新增的内容去创建你想要的脚本。如果不使用工具&#xff0c;那么你只能不断去修改某个脚本&#xff0c;这项工作既繁琐也浪费时间。这个时候作为程…

什么是时间序列分析

时间序列分析是现代计量经济学的重要内容&#xff0c;广泛应用于经济、商业、社会问题研究中&#xff0c;在指标预测中具有重要地位&#xff0c;是研究统计指标动态特征和周期特征及相关关系的重要方法。 一、基本概念 经济社会现象随着时间的推移留下运行轨迹&#xff0c;按…

listpack

目录 为什么有listpack? listpack结构 listpack的节点entry 长度length encoding编码方式 listpack的API 1.创建listpack 2.遍历操作 正向遍历 反向遍历 3.查找元素 4.插入/替换/删除元素 总结 为什么有listpack? ziplist是存储在连续内存空间&#xff0c;节省…

VSCode + ESP-IDF安装与配置全过程

接前一篇文章&#xff1a;ESP-IDF下载与安装完整流程 前一篇文章讲解了如何手动下载ESP-IDF&#xff0c;也就是快速入门 - ESP32 - — ESP-IDF 编程指南 latest 文档 (espressif.com)中的红色框中的部分&#xff1a; 本文讲解另一种方法&#xff0c;也是更为常用的方式 —— VS…

通俗说字解词:什么是道理?常说讲道理,李秘书讲写作这节就给你讲“道理”!

通俗说字解词&#xff1a;什么是道理&#xff1f;常说讲道理&#xff0c;李秘书讲写作这节就给你讲“道理”&#xff01; 说到“道理”&#xff0c;这可真是个有意思的词。它由“道”和“理”两个部分组成&#xff0c;就像一碗好吃的面&#xff0c;有汤有料&#xff0c;缺一不可…

MySQL-实验-单表、多表数据查询和嵌套查询

目录 0.简单子查询 &#xff08;1&#xff09;带比较运算符的子查询 &#xff08;2&#xff09;关键字子查询 1.多表查询 3.子查询 4.多表子查询 0.简单子查询 &#xff08;1&#xff09;带比较运算符的子查询 在右侧编辑器补充代码&#xff0c;查询大于所有平均年龄的员…

【学习】自动化测试有哪些优势和不足

在当今这个数字化时代&#xff0c;软件测试已经成为了任何一款产品成功的关键因素之一。而在诸多的测试方法中&#xff0c;自动化测试凭借着其独特的魅力吸引着越来越多的企业。今天就让我们一起走进自动化测试的世界&#xff0c;探讨它的优势与不足。 一、自动化测试优势 1.…

小红的排列构造(dp优化)

题目描述 小红拿到了一个长度为n的数组a&#xff0c;她希望你构造两个排列p和q&#xff0c;满足对于i∈[1,n],ai∈[1,n]pi或qi二选一。你能帮帮她吗&#xff1f;定义排列是一个长度为n的数组&#xff0c;其中1到n每个元素恰好出现1次。 输入描述:第一行输入一个正整数n&#…

Github 2024-04-20 开源项目日报 Top10

根据Github Trendings的统计,今日(2024-04-20统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量非开发语言项目2Python项目2Swift项目2HTML项目1CSS项目1Go项目1C项目1C++项目1Rust项目1编程面试大学:成为软件工程师的全面学习计划 创建周期…

姑苏寻韵~庆开放原子开源大赛 OpenTiny 前端 Web 应用开发挑战赛路演圆满落幕。

春日已至&#xff0c;姑苏古城迎来了一场编程的盛宴——开放原子开源大赛OpenTiny前端Web应用开发挑战赛。历时三个月的激烈角逐&#xff0c;OpenTiny与众多开发者携手共赴这场智慧的较量。决赛路演于4月14日在苏州&#xff08;太湖&#xff09;产业软件园圆满落下帷幕~ 开放原…

(C语言)sscanf 与 sprintf详解

目录 1.sprintf函数详解 2. sscanf函数详解 1.sprintf函数详解 头文件&#xff1a;stdio.h 作用&#xff1a;将格式化的数据写入字符串里&#xff0c;也就是将格式化的数据转变为字符串。 演示&#xff1a; #include <stdio.h> struct S {char name[10];int height;…

【Ne4j图数据库入门笔记1】图形数据建模初识

1.1 图形建模指南 图形数据建模是用户将任意域描述为节点的连接图以及与属性和标签关系的过程。Neo4j 图数据模型旨在以 Cypher 查询的形式回答问题&#xff0c;并通过组织图数据库的数据结构来解决业务和技术问题。 1.1.1 图形数据模型介绍 图形数据模型通常被称为对白板友…