C # data.fill (ошибка преобразования) - PullRequest
1 голос
/ 14 марта 2012

Использование C #, .NET 4, SQL, Visual Studio 2010 и SQL Server Manager 2008.

Привет, ребята. Похоже на тот же самый старый вопрос, который легко решить 101, но что-то меня беспокоит.

Моя программа выполняет запрос, захватывает данные и заполняет набор данных.

Одно из моих полей называется pg (группа продуктов) и имеет значение nvarchar (255). большинство pgs - это числа типа 30, 50, 12 и т. д., но есть исключения из этого, такие как T1B и 50a.

По какой-то причине я получаю ошибку преобразования.

"Преобразование не удалось при преобразовании значения varchar 'T1B' в int".

В моем коде все, что я использую, это data.fill ();

Это я или кажется, что data.fill пытается присвоить полю PG целое число, потому что первые извлекаемые им записи выглядят как int? Честно говоря, я всегда думал, что заполнение будет имитировать, независимо от того, какие типы данных sql были эквивалентны.

Надеюсь, это что-то легкое, что я пропускаю.

Если вы хотите увидеть больше кода, дайте мне знать, и я отредактирую этот пост.

Большое спасибо

SQL-запрос

USE [ShaftData]
GO
/****** Object:  StoredProcedure [dbo].[GetSalesParetotemp]    Script Date: 03/14/2012       09:30:13 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER PROCEDURE [dbo].[GetSalesParetotemp] 
@acct varchar(255), 
@From date, 
@Too date
AS
SELECT i.Acct,
   i.Name, 
   i.Document, 
   i.Part, 
   i.Qty, 
   i.Unit, 
   dbo.NEWPareto.Pareto, 
   i.pg,
   dbo.MyPgTable.PgName,
   i.[DateTime]

FROM   
OPENQUERY(SACBAUTO, 'SELECT dbo.iHeads.acct,
                            dbo.iHeads.name,
                            dbo.iLines.Document,
                            dbo.iLines.Part,
                            dbo.iLines.Pg,
                            dbo.iLines.Qty,
                            dbo.iLines.unit,
                            dbo.iHeads.[DateTime]  
                     FROM Autopart.dbo.iheads INNER JOIN     Autopart.dbo.iLines ON 
                     Autopart.dbo.Iheads.document =   autopart.dbo.iLines.document
                     GROUP By dbo.iHeads.acct,
                            dbo.iHeads.name,
                            dbo.iLines.Document,
                            dbo.iLines.Part,
                            dbo.iLines.Pg,
                            dbo.iLines.Qty,
                            dbo.iLines.unit,
                            dbo.iHeads.[DateTime]
                      ') i
left JOIN
  dbo.NEWPareto
ON 
i.Part collate SQL_Latin1_General_CP1_CI_AS = dbo.NEWPareto.Part 
left JOIN
dbo.MyPgTable 
ON  
  i.pg collate SQL_Latin1_General_CP1_CI_AS = dbo.MyPgTable.[pGroup]

WHERE
 (i.[DateTime] BETWEEN @From AND @Too) AND
 i.Acct = @acct 
 AND i.pg != 60
 AND i.pg != 61
 AND i.pg != 62

 GROUP BY i.Acct,
   i.Name, 
   i.Document, 
   i.Part, 
   i.Qty, 
   i.Unit, 
   dbo.NEWPareto.Pareto, 
   i.pg,
   dbo.MyPgTable.PgName, 
   i.[DateTime]

А вот метод, который вызывает его

try
        {
            string myConn = "Server=derp;" +
                            "Database=derp;" +
                            "uid=derp;" +
                            "pwd=derp;" +
                            "Connect Timeout=120;";

            string acct;// test using 1560

            SqlConnection conn = new SqlConnection(myConn);
            SqlCommand Pareto = new SqlCommand();
            BindingSource bindme = new BindingSource();
            SqlDataAdapter adapt1 = new SqlDataAdapter(Pareto);
            DataSet dataSet1 = new DataSet();
            DataTable table1 = new DataTable();

            acct = Acct;

            string fromDate = this.dateTimePicker1.Value.ToString("MM/dd/yyyy");
            string tooDate = this.dateTimePicker2.Value.ToString("MM/dd/yyyy");

            Pareto.Connection = conn;
            Pareto.CommandType = CommandType.StoredProcedure;
            Pareto.CommandText = "dbo.GetSalesParetotemp";
            Pareto.CommandTimeout = 120;

            Pareto.Parameters.AddWithValue("@acct", acct);
            Pareto.Parameters.AddWithValue("@from", fromDate);
            Pareto.Parameters.AddWithValue("@too", tooDate);

            SetCheckBoxValue(true);
            SetPictureBoxVisibility(true);
            //label1.Visible = true;
            adapt1.Fill(dataSet1, "Pareto");
            //label1.Visible = false;
            SetCheckBoxValue(false);
            SetPictureBoxVisibility(false);

            SetDataGrid(true, dataSet1, "Pareto", DataGridViewAutoSizeColumnsMode.AllCells);

            dataGridView1.AutoResizeColumns(
                DataGridViewAutoSizeColumnsMode.AllCells);
        }
        catch (Exception execc)
        {
            MessageBox.Show("Whoops! Seems we couldnt connect to the server!"
                            + " information:\n\n" + execc.Message + execc.StackTrace,
                            "Fatal Error", MessageBoxButtons.OK, MessageBoxIcon.Stop);
        }

1 Ответ

2 голосов
/ 14 марта 2012

Я полагаю, что это ошибка SQL, вызванная самим запросом, потому что он упоминает «varchar», и если бы это была проблема .Net, он бы сказал «строка».

В частности:

WHERE 
 (i.[DateTime] BETWEEN @From AND @Too) AND 
 i.Acct = @acct  
 AND i.pg != 60 
 AND i.pg != 61 
 AND i.pg != 62 

Это предложение разрывается, когда встречается одна из строк с нечисловым значением pg

Вы можете просто изменить их на строки - то есть '60', '61' и '62'

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...