powered by simpleCommunicator - 2.0.49     © 2025 Programmizd 02
Форумы / ADO.NET, LINQ, Entity Framework, NHibernate, DAL, ORM [игнор отключен] [закрыт для гостей] / Ошибка: System.StackOverflowException
8 сообщений из 8, страница 1 из 1
Ошибка: System.StackOverflowException
    #39316895
son456
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Здравствуйте! Столкнулся с проблемой, при обращении к классу DataAccessLayer выдает ошибку System.StackOverflowException
Сам класс:
Код: c#
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.OleDb;
using System.Data;
using System.Collections;
using System.IO;

namespace View_DBF_File.DAL
{
    public class DataAccessLayer
    {
        #region Properties
        private string ConnectionString
        {
            get
            {
                return View_DBF_File.Properties.Settings.Default.DBFConnStr;
            }
        }
        private OleDbConnection DBF_Connection
        {
            get
            {
                if (this.dbfConnection == null)
                {
                    this.dbfConnection = new OleDbConnection(this.ConnectionString);
                }
                return this.dbfConnection;
            }
        }
        
        #endregion

        #region Fields
        private OleDbConnection dbfConnection;
        private OleDbDataAdapter tableAdapter;   
        //private DataTable all_DBF_File;
        #endregion


        private OleDbDataAdapter DBF_Table
        {
            get
            {
                if (this.tableAdapter == null)
                {
                    this.tableAdapter = new OleDbDataAdapter();

                    OleDbCommand dbfCommand = new OleDbCommand();
                    dbfCommand.CommandText = " select * from @tableName";
                    dbfCommand.CommandType = CommandType.Text;
                    dbfCommand.Connection = this.DBF_Connection;

                    OleDbParameter mySqlParameter =
                        new OleDbParameter("@tableName", OleDbType.VarChar, 0);
                    //MySqlParameter.Direction = ParameterDirection.Input;

                    this.tableAdapter.SelectCommand = dbfCommand;
                }
                return this.tableAdapter;
            }
        }

        public DataTable GetDBF_Table(string tableName)
        {
            this.DBF_Table.SelectCommand.Parameters["@tableName"].Value = tableName;

            try
            {
                DataTable classes = new DataTable("Table");
                this.DBF_Table.Fill(classes);
                return classes;
            }
            catch
            {
                return null;
            }
        }
    }
}


Сама форма:
Код: c#
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using View_DBF_File.DAL;
using System.Collections;
using System.IO;

namespace View_DBF_File
{
    public partial class MainForm : Form
    {
        
        
        public MainForm()
        {
            InitializeComponent();
        }
        public DataAccessLayer DataAccessLayer
        {
            get
            {
                if (this.DataAccessLayer == null)
                {
                    this.m_dataAccessLayer = new DataAccessLayer();
                }
                return this.m_dataAccessLayer;
            }
        }
        private DataAccessLayer m_dataAccessLayer;
        public DataTable DBF_Table
        {
            get
            {
                return this.DataAccessLayer.GetDBF_Table(Path.GetFileName(cb_Files.Text.Trim()));
            }
        }
        private void bt_Review_Click(object sender, EventArgs e)
        {
            this.dgv_Review.DataSource = this.DBF_Table;
            
        }

        private void cb_Files_Click(object sender, EventArgs e)
        {
           
            cb_Files.Items.Clear();
            foreach (string File in Directory.GetFiles("D:\\KVPLATA\\BAZA6"))
            {
                cb_Files.Items.Add(Path.GetFileName(File));
            }
        }
    }
}
...
Рейтинг: 0 / 0
Ошибка: System.StackOverflowException
    #39317053
Monochromatique
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
son456
public DataAccessLayer DataAccessLayer
{
get
{
if (this. m_dataAccessLayer == null)
{
this.m_dataAccessLayer = new DataAccessLayer();
}
return this.m_dataAccessLayer;
}
}
...
Рейтинг: 0 / 0
Ошибка: System.StackOverflowException
    #39317091
son456
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Так где здесь ошибка?
...
Рейтинг: 0 / 0
Ошибка: System.StackOverflowException
    #39317095
oaken
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
son456Так где здесь ошибка?выделено жирным как должно быть
...
Рейтинг: 0 / 0
Ошибка: System.StackOverflowException
    #39317096
Monochromatique
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
son456Так где здесь ошибка?

Страуструп, перелогинься.

Я исправил ТВОЙ код.
...
Рейтинг: 0 / 0
Ошибка: System.StackOverflowException
    #39317109
son456
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Теперь пишет OleDbParameter с ParameterName "@tableName" не содержится в данном OleDbParameterCollection.
...
Рейтинг: 0 / 0
Ошибка: System.StackOverflowException
    #39317124
Monochromatique
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
son456Теперь пишет OleDbParameter с ParameterName "@tableName" не содержится в данном OleDbParameterCollection.

Держи нас в курсе
...
Рейтинг: 0 / 0
Ошибка: System.StackOverflowException
    #39317142
son456
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Большое, спасибо за исправленную предыдущую ошибку, не могли бы вы подсказать ответ на следующую.
...
Рейтинг: 0 / 0
8 сообщений из 8, страница 1 из 1
Форумы / ADO.NET, LINQ, Entity Framework, NHibernate, DAL, ORM [игнор отключен] [закрыт для гостей] / Ошибка: System.StackOverflowException
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]