Сведения о вопросе

Fhohir

16:03, 1st July, 2020

Теги

c#   database   loops   connection    

Как подключиться к базе данных и выполнить цикл над набором записей в C#?

Просмотров: 536   Ответов: 8

Каков самый простой способ подключения и запроса базы данных для набора записей в C#?



  Сведения об ответе

piter

18:03, 1st July, 2020

@Goyuix - это отлично подходит для чего-то написанного по памяти. проверил его здесь - обнаружил, что соединение не было открыто. В остальном очень мило.

using System.Data.OleDb;
...

using (OleDbConnection conn = new OleDbConnection())
{
    conn.ConnectionString = "Provider=sqloledb;Data Source=yourServername\\yourInstance;Initial Catalog=databaseName;Integrated Security=SSPI;";

    using (OleDbCommand cmd = new OleDbCommand())
    {
        conn.Open();
        cmd.Connection = conn;
        cmd.CommandText = "Select * from yourTable";

        using (OleDbDataReader dr = cmd.ExecuteReader())
        {
            while (dr.Read())
            {
                Console.WriteLine(dr["columnName"]);
            }
        }
    }
}


  Сведения об ответе

nYU

18:03, 1st July, 2020

Очень грубо и по памяти так как у меня нет кода на этом ноутбуке:

using (OleDBConnection conn = new OleDbConnection())
{
  conn.ConnectionString = "Whatever connection string";

  using (OleDbCommand cmd = new OleDbCommand())
  {
    cmd.Connection = conn;
    cmd.CommandText = "Select * from CoolTable";

    using (OleDbDataReader dr = cmd.ExecuteReader())
    {
      while (dr.Read())
      {
        // do something like Console.WriteLine(dr["column name"] as String);
      }
    }
  }
}


  Сведения об ответе

PROGA

18:03, 1st July, 2020

Это определенно хороший способ сделать это. Но вы, если вы случайно используете базу данных, которая поддерживает LINQ до SQL, это может быть намного веселее. Это может выглядеть примерно так:

MyDB db = new MyDB("Data Source=...");
var q = from db.MyTable
        select c;
foreach (var c in q)
  Console.WriteLine(c.MyField.ToString());


  Сведения об ответе

VCe znayu

18:03, 1st July, 2020

Это альтернативный способ (DataReader быстрее, чем этот):

string s = "";
SqlConnection conn = new SqlConnection("Server=192.168.1.1;Database=master;Connect Timeout=30;User ID=foobar;Password=raboof;");
SqlDataAdapter da = new SqlDataAdapter("SELECT TOP 5 name, dbid FROM sysdatabases", conn);
DataTable dt = new DataTable();

da.Fill(dt);

for (int i = 0; i < dt.Rows.Count; i++)
{
    s += dt.Rows[i]["name"].ToString() + " -- " + dt.Rows[i]["dbid"].ToString() + "\n";
}

MessageBox.Show(s);


  Сведения об ответе

appple

18:03, 1st July, 2020

Если вы собираетесь читать большое количество столбцов или записей, то также стоит кэшировать ординалы и обращаться к строго типизированным методам, например

using (DbDataReader dr = cmd.ExecuteReader()) {
  if (dr.Read()) {
    int idxColumnName = dr.GetOrdinal("columnName");
    int idxSomethingElse = dr.GetOrdinal("somethingElse");

    do {
      Console.WriteLine(dr.GetString(idxColumnName));
      Console.WriteLine(dr.GetInt32(idxSomethingElse));
    } while (dr.Read());
  }
}


  Сведения об ответе

прога

18:03, 1st July, 2020

При запросе базы данных сервера SQL (версия 7 и выше ) следует заменить классы OleDb соответствующими классами в пространстве имен System.Data.SqlClient ( SqlConnection , SqlCommand и SqlDataReader), поскольку эти классы были оптимизированы для работы с сервером SQL.

Кроме того, следует отметить, что вы должны 'never' выбрать все, так как это может привести к неожиданным результатам позже, если вы добавите или удалите столбцы в эту таблицу.


  Сведения об ответе

Chhiki

18:03, 1st July, 2020

Я думаю, вы можете попробовать entity framework.

using (SchoolDBEntities ctx = new SchoolDBEntities())
{
     IList<Course> courseList = ctx.GetCoursesByStudentId(1).ToList<Course>();
     //do something with courselist here
}


  Сведения об ответе

lool

18:03, 1st July, 2020

Зарядка библиотеки

using MySql.Data.MySqlClient;

Это и есть связь:

public static MySqlConnection obtenerconexion()
        {
            string server = "Server";
            string database = "Name_Database";
            string Uid = "User";
            string pwd = "Password";
            MySqlConnection conect = new MySqlConnection("server = " + server + ";" + "database =" + database + ";" + "Uid =" + Uid + ";" + "pwd=" + pwd + ";");

            try
            {
                conect.Open();
                return conect;
            }
            catch (Exception)
            {
                MessageBox.Show("Error. Ask the administrator", "An error has occurred while trying to connect to the system", MessageBoxButtons.OK, MessageBoxIcon.Error);
                return conect;
            }
        }


Ответить на вопрос

Чтобы ответить на вопрос вам нужно войти в систему или зарегистрироваться