通过EFCore调用GBase8s数据库存储过程

本文介绍了如何在C#中利用EFCore调用GBase8s数据库的存储过程,包括有两个入参和两个返回值、一个出参以及两个出参的存储过程示例,详细展示了存储过程的创建、执行及结果验证。
摘要由CSDN通过智能技术生成

前置阅读文章
《EFCore使用ADO.NET连接GBase8s数据库示例》
《C#连接GBase8s数据库在windows环境下使用步骤》
创建解决方案Demo工程,并引入相应的EFCore包
在这里插入图片描述

我们首先创建名字为test的数据库,并创建使用到的数据表和存储过程。
示例1: 有两个入参和两个返回值的存储过程
CREATE TABLE test:company (
id INTEGER,
branck VARCHAR(100),
address VARCHAR(100),
city VARCHAR(100),
phone VARCHAR(100)
)

create procedure testselect (id int,city varchar(100)) returning varchar(100),varchar(100)
begin
define v_in int;
define v_in2 VARCHAR(100);
let v_in = id+1;
let v_in2 = “Hello GBase8s”;
insert into company values (id,‘1’,‘2’,city,‘3’);
return 'value: ’ || v_in,v_in2 ;
end
end procedure;

在这里插入图片描述

控制台输出结果,与预期一致&#x

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个使用Oracle.ManagedDataAccess批量插入数据的完整例子: ```csharp using Oracle.ManagedDataAccess.Client; using System; using System.Collections.Generic; using System.Data; using System.Linq; namespace OracleBulkInsertExample { class Program { static void Main(string[] args) { string connectionString = "Data Source=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=localhost)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=XE)));User Id=hr;Password=hr;"; // 构建数据表和数据集 DataTable employeesTable = new DataTable(); employeesTable.Columns.Add("ID", typeof(int)); employeesTable.Columns.Add("NAME", typeof(string)); employeesTable.Columns.Add("AGE", typeof(int)); employeesTable.Columns.Add("SALARY", typeof(double)); employeesTable.Rows.Add(1, "John Smith", 35, 5000.50); employeesTable.Rows.Add(2, "Mary Johnson", 28, 4000.75); employeesTable.Rows.Add(3, "Peter Lee", 42, 7000.25); employeesTable.Rows.Add(4, "Kim Chen", 31, 5500.00); DataSet employeesDataSet = new DataSet(); employeesDataSet.Tables.Add(employeesTable); // 使用批量插入将数据插入到数据库中 using (OracleConnection connection = new OracleConnection(connectionString)) { connection.Open(); OracleCommand command = new OracleCommand("INSERT INTO EMPLOYEES(ID, NAME, AGE, SALARY) VALUES(:ID, :NAME, :AGE, :SALARY)", connection); command.ArrayBindCount = employeesTable.Rows.Count; command.Parameters.Add(":ID", OracleDbType.Int32, employeesTable.AsEnumerable().Select(r => r.Field<int>("ID")).ToArray(), ParameterDirection.Input); command.Parameters.Add(":NAME", OracleDbType.Varchar2, employeesTable.AsEnumerable().Select(r => r.Field<string>("NAME")).ToArray(), ParameterDirection.Input); command.Parameters.Add(":AGE", OracleDbType.Int32, employeesTable.AsEnumerable().Select(r => r.Field<int>("AGE")).ToArray(), ParameterDirection.Input); command.Parameters.Add(":SALARY", OracleDbType.Double, employeesTable.AsEnumerable().Select(r => r.Field<double>("SALARY")).ToArray(), ParameterDirection.Input); int rowsAffected = command.ExecuteNonQuery(); Console.WriteLine($"{rowsAffected} rows inserted."); } Console.ReadLine(); } } } ``` 在上面的例子中,我们首先创建了一个包含员工信息的数据表和数据集。然后,我们使用Oracle.ManagedDataAccess客户端连接到Oracle数据库,并使用批量插入将数据插入到数据库中。 请注意,我们使用OracleCommand的ArrayBindCount属性指定要插入的行数,然后使用参数化查询和数组绑定技术将数据传递给INSERT语句。 最后,我们输出插入的行数,然后关闭数据库连接。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值