基于达梦数据库开发-C#篇

文章目录

  • 前言
  • 一、相关准备
  • 二、主要代码
    • 1.引入达梦类库
    • 2.连接达梦数据库
    • 3.DmCommand方式获取达梦数据库信息
    • 4.DmDataAdapter方式获取达梦数据库信息
  • 总结


前言

达梦数据库是国产的新一代大型通用关系型数据库,全面支持 SQL 标准和主流编程语言接口/开发框架。其中.NET Data Provider 是 .NET Framework 编程环境下的访问达梦数据库的编程接口,用于连接数据库、执行相关数据库操作。本文将以简单的C#演示工程展示如何获取达梦数据库相关记录信息。


一、相关准备

  • 确保具有可访问的达梦数据库及相关对象
    本文在本地建立了相关的达梦数据库,并创建了对象账号TESTDM,并在该账户下建立相关的表T_CITY_T。表T_CITY_T相关记录如下 在这里插入图片描述

  • 搭建.NET工程,根据相关的.NET框架选择复制对应的类库
    达梦支持的.NET框架有NET20, NET40, NET45,NET50,NET60,NETSTANDARD2.0,NETCOREAPP2.1以及NETCOREAPP3.1,相关的DmProvider.dll 都在达梦数据库的dmdbms\drivers\dotNet 路径下的子文件中 ,本文采用NET40下的DmProvider.dll 搭建相关的演示工程
    在这里插入图片描述

二、主要代码

1.引入达梦类库

当工程引入类库后,在需要连接达梦数据库的cs文件的using区域采用如下方式开始引入达梦类库

using Dm;

2.连接达梦数据库

使用DmProvider提供的DmConnection类建立达梦数据库的连接,示例代码如下

 static DmConnection cnn = new DmConnection();cnn.ConnectionString = "Server=localhost;PORT=5236; User Id=testdm; PWD=123456;";cnn.Open();

其中ConnectionString 连接子串的Server参数配置具体的ip地址,PORT参数为达梦数据库建立时使用的端口号(默认端口为5236),User为达梦数据库的账号名称,PWD为达梦数据库的账号密码

3.DmCommand方式获取达梦数据库信息

DmProvider提供的DmCommand类来获取相关数据库记录信息,示例代码如下

 DmCommand command = new DmCommand();command.Connection = cnn;string a;command.CommandText = "select * from TESTDM.T_CITY_T";var reader = command.ExecuteReader();while (reader.Read()){a = reader.GetString(0);Console.WriteLine(a);}reader.Close();

4.DmDataAdapter方式获取达梦数据库信息

DmProvider还提供的DmDataAdapter类来获取相关数据库记录信息,示例代码如下

 DataTable dt = new DataTable();string sql = "select * from TESTDM.T_CITY_T";using (DmDataAdapter command1 = new DmDataAdapter(sql, cnn)){DataSet ds = new DataSet();command1.Fill(ds, "ds");dt = ds.Tables[0];}    foreach(DataRow  dr in dt.Rows){Console.WriteLine("id:" + dr["CITY_ID"].ToString() + ",name:" + dr["CITY_NAME"].ToString());}

总结

本文简要讲述了如何使用C#获取达梦数据库记录信息,以示例形式展示了DmConnection、DmCommand、DmDataAdapter的简单使用,以vs2019编写的整体相关示例代码请见
VS2019开发的C#连接达梦简要示例

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

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

相关文章

OpenHarmony实战开发-如何利用panel实现底部面板内嵌套列表。

介绍 本示例主要介绍了利用panel实现底部面板内嵌套列表,分阶段滑动效果场景。 效果图预览 使用说明 点击底部“展开”,弹出panel面板。在panel半展开时,手指向上滑动panel高度充满页面,手指向下滑动panel隐藏。在panel完全展开…

浏览器工作原理与实践--浏览上下文组:如何计算Chrome中渲染进程的个数

经常有朋友问到如何计算Chrome中渲染进程个数的问题,那么今天就来完整地解答这个问题。 在前面“04 | 导航流程”这一讲中我们介绍过了,在默认情况下,如果打开一个标签页,那么浏览器会默认为其创建一个渲染进程。不过我们在“04 |…

Echarts-知识图谱

Echarts-知识图谱 demo地址 打开CodePen 效果 思路 1. 生成根节点 2. 根据子节点距离与根节点的角度关系,生成子节点坐标,进而生成子节点 3. 从子节点上按角度生成对应的子节点 4. 递归将根节点与每一层级子节点连线核心代码 定义节点配置 functio…

1011 A+B 和 C

给定区间 [−2^31,2^31] 内的 3 个整数 A、B 和 C,请判断 AB 是否大于 C。 输入格式: 输入第 1 行给出正整数 T (≤10),是测试用例的个数。随后给出 T 组测试用例,每组占一行,顺序给出 A、B 和 C。整数间以空格分隔。…

基于springboot实现车辆管理系统设计项目【项目源码+论文说明】计算机毕业设计

基于springboot实现车辆管理系统演示 摘要 随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。本文介绍了车辆管理系统的开发全过程。通过分析车辆管理系统管理的不足,创建了一个计算机管理车辆管理系统的方案。文章介…

Linux查看cache工具

参考:Linux cache占用大量内存,如何分析是哪些进程、文件导致? 查看cache工具 工具fincorepcstathcachevmtouch说明该工具最初发布于googlecode,但googlecode现在已经关闭了。可以从github上找到其代码。很多工具基于该工具二次…

【数据结构】分块查找

分块查找(也称为索引顺序查找)是一种改进的顺序查找方法,它将查找表分成若干个块,并要求块内的元素有序排序,但块与块之间不要求有序。每个块内的最大元素构成一个索引表。分块查找的过程是先查找索引,确定…

黑洞路由、 DDoS 攻击 、 环路

黑洞路由 DDoS 攻击 DDoS 攻击是一种针对服务器、服务或网络的恶意行为。DDoS 攻击通过向目标发送大量流量,使其不堪重负,导致资源和带宽被耗尽。因此,目标可能会变慢或崩溃,无法正常处理合法的流量。DDoS 攻击通常是由僵尸网络…

在龙梦迷你电脑福珑2.0上使用Fedora 28 龙梦版

在龙梦迷你电脑福珑2.0上使用Fedora 28 龙梦版。这个版本的操作系统ISO文件是:Fedora28_for_loongson_MATE_Live_7.2.iso 。它在功能方面不错。能放音乐,能看cctv直播,有声音,能录屏,能在局域网里用PuTTY的ssh方式连接…

嵌入式学习——C语言基础——day5

1. 分支结构——switch 1.1 单层switch switch (整形表达式) { case 常量1:语句块1;break; case 常量2:语句块2;break; case 常量3:语句块3;break; default: 语句块4; } 注意: 1. 表达式必须…

《苏东坡 传》一蓑烟雨任平生

《苏东坡 传》一蓑烟雨任平生 林语堂,中国现代著名作家、学者、翻译家、语言学家。 张振玉 译 文章目录 《苏东坡 传》一蓑烟雨任平生[toc]摘录小结感悟 摘录 苏东坡是个秉性难改的乐天派,是悲天悯人的道德家,是黎民百姓的好朋友,…

C语言C/S架构PACS影像归档和通信系统源码 医院PACS系统源码

C语言C/S架构PACS影像归档和通信系统源码 医院PACS系统源码 医院影像科PACS系统,意为影像归档和通信系统。它是应用在医院影像科室的系统,主要的任务是把日常产生的各种医学影像(包括核磁、CT、超声、各种X光机、各种红外仪、显微…

JAVA ASM总结篇-03

MethodVisitor ClassVisitor的visitMethod能够访问到类中某个方法的一些入口信息,那么针对具体方法中字节码的访问是由MethodVisitor来进行的 访问顺序如下,其中visitCode和visitMaxs仅调用一次,标志方法字节码访问的开始和结束 MethodVisi…

不羁联盟怎么参与测试 不羁联盟测试时间+参与测试方法分享

不羁联盟怎么参与测试 不羁联盟测试时间参与测试方法分享 《不羁联盟》是由育碧(Ubisoft)开发的一款6v6团队合作射击游戏。游戏的背景设定在一个后启示录时代的废土世界中,玩家能够身临其境地感受到废土世界的荒凉和残酷。游戏在内测时候就受…

安防视频监控/视频集中存储/云存储/磁盘阵列EasyCVR平台级联时,下级平台未发流是什么原因?

安防视频监控/视频集中存储/云存储/磁盘阵列EasyCVR平台可拓展性强、视频能力灵活、部署轻快,可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等,以及支持厂家私有协议与SDK接入,包括海康Ehome、海大宇等设备的SDK等。平台既具备传统安…

AUTOCAD输出或打印PDF文件时,如何将图形居中且布满图纸?

AUTOCAD输出或打印PDF文件时,如何将图形居中且布满图纸? 如下图所示,我们打开一份DWG格式的图纸文件,然后点击上方的“打印“图标, 如下图所示, 打印机/绘图仪这里选择“DWG To PDF“; 图纸尺寸:这里以普通的A4纸为例进行说明; 打印比例选择“布满图纸“; 打印偏移…

优维应用级数字化架构管理:让企业运维天堑变通途

在优维科技的产品视角中,数字化架构管理就像是一门精妙的艺术,它将上层应用模型的业务概念以可视化的方式呈现出来,使得业务逻辑和流程变得更加直观、清晰。我们将这样的管理方式理解为“给企业搭起一座桥梁”——在这座桥梁的搭建过程中&…

express服务器 authorization 前端获取不到的问题

服务器生成token 设置在响应头,但是前端获取不到 const token JWT.generate({ id: new Date().getTime(), userName }, 10s) res.header(Authorization, token) axios.interceptors.response.use((response) > {console.log(response);if (response.data?.co…

破解费用管理迷局,企业费用管理从不止于报销

数字化变革浪潮下,各种企业费用报销软件如雨后春笋般不断涌现,企业报销效率大幅提升,部分财务处理流程得到固化和优化,报销早已不再是企业费时费力的财务难题。那么,企业费用管里如何实现呢? 企业费用贯穿于…

ubuntu上安装调试SVN服务

刚成立团队需要临时搭建一台SVN服务器,所以对照网上的一些提示做了下,操作起来不复杂,还是踩了不少坑,顺便原理性了解了下。 主要操作步骤如下: 1:安装svn sudo apt-get install subversion 2: 创建svn版…