3

我正在学习 C#/ASP.NET,我想知道以下 PHP 代码的 C# 等价物是什么?我知道用户 ID,我想从这个表中获取行到变量“row”的数组中,所以我可以将它用作“row['name']”和“row['email']。

$result = mysql_query("SELECT email, name FROM mytable WHERE id=7");

while ($row = mysql_fetch_array($result, MYSQL_ASSOC)) {
    printf("Email: %s  Name: %s", $row["email"], $row["name"]);
}

谢谢。

4

5 回答 5

5

我不确定这是否相同,mysql_fetch_array但我假设。您可以使用IDBCommmand.ExecuteReader创建一个IDataReader并使用它来填充Object[]行的所有字段。

例如(使用 SQL-Server):

// use using statements to ensure that connections are disposed/closed (all implementing IDisposable)
using (var con = new SqlConnection(Properties.Settings.Default.ConnectionString))
using (var cmd = new SqlCommand("SELECT email, name FROM mytable WHERE id=@id", con))
{
    cmd.Parameters.AddWithValue("@id", ID);  // use parameters to avoid sql-injection
    con.Open();
    using (var reader = cmd.ExecuteReader())
    {
        while (reader.Read())
        { 
            var fields = new object[reader.FieldCount];
            // following fills an object[] with all fields of the current line, 
            // is this similar to mysql_fetch_array?
            int count  = reader.GetValues(fields);
        }
    }
}

编辑

我并不是要让它尽可能相似,但是我将如何在 C# 中获得相同的最终结果(带有结果的变量)

那是口味问题。您可以使用某种 ORM,例如 Enity-Framework、NHibernate、LINQ-To-SQL 或 Stackoverflow 的 Micro-ORM Dapper.NET(我目前正在使用的)或普通的 ADO.NET(如上所示)。

您可以使用您手动填充的自定义类,DataReader或者使用DataTable自动加载的模式。

例如(这里使用 MySQL):

DataTable tblEmail = new DataTable();
using (var con = new MySqlConnection(Properties.Settings.Default.MySQL))
using (var da = new MySqlDataAdapter("SELECT Email, Name FROM Email WHERE id=@id", con))
{
    da.SelectCommand.Parameters.AddWithValue("@id", ID);
    da.Fill(tblEmail);
}

if (tblEmail.Rows.Count == 1)
{
    DataRow row  = tblEmail.Rows[0];
    String email = row.Field<String>("Email");
    String name  = row.Field<String>("Name");
}

如您所见,.NET 中有很多方法。我只用 ADO.NET 展示了两个。

于 2012-06-30T20:00:13.697 回答
2

没有真正的等价物。作为过去的 PHP 开发人员,我想说最接近的事情是使用数据适配器并填充数据表。这是对DbDataAdapter.Fill的引用。

我不确定 MySql 驱动程序,但如果您使用的是 Sql Server,这里有一些代码可以帮助您入门:

using (var connection = new SqlConnection(connectionString))
{
    var table = new DataTable("tbl_objects");
    var adapter = new SqlDataAdapter();
    adapter.SelectCommand = new SqlCommand("SELECT * FROM tbl_name", connection);
    adapter.Fill(table);
}

然后,您可以遍历表中的行:

foreach(var row in table)
{
    Console.WriteLine("{0}", row["ColumnName"]);
}
于 2012-06-30T20:15:56.137 回答
0

您需要连接到数据库。

假设您使用的是 mysql 和 odbc 连接。

var connectionString = "DRIVER={MySQL ODBC 3.51 Driver};" +
                     "SERVER=localhost;" +
                     "DATABASE=test;" +
                     "UID=venu;" +
                     "PASSWORD=venu;" +
                     "OPTION=3");


using (OdbcConnection connection = new OdbcConnection(connectionString))
{
    OdbcCommand command = new OdbcCommand("SELECT email, name FROM mytable WHERE id=7", connection);

    connection.Open();

    // Execute the DataReader and access the data.
    OdbcDataReader reader = command.ExecuteReader();
    while (reader.Read())
    {
        //do stuff with the data here row by row the reader is a cursor
    }

    // Call Close when done reading.
    reader.Close();

或者,您可以使用 odbcdataadapter 和数据表,如果您希望将所有结果放在可以像数组一样使用的表中。

于 2012-06-30T20:04:50.763 回答
0

您可以使用 foreach 循环遍历结果,如下所示:

  foreach(var row in result)
  { 
      console.writeline("Email:" + row.Email, "Name:", row.Name);
  }

那是你要找的那种东西吗?

编辑

事实上,我刚刚看到你只有一个结果。

然后你可以完全跳过 foreach 循环

于 2012-06-30T19:38:40.960 回答
0

.net 中最接近的等价物是这样的......

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using MySql.Data.MySqlClient;

namespace ConsoleApplication5
{
    class Program
    {
        static void Main(string[] args)
        {
            var foo = MySqlHelper.ExecuteDataRow("Server=myServerAddress;Database=myDataBase;Uid=myUsername;Pwd=myPassword;", "select * from foo");
            Console.WriteLine(foo["Column"]);
        }
    }
}

我假设您使用的是 MySql 数据连接器http://dev.mysql.com/downloads/connector/net/

请注意.net 中有更好的方法可以连接到数据库,但我认为逐行来说,这与 PHP 一样接近。

于 2012-06-30T21:39:45.633 回答