C#调用SqlSugar操作达梦数据库报错“无效的表或视图名”

安装达梦数据库后,使用SqlSugar连接测试数据库并基于DBFirst方式创建数据库表对应的类,主要代码如下:

csharp 复制代码
SqlSugarClient db = new SqlSugarClient(new ConnectionConfig()
   {
       DbType = DbType.Dm,
       ConnectionString = "Server=localhost; User Id=SYSDBA; PWD=XXXXXXXX;DATABASE=PERSON",
       IsAutoCloseConnection = true
   });

db.DbFirst.CreateClassFile("Models", "XXXXXX.Models");

运行到CreateClassFile函数时报如下错误:

csharp 复制代码
SqlSugar.SqlSugarException
  HResult=0x80131500
  Message=Table 'ADDRESS' error,You can filter it with Db.DbFirst.Where(name=>name!="ADDRESS" ) 
 Error message:第1 行附近出现错误:
无效的表或视图名[ADDRESS]
  Source=SqlSugar
  StackTrace:
   at SqlSugar.Check.Exception(Boolean isException, String message, String[] args)
   at SqlSugar.DbFirstProvider.ToClassStringList(String nameSpace)
   at SqlSugar.DbFirstProvider.CreateClassFile(String directoryPath, String nameSpace)
   at TestDM.Program.Main(String[] args) in \TestDM\Program.cs:line 18

通过达梦管理工具查看数据库,PERSON数据库下有ADDRESS表,不清楚为什么报错。

百度错误信息,检索结果中介绍可能是表名前需添加模式名,如访问ADDRESS表的话,应使用PERSON.ADDRESS,于是在参考文献1中查看如何设置模式名,找到如下说明:

于是在代码的连接字符串中增加SCHEMA,并赋值为模式名,同时在DbFirst函数后增加表筛选函数,最终代码如下所示,此时即可正常创建PERSON模式下的表对象类文件。

csharp 复制代码
SqlSugarClient db = new SqlSugarClient(new ConnectionConfig()
   {
       DbType = DbType.Dm,
       ConnectionString = "Server=localhost; User Id=SYSDBA; PWD=XXXXXXXX;SCHEMA=PERSON;DATABASE=PERSON",
       IsAutoCloseConnection = true
   });

db.DbFirst.Where(name=>name.StartsWith("ADDRESS")||name.StartsWith("PERSON")).CreateClassFile("Models", "XXXXXXXX.Models");

参考文献:

1\]https://www.donet5.com/Home/Doc?typeId=1229 \[2\]https://eco.dameng.com/document/dm/zh-cn/app-dev/dot-Net-Data-Provider.html

相关推荐
hixiong1237 小时前
C# OpenCVSharp使用 读光-票证检测矫正模型
人工智能·opencv·c#
霜绛7 小时前
C#知识补充(二)——命名空间、泛型、委托和事件
开发语言·学习·unity·c#
好望角雾眠7 小时前
第四阶段C#通讯开发-6:Socket之UDP
开发语言·笔记·学习·udp·c#
霜绛8 小时前
C#知识补充(一)——ref和out、成员属性、万物之父和装箱拆箱、抽象类和抽象方法、接口
开发语言·笔记·学习·c#
爱编程的鱼9 小时前
C# var 关键字详解:从入门到精通
开发语言·c#·solr
玩泥巴的10 小时前
解放双手!使用Roslyn生成代码让你的 HTTP 客户端开发变得如此简单
c#·.net·代码生成·roslyn
星释11 小时前
Rust 练习册 :Pig Latin与语言游戏
游戏·rust·c#
蒲公英源码12 小时前
超市进销存源码
sqlserver·c#·.net
星光一影17 小时前
PDF工具箱/合并拆分pdf/提取图片
pdf·c#
baivfhpwxf202318 小时前
要在 WPF 中实现数据表对应实体的属性与 UI 控件的双向绑定,并支持修改通知和 UI 自动更新
c#·wpf