C#CLR,无法连接到excel文件

时间:2015-03-18 11:46:30

标签: c# sql-server excel clr oledbconnection

我尝试从CLR过程连接到xlsx文件。 我在一个简单的测试器(不是clr,只是一个控制台应用程序)中运行代码,它可以工作。 但是当我尝试运行(相同的代码)时,在SQL服务管理2008中,我收到错误:"未指定的错误"。

这是c#代码:

 [Microsoft.SqlServer.Server.SqlProcedure]
public static void GetURLandQueueByCLID(SqlString phoneNumber, SqlString isDebug, string wsURL, out SqlInt32 queue, out SqlInt32 priority, out SqlString attData)
{
 string[] parameters = new string[3] { "", "", "" };
        try
        {
            DataTable sheetData = new DataTable();

            string filePath = @"C:\Excel_route_file\ms.xlsx";
            using (OleDbConnection conn = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filePath + ";Extended Properties=Excel 12.0;HDR=YES;"))
            {
                Helper.WriteLogToDB("before open");
                conn.Open();

                OleDbDataAdapter sheetAdapter = new OleDbDataAdapter("select * from [Sheet1$] where '0575271470' = phone", conn);

                Helper.WriteLogToDB("before fill");
                sheetAdapter.Fill(sheetData);

                parameters[0] = sheetData.Rows[0].ItemArray[1].ToString();
                parameters[1] = sheetData.Rows[0].ItemArray[2].ToString();
                parameters[2] = sheetData.Rows[0].ItemArray[3].ToString();

                conn.Close();
                conn.Dispose();
            }
        }
        catch (Exception ex)
        {
            Helper.WriteLogToDB("fail to fill: " + ex.Message);
        }


        queue = SqlInt32.Parse(parameters [0]);
        priority = SqlInt32.Parse(parameters [1]);
        attData = parameters [2];
 }

它没有达到conn.Open():( 这是OleDbConnection创作中的一些东西。

创建程序:

  CREATE PROCEDURE [dbo].[proName]
  (@PHONENUMBER [nvarchar](MAX),@ISDEBUG [nvarchar](MAX),@WSURL [nvarchar] (MAX),@QUEUE INT OUTPUT ,@PRIORITY INT OUTPUT,@ATTDATA [nvarchar](MAX) OUTPUT)

  WITH EXECUTE AS CALLER
  AS

  EXTERNAL NAME [assemblyName].[StoredProcedures].[GetURLandQueueByCLID]
  GO

使用PERMISSION_SET = UNSAFE

创建ASSEMBLY

我也这样做了:

 ALTER DATABASE MyDatabase SET TRUSTWORTHY ON

和此:

 sp_configure 'clr enabled',1
 GO
 RECONFIGURE
 GO
 sp_configure 'clr enabled'  -- make sure it took
 GO

我无法让它发挥作用,帮助。

1 个答案:

答案 0 :(得分:0)

是,OleDbConnection创建中存在问题。在扩展属性的值周围添加引号。

new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filePath + ";Extended Properties='Excel 12.0;HDR=YES';")