首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C# postgres数据库连接

C# postgres数据库连接
EN

Stack Overflow用户
提问于 2012-08-08 07:19:00
回答 1查看 1.4K关注 0票数 0

我已经成功地连接到数据库,但是我使用了下面的代码来连接。

代码语言:javascript
复制
static void Main(string[] args)
{
    using (NpgsqlConnection conn= new NpgsqlConnection(
        "Host=xxx.xx.xx.xxx;Port=5432;User Id=Admin;Password=postgres.1;Database=Test1;")) 
    {
        conn.Open();

        NpgsqlCommand cmd = new NpgsqlCommand("SELECT * FROM TABLE1", conn);

        try
        {
            NpgsqlDataReader dr = cmd.ExecuteReader();
            while (dr.Read())
            {
                for (int i = 0; i < dr.FieldCount; i++)
                {
                    Console.Write("{0} \t", dr[i]);
                }
                Console.WriteLine();
            }
            dr.Close();
        }
        finally
        {
            conn.Close();
        }
    }

    Console.ReadLine();
}

显然,我必须以某种方式为数据库中的表生成类,并使用这些类进行连接,而不是使用NpgsqlCommand cmd = new NpgsqlCommand("SELECT * FROM TABLE1", conn);。已经尝试使用DbLinq的DbMetal,但是我得到了错误消息:

DbMetal :服务器已关闭连接。

我一直在研究这个,但我没有发现任何有用的东西。

如果可以的话请帮忙。有点急事。

提前谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-08-08 07:25:56

我想你需要一个NpgsqlDataAdapter和一个DataSet

代码语言:javascript
复制
            DataSet ds = new DataSet();
            NpgsqlDataAdapter da = new NpgsqlDataAdapter(); 
            da.SelectCommand = cmd;
            da.Fill(ds);
            return ds;

现在,您的DataSet包含一个表(ds.Tables)和该表所选的所有行

代码语言:javascript
复制
            foreach(DataRow r in ds.Tables[0].Rows)
                 Console.WriteLine(r["ColumnName"].ToString());
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11859558

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档