Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(下)

简介: 本文接续前文,深入讲解了在Windows环境下使用C#和ADO.NET操作南大通用GBase 8s数据库的方法。通过Visual Studio 2022创建项目,添加GBase 8s的DLL引用,并提供了详细的C#代码示例,涵盖数据库连接、表的创建与修改、数据的增删查改等操作,旨在帮助开发者提高数据库管理效率。

在上一篇文章中,我们介绍了如何在Windows环境下安装CSDK及连接配置,并执行基本的数据库操作。本文将进一步介绍C#操作数据库的操作及C#代码示例,帮助您更高效地管理和操作数据库。

查看上篇链接:Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)

C#操作数据库
这里我使用的是 Visual Studio 2022 社区版开发工具。

1、创建并配置新项目
打开Visual Studio 2022,创建新项目,选择控制台应用(.NET Framework),点击下一步。

使用.NET Framework 4.8,创建控制台应用程序,指定项目名称为 ConsoleApp1,位置等。

2、添加GBS.Data.GBasedbt.dll引用
在解决方案管理器上的引用中,右键添加引用,浏览并增加 GBS.Data.GBasedbt.dll文件。

示例中的路径为:

C:\Program Files\GBase Client-SDK\bin\netf40\GBS.Data.GBasedbt.dll

3、C#代码示例
using System;
using GBS.Data.GBasedbt;
using System.Data;

namespace ConsoleApp1
{
internal class Program
{
static void Main()
{
var constr = "database=testdb1;server=yangzai;host=192.168.137.66;service=6666;protocol=onsoctcp;uid=gbasedbt;pwd=111111;DB_LOCALE=zh_CN.utf8;CLIENT_LOCALE=zh_CN.utf8";
var conres = logon(constr);

        if (conres != null)  
        {  
            execute_database(conres);  
            logoff(conres);  
        }            
    }  

    static IfxConnection logon(string constr)  
    {  
        var conn = new IfxConnection(constr);  
        try  
        {  
            conn.Open();  
            Console.WriteLine("数据库连接成功!\n");  
            return conn;  
        }  
        catch (Exception ex)  
        {  
            Console.WriteLine("数据库连接失败!" + ex.Message);  
            return null;  
        }  
    }  

    static void execute_database(IfxConnection conn)  
    {       
        IfxCommand ifxcmd = conn.CreateCommand();  
        ifxcmd.CommandText = "drop table if exists student";  
        ifxcmd.ExecuteNonQuery();  

       ifxcmd.CommandText = "create table student(num int,name varchar(100),class varchar(255))";  
        ifxcmd.ExecuteNonQuery();  

       ifxcmd.CommandText = "insert into student values (1001,'小张','计算机科学与技术3班')";  
        ifxcmd.ExecuteNonQuery();  

        ifxcmd.CommandText = "insert into student values (1002,'小明','电子信息工程1班')";  
        ifxcmd.ExecuteNonQuery();  

        ifxcmd.CommandText = "insert into student values (1003,'小李','土木工程4班')";  
        ifxcmd.ExecuteNonQuery();  

ifxcmd.CommandText = "update student set class = '新闻传播专业2班' where num = 1001";  
        ifxcmd.ExecuteNonQuery();  

        ifxcmd.CommandText = "delete student where num = 1003";  
        ifxcmd.ExecuteNonQuery();  

        ifxcmd.CommandText = "select dbinfo('version','full') from dual";  
        IfxDataReader dr = ifxcmd.ExecuteReader();  

        if (dr.Read())  
        {  
          Console.WriteLine("当前数据库版本号为:" + dr[0] + '\n');  
        }  

        IfxDataAdapter ifxadpt = new IfxDataAdapter("select * from student", conn);  
        DataSet ds = new DataSet();  
        ifxadpt.Fill(ds);  
        Console.WriteLine("student表查询结果如下:\n");  
        int i = 0;  
        for (i = 0; i < ds.Tables.Count; i++)  
        {  
            var tb1 = ds.Tables[i];  
            var count = tb1.Rows.Count;  

            for (int r = 0; r < tb1.Rows.Count; r++)  
            {  
                for (int c = 0; c < tb1.Columns.Count; c++)  
                {  
                    var colname = tb1.Columns[c].ColumnName;  
                    var value = tb1.Rows[r].ItemArray[c];  
                    Console.WriteLine(colname + " " + value);  
                }  
                Console.Write("\n");  
            }  
            Console.WriteLine(count + " row(s) retrieved.\n");  
        }  
    }  

    static void logoff(IfxConnection conn)  
    {  
        try  
        {  
            conn.Close();  
            Console.WriteLine("数据库连接断开成功!\n");  
        }  
        catch (Exception ex)  
        {  
            Console.WriteLine("数据库连接断开失败:" + ex.Message);  
        }  
    }  
}  

}
4、程序运行结果
将上面示例代码复制到Program.cs中,执行Debug测试连接到数据库结果。

通过本系列文章的探讨,您应该对使用C#通过ADO.NET操作GBase 8s数据库有了更全面的理解。掌握这些技巧将使您能够构建更高效、更可靠的数据库应用。感谢您的阅读。

附录
GBase 8s数据库文档:官方文档

ADO.NET编程指南:Microsoft Docs

相关文章
|
1天前
|
开发框架 搜索推荐 算法
一个包含了 50+ C#/.NET编程技巧实战练习教程
一个包含了 50+ C#/.NET编程技巧实战练习教程
47 18
|
1天前
|
缓存 算法 安全
精选10款C#/.NET开发必备类库(含使用教程),工作效率提升利器!
精选10款C#/.NET开发必备类库(含使用教程),工作效率提升利器!
26 12
|
14天前
|
开发框架 监控 .NET
C#进阶-ASP.NET WebForms调用ASMX的WebService接口
通过本文的介绍,希望您能深入理解并掌握ASP.NET WebForms中调用ASMX WebService接口的方法和技巧,并在实际项目中灵活运用这些技术,提高开发效率和应用性能。
31 5
|
22天前
|
算法 Java 测试技术
Benchmark.NET:让 C# 测试程序性能变得既酷又简单
Benchmark.NET是一款专为 .NET 平台设计的性能基准测试框架,它可以帮助你测量代码的执行时间、内存使用情况等性能指标。它就像是你代码的 "健身教练",帮助你找到瓶颈,优化性能,让你的应用跑得更快、更稳!希望这个小教程能让你在追求高性能的路上越走越远,享受编程带来的无限乐趣!
75 13
|
1月前
|
数据库连接 数据库 C#
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
|
7月前
|
开发框架 前端开发 .NET
C#编程与Web开发
【4月更文挑战第21天】本文探讨了C#在Web开发中的应用,包括使用ASP.NET框架、MVC模式、Web API和Entity Framework。C#作为.NET框架的主要语言,结合这些工具,能创建动态、高效的Web应用。实际案例涉及企业级应用、电子商务和社交媒体平台。尽管面临竞争和挑战,但C#在Web开发领域的前景将持续拓展。
220 3
|
1月前
|
C# 开发者
C# 一分钟浅谈:Code Contracts 与契约编程
【10月更文挑战第26天】本文介绍了 C# 中的 Code Contracts,这是一个强大的工具,用于通过契约编程增强代码的健壮性和可维护性。文章从基本概念入手,详细讲解了前置条件、后置条件和对象不变量的使用方法,并通过具体代码示例进行了说明。同时,文章还探讨了常见的问题和易错点,如忘记启用静态检查、过度依赖契约和性能影响,并提供了相应的解决建议。希望读者能通过本文更好地理解和应用 Code Contracts。
40 3
|
8天前
|
存储 安全 编译器
学懂C#编程:属性(Property)的概念定义及使用详解
通过深入理解和使用C#的属性,可以编写更清晰、简洁和高效的代码,为开发高质量的应用程序奠定基础。
46 12
|
1月前
|
设计模式 C# 图形学
Unity 游戏引擎 C# 编程:一分钟浅谈
本文介绍了在 Unity 游戏开发中使用 C# 的基础知识和常见问题。从 `MonoBehavior` 类的基础用法,到变量和属性的管理,再到空引用异常、资源管理和性能优化等常见问题的解决方法。文章还探讨了单例模式、事件系统和数据持久化等高级话题,旨在帮助开发者避免常见错误,提升游戏开发效率。
58 4
|
3月前
|
API C#
C# 一分钟浅谈:文件系统编程
在软件开发中,文件系统操作至关重要。本文将带你快速掌握C#中文件系统编程的基础知识,涵盖基本概念、常见问题及解决方法。文章详细介绍了`System.IO`命名空间下的关键类库,并通过示例代码展示了路径处理、异常处理、并发访问等技巧,还提供了异步API和流压缩等高级技巧,帮助你写出更健壮的代码。
54 2