繁体   English   中英

并非所有变量都绑定 Oracle REST Web ZDB974238714CA8DE634A7CE1D08

[英]Not all Variables Bound Oracle REST Web API

我得到并非所有变量都绑定。

这是我的代码的样子。

public IEnumerable<VaultService> Get(string Branch_Desg)
{
    OracleConnection con = new OracleConnection(constr);
    con.Open();
    DataTable dt = new DataTable();
    //string sql = "select * from wemadummyvaulttable where branch_desg = " + Branch_Desg + "";
    string sql = "select BRANCH_ID ,BRANCH_NAME ,BRANCHID_NUMBER ,BRANCH_ACCOUNTNO ,BRANCH_DESG ,CURRENCY ,BRANCH_BALANCE from wemadummyvaulttable where Branch_Desg =" + ":Branch_Desg";

  OracleDataAdapter da = new OracleDataAdapter(sql, con);
    da.Fill(dt);
    List<VaultService> vr = new List<Models.VaultService>(dt.Rows.Count);
    if (dt.Rows.Count > 0)
    {
        foreach (DataRow vaultrecord in dt.Rows)
        {
            vr.Add(new ReadVaultBal(vaultrecord));
        }
    }
    return vr;
}

出于某种原因,它不像它应该的那样工作。

屏幕截图如下所示:

在此处输入图像描述

现在我更新的代码如下所示:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Web.Http;
using WEMAVaultREST.Models;
using Oracle.ManagedDataAccess.Client;
using Oracle.ManagedDataAccess.Types;
using System.Data;

namespace WEMAVaultREST.Controllers
{
    public class VaultServiceController : ApiController
    {
        string constr = "User ID=system; Password=admin1234; Data Source=SAM;";
        // GET api/<controller>
        public IEnumerable<string> Get()
        {
            return new string[] { "value1", "value2" };
        }

        // GET api/<controller>/5
        public string Get(int id)
        {
            return "value";
        }

        // GET api/<controller>/5
        /* public VaultService Get(string Branch_Desg)
         {
             OracleConnection con = new OracleConnection(constr);
             con.Open();
             DataTable dt = new DataTable();

             string sql = "select * from wemadummyvaulttable where branch_desg = '"+Branch_Desg+"'";
             OracleDataAdapter da = new OracleDataAdapter(sql,con);
             da.Fill(dt);
             if (dt.Rows.Count > 0)
             {
                 return new ReadVaultBal(dt.Rows[0]);
             }
             throw new Exception("Account not found");
         }*/

        public IEnumerable<VaultService> Get(string Branch_Desg)
        {
            OracleConnection con = new OracleConnection(constr);
            con.Open();
            DataTable dt = new DataTable();
            //string sql = "select * from wemadummyvaulttable where branch_desg = " + Branch_Desg + "";
            string sql = "select BRANCH_ID ,BRANCH_NAME ,BRANCHID_NUMBER ,BRANCH_ACCOUNTNO ,BRANCH_DESG ,CURRENCY ,BRANCH_BALANCE from wemadummyvaulttable where Branch_Desg =" + ":Branch_Desg";

            var command = new OracleCommand(sql, con);
            command.Parameters.Add("Branch_Desg", Branch_Desg);
            OracleDataAdapter da = new OracleDataAdapter(command);
            da.Fill(dt);
            List<VaultService> vr = new List<Models.VaultService>(dt.Rows.Count);
            if (dt.Rows.Count > 0)
            {
                foreach (DataRow vaultrecord in dt.Rows)
                {
                    vr.Add(new ReadVaultBal(vaultrecord));
                }
            }
            return vr;
        }


        // POST api/<controller>
        public void Post([FromBody]string value)
        {
        }

        // PUT api/<controller>/5
        public void Put(int id, [FromBody]string value)
        {
        }

        // DELETE api/<controller>/5
        public void Delete(int id)
        {
        }
    }
}

这就是我现在所拥有的。 如您所见,它在 Sqldeveloper 中返回。在代码中,它没有。 我不知道从这里到 Go 的内容和位置。

如果我像这样运行 REST api:

http://localhost:7177/api/VaultService?Branch_Desg=Branch01

它返回这个

在此处输入图像描述

换线试试

  OracleDataAdapter da = new OracleDataAdapter(sql, con);

    var command = new OracleCommand(sql, con);
    command.Parameters.Add("Branch_Desg", branchDesg);
    OracleDataAdapter da = new OracleDataAdapter(command);

似乎没有办法将绑定参数直接添加到OracleDataAdapter ,因此我们必须首先从 SQL 字符串创建一个OracleCommand ,为参数添加一个值:Branch_Desg ,然后从该命令创建适配器。

最后,我能否推荐所有 Oracle 资源(连接、命令和数据适配器)通过using块创建它们来正确处理,例如

using (OracleConnection con = new OracleConnection(constr))
{
    // code using the database connection 'con'
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM