达梦数据库踩坑

提示:第一次接触达梦,是真的不好用,各种报错不提示详细信息,吐槽归吐槽,还是需要学习使用的。

前言

题主刚接触达梦数据库时,本来是想下载官网的连接工具进行数据库连接的,但是谁曾想,官网既然客户端和服务端集成到一块下载一个压缩包一个多G,题主大为不解。所以第一次使用客户端时,我选择了DBeaver工具。后面做代码本地测试时,才被迫下载了服务器端。

一、达梦和mysql创建database对比

对于mysql我们一般是通过ip地址、端口号、用户名、密码去在mysql的连接工具当中去连接,此时如果这个登录的账号有创建数据的权限是,我们可以直接通过new Database去新建数据库。对于达梦数据来说,我们也可以通过上述的四个参数去连接数据库。但是当我们创建数据库时,需要在达梦数据库的一个模式的目录下去创建,这个操作类似于mysql当中的new Database操作。在创建数据库时,需要勾选忽略大小写敏感。不然后续做数据查询时,默认使用的表名称是大写,如果表定义使用的小写就会报错。

二、spring boot连接达梦数据库出现的异常

Cause: dm.jdbc.driver.DMException:第4 行附近出现错误:无效的表或视图名:
在这里插入图片描述
对于spring配置达梦数据库连接时,题主第一次直接在原生的SYSDBA用户连接当中去创建了一个新的模式(即一个新的database)。在spring做数据库查询时就会爆出异常,后面查询得知达梦在查询时,如果用户名和模式名称一致时,查询语句不会拼接模式名称,例如:select * from user。
如果用户名和查询的模式不一致时,达梦默认查询时会默认带上用户名称对应的模式名称。例如如果我们通过SYSDBA登录,新建一个模式(库)TEST,然后在TEST当中新增表数据。spring在做数据查询时,就会报出上述的异常,因为达梦在做数据查询时,使用的sql是select * from SYSDBA.user。此时就会出现异常,所以我们需要给一个模式创建一个单独的用户,且模式的名称和用户名称要完全一致。

三、语法差异

对于创建一个表结构数据,自增主键id的设置和mysql的差异比较大,INT类型的数据不可以设置长度。对于字段的描述和表结构的描述也不可以在表定义上去设置。

-- 创建一个表
CREATE TABLE "mh_user" ("id" BIGINT IDENTITY(1, 1) PRIMARY KEY,"account" VARCHAR(20) NOT NULL,"actual_name" VARCHAR(16) NOT NULL,"company_id" BIGINT DEFAULT NULL,"department_id" BIGINT DEFAULT NULL,"email" VARCHAR(32) DEFAULT NULL,"employee_no" VARCHAR(32) DEFAULT NULL,"password" VARCHAR(64) NOT NULL,"password_status" INT NOT NULL,"enabled" TINYINT NOT NULL,"remark" TEXT,"create_by" INT DEFAULT NULL,"create_time" TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,"update_by" INT DEFAULT NULL,"updated_time" TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,"deleted" TINYINT NOT NULL DEFAULT 0
);
-- 设置表的备注信息
COMMENT ON TABLE "TEST"."mh_user" is '用户信息';
-- 添加字段注释
COMMENT ON COLUMN "mh_user"."id" IS '主键id';
COMMENT ON COLUMN "mh_user"."account" IS '用户名|账号';

总结

上述的问题就是题主在第一次接触达梦时遇到的坑,其实还有就是达梦数据库的语法和mysql语法的差异,主要记录一下解决方案,后续如果再遇到的话,可以快速的去修复。

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

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

相关文章

sql中的union与union all区别

sql中的union与union all区别 1、 区别2、效率3、使用建议 💖The Begin💖点点关注,收藏不迷路💖 1、 区别 union: 功能:合并多个查询结果集,并自动去除重复行。特点:结果集中不包含重…

linux如何对c++进行内存分析

linux如何对c进行内存分析 背景分析方法以及原理原理分析结果以及重点关注 背景 在工作中,我遇到一个问题,需要将c写的进程部署到MCU上。由于MCU上可用的RAM 非常有限,所以在部署时就需要考虑到使用内存大小。所以为了搞清楚,内存…

计算机网络29——Linux基本命令vim,gcc编译命令

1、创建新用户 2、给用户设置密码 3、切换到新用户 切换到root用户 4、删除用户 5、查看ip 6、ping 查看物理上两台主机是否联通 7、netstatus 8、nslookup 查看网址的地址 9、负载均衡与容灾备份 负载均衡:指将负载(工作任务)进行平衡、分…

STM32如何修改外部晶振频率和主频

对于STM32F10x系列的单片机,除了STM32F10x_CL单片机,其它的单片机一般外部晶振HSE的时钟频率都默认是8MHz。如果我们使用的外部晶振为12Mhz,那么可以把上图绿色标记改为:12000000 72MHz的主频8MHz的外部晶振HSE*倍频系数9。当然如果像上面把外…

什么是HTTP DDOS,如何防护

在当今高度互联的网络世界中,网络安全威胁日益严峻,其中HTTP DDoS(Distributed Denial of Service,分布式拒绝服务)攻击作为一种常见的网络攻击手段,给企业和个人用户带来了巨大的挑战。今天我们就来详细介…

STM32与51单片机的区别:是否应该直接学习STM32?

STM32与51单片机的区别:是否应该直接学习STM32? 在单片机的世界里,STM32和51单片机都是非常重要的角色。对于初学者来说,是否可以直接跳过51单片机,直接学习STM32,这个问题一直存在争议。让我们深入探讨这…

Linux 文件权限详解与管理

文章目录 前言一、文件权限概述1. 权限表示格式2. 权限组合值 二、查看文件权限三、修改文件所有者与所属组1. 使用 chown 修改文件所有者2. 使用 chgrp 修改文件所属组3. 添加所有者 四、修改文件权限1. 符号方式2. 八进制方式3. 实际修改 总结 前言 在 Linux 系统中&#xf…

2024 新手指南:轻松掌握 Win10 的录屏操作

之前为了节约成本我们公司都采用录制软件操作都方式来为异地的同事进行远程操作培训的。所以我们尝试了不少的录屏工具,这里我就分享下win10怎么录屏的操作过程。 1.福昕录屏大师 链接:www.foxitsoftware.cn/REC/ 这款录屏工具是初学者的理想之选&…

网关登录校验(2)----网关如何将用户信息传递给微服务

1.微服务获取用户信息 现在,网关已经可以完成登录校验并获取登录用户身份信息。但是当网关将请求转发到微服务时,微服务又该如何获取用户身份呢? 由于网关发送请求到微服务依然采用的是Http请求,因此我们可以将用户信息以请求头…

【linux】4张卡,坏了1张,怎么办?

先禁用这张卡 grub 禁用,防止加载驱动 禁用这张卡的 PCI # 禁用 PCI 设备 0000:b1:00.0 (NVIDIA GPU) ACTION"add", SUBSYSTEM"pci", ATTR{vendor}"0x10de", KERNELS"0000:b1:00.0", RUN"/bin/sh -c echo 0000:b1:00…

QTCreator 调试:unknown debugger type “No engine“

QTCreator 调试:unknown debugger type "No engine" - kaizenly - 博客园 (cnblogs.com) 一开始Debuggers---Auto-detected这里第一row第一个项是标红的,然后没改东西,点完应用Apply以后,就可以调试了...(不…

sqlite数据库设计工具

下载 开发环境 VS2022 + Qt5.14.2 CMake修改 add_subdirectory(sqlite3-cmake) include_directories(${CMAKE_SOURCE_DIR}/sqlite3-cmake/src) target_link_libraries(${PROJECT_NAME} sqlite3) 效果 参考 https://github.com/sqlitebrowser/sqlitebrowser

JavaWeb JavaScript 11.XML —— 配置文件

生活想埋没我,没想到我是颗种子 —— 24.9.19 一、XML 1.什么是XML XML是EXtensible Markup Languge的缩写,翻译过来就是可扩展标记语言。所以很明显,XML和HTML一样都是标记语言,也就是说它们的基本语法都是标签 可扩展 三个字…

AI健身体能测试之基于paddlehub实现引体向上计数个数统计

【引体向上计数】 本项目使用PaddleHub中的骨骼检测模型human_pose_estimation_resnet50_mpii,进行人体运动分析,实现对引体向上的自动计数。 1. 项目介绍 人体运动分析是近几年许多领域研究的热点问题。在学科的交叉研究上,人体运动分析涉…

《微软飞行模拟2024》储存空间需求仅不到前作的1/5

根据微软在最新一期 Xbox Wire 中的介绍,将于今年11 月登陆 Xbox Series X|S 主机的《微软飞行模拟2024》将比前作占用空间小很多。 微软解释了为何新作的文件大小仅为30GB,约为前作的五分之一。简单来说,微软使用了云流媒体传输技术。公司还…

macOS平台(intel)编译MAVSDK安卓平台SO库

1.下载MAVSDK: git clone https://github.com/mavlink/MAVSDK.git --recursive 2.编译liblzma 修改CMakeLists.txt文件增加C与CXX指令-fPIC set(CMAKE_C_FLAGS "-fPIC ${CMAKE_C_FLAGS}") set(CMAKE_CXX_FLAGS "-fPIC ${CMAKE_CXX_FLAGS}") 修改如下:…

谷粒商城のElasticsearch

文章目录 前言一、前置知识1、Elasticsearch 的结构2、倒排索引 (Inverted Index)2.1、 索引阶段2.2、查询阶段 二、环境准备1、安装Es2、安装Kibana3、安装 ik 分词器 三、项目整合1、引入依赖2、整合业务2.1、创建索引、文档、构建查询语句2.2、整合业务代码 后记 前言 本篇介…

一文读懂SpringCLoud

一、前言 只有光头才能变强 认识我的朋友可能都知道我这阵子去实习啦,去的公司说是用SpringCloud(但我觉得使用的力度并不大啊~~)… 所以,这篇主要来讲讲SpringCloud的一些基础的知识。(我就是现学现卖了,主要当做我学习SpringCloud的笔记吧&…

分发饼干00

题目链接 分发饼干 题目描述 注意点 1 < g[i], s[j] < 2^31 - 1目标是满足尽可能多的孩子&#xff0c;并输出这个最大数值 解答思路 可以先将饼干和孩子的胃口都按升序进行排序&#xff0c;随后根据双指针 贪心&#xff0c;将当前满足孩子胃口的最小饼干分配给该孩…

携手鲲鹏,长亮科技加速银行核心系统升级

新经济周期下&#xff0c;银行净息差持续收窄、盈利压力加大、市场竞争日趋加剧。同时&#xff0c;国家相关政策不断出台&#xff0c;对金融科技的自主创新与安全可控提出了更高要求。 在这样的大背景下&#xff0c;银行业的数字化转型已经步入深水区。其中&#xff0c;核心系统…