如何将数据访问到 IQueryable 中?

发布于 2024-08-19 14:17:44 字数 974 浏览 6 评论 0原文

我有 IQueryable 对象,我需要将 IQueryable 内的数据放入 Textboxs 控件中。这可能吗?

我尝试类似的操作:

public void setdata (IQueryable mydata)
{

    textbox1.text = mydata.????

}

更新:

我正在这样做:

public IQueryable getData(String tableName, Hashtable myparams)
{
        decimal id = 0;

        if (myparams.ContainsKey("id") == true)
             id = (decimal)myparams["id"];

        Type myType= Type.GetType("ORM_Linq." + tableName + ", ORM_Linq");

        return this.GetTable(tableName , "select * from Articu where id_tipo_p = '" + id + "'");

}


public IQueryable<T> GetTable<T>(System.Linq.Expressions.Expression<Func<T, bool>> predicate) where T : class
{
    return _datacontext.GetTable<T>().Where(predicate);
}

这返回 {System.Data.Linq.SqlClient.SqlProvider+OneTimeEnumerable1[ORM_Linq.Articu]}`

我没有看到任何方法就像你告诉我的那样。我看到 Cast<>、Expression、ToString...

I have IQueryable object and I need to take the data inside the IQueryable to put it into Textboxs controls. Is this possible?

I try something like:

public void setdata (IQueryable mydata)
{

    textbox1.text = mydata.????

}

Update:

I'm doing this:

public IQueryable getData(String tableName, Hashtable myparams)
{
        decimal id = 0;

        if (myparams.ContainsKey("id") == true)
             id = (decimal)myparams["id"];

        Type myType= Type.GetType("ORM_Linq." + tableName + ", ORM_Linq");

        return this.GetTable(tableName , "select * from Articu where id_tipo_p = '" + id + "'");

}


public IQueryable<T> GetTable<T>(System.Linq.Expressions.Expression<Func<T, bool>> predicate) where T : class
{
    return _datacontext.GetTable<T>().Where(predicate);
}

This returns a {System.Data.Linq.SqlClient.SqlProvider+OneTimeEnumerable1[ORM_Linq.Articu]}`

I don't see any method like you tell me. I see Cast<>, Expression, ToString...

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

浅笑轻吟梦一曲 2024-08-26 14:17:44

编辑:根据其他帖子中的附加信息进行更新...

您的 getData 方法返回 IQueryable 而不是强类型结果,这就是您最终转换它的原因。尝试将其更改为:

public IQueryable<ORM_Linq.Articu> getData(...)

您是否尝试从不同的表查询“Articu”?

完成上述更改后,您的代码可以重写如下:

ORM_Linq.Articu result = mydata.SingleOrDefault();
if (result != null)
{
    TextBoxCode.Text = result.id.ToString();
    TextBoxName.Text = result.descrip; 
}


If you have a single result use SingleOrDefault which will return a default value if no results are returned:

var result = mydata.SingleOrDefault();
if (result != null)
{
       textbox1.text = result.ProductName; // use the column name
}
else
{
    // do something
}

如果有多个结果,则循环它们:

foreach (var item in mydata)
{
   string name = item.ProductName;
   int id = item.ProductId;
   // etc..
}

EDIT: Updated based on additional info from your other posts...

Your getData method is returning IQueryable instead of a strongly typed result, which is why you end up casting it. Try changing it to:

public IQueryable<ORM_Linq.Articu> getData(...)

Are you trying to query for "Articu" from different tables?

With the above change in place, your code can be rewritten as follows:

ORM_Linq.Articu result = mydata.SingleOrDefault();
if (result != null)
{
    TextBoxCode.Text = result.id.ToString();
    TextBoxName.Text = result.descrip; 
}


If you have a single result use SingleOrDefault which will return a default value if no results are returned:

var result = mydata.SingleOrDefault();
if (result != null)
{
       textbox1.text = result.ProductName; // use the column name
}
else
{
    // do something
}

If you have multiple results then loop over them:

foreach (var item in mydata)
{
   string name = item.ProductName;
   int id = item.ProductId;
   // etc..
}
作妖 2024-08-26 14:17:44

首先,您应该使用强类型版本的 IQueryable。假设您的对象属于 MyObject 类型,并且 MyObject 有一个名为 Name 且类型为 string 的属性。然后,首先将参数 mydata 更改为 IQueryable 类型:

public void setdata (IQueryable<MyObject> mydata)

然后我们可以编写这样的主体来实际获取一些数据。假设我们只想要查询的第一个结果:

public void setdata (IQueryable<MyObject> mydata) {
    MyObject first = mydata.FirstOrDefault();
    if(first != null) {
        textbox1.Text = first.Name;
    }
}

或者,如果您想连接所有名称:

public void setdata(IQueryable<MyObject> mydata) {
    string text = String.Join(", ", mydata.Select(x => x.Name).ToArray());
    textbo1.Text = text;
}

First, you should be using a strongly-typed version of IQueryable. Say that your objects are of type MyObject and that MyObject has a property called Name of type string. Then, first change the parameter mydata to be of type IQueryable<MyObject>:

public void setdata (IQueryable<MyObject> mydata)

Then we can write a body like so to actually get some data out of. Let's say that we just want the first result from the query:

public void setdata (IQueryable<MyObject> mydata) {
    MyObject first = mydata.FirstOrDefault();
    if(first != null) {
        textbox1.Text = first.Name;
    }
}

Or, if you want to concatenate all the names:

public void setdata(IQueryable<MyObject> mydata) {
    string text = String.Join(", ", mydata.Select(x => x.Name).ToArray());
    textbo1.Text = text;
}
思念绕指尖 2024-08-26 14:17:44

嗯,顾名思义,实现 IQueryable 的对象是......可查询的!您需要编写一个 linq 查询来获取 IQueryable 对象的内部详细信息。在您的 linq 查询中,您将能够提取其数据并将其分配到您想要的任何位置 - 例如文本框。

这是学习 Linq 的一个很好的起点。

Well, as the name suggests, an object implementing IQueryable is... Queryable! You'll need to write a linq query to get at the internal details of your IQueryable object. In your linq query you'll be able to pull out its data and assign bits of it where ever you'd like - like your text box.

Here's a great starting place for learning Linq.

薯片软お妹 2024-08-26 14:17:44

我认为当您使用 FoxPro 和 DataSet 时,您会发现同样的心理斗争。非常好的、强大的基于字符串的功能(用于查询的 SQL、访问表和列名称)在这些世界中不可用,而是被一组已编译的强类型功能所取代。

如果您要根据编译时已知的数据源静态定义搜索和结果显示的 UI,这非常好。如果您尝试构建一个附加到仅在运行时已知并由配置数据定义的现有数据源的系统,那就不太好了。

I think you find the same mental struggle when coming from FoxPro and from DataSet. Really nice, powerful string-based capabilities(sql for query, access to tables and columns name) in these worlds are not available, but replaced with a compiled, strongly-typed set of capabilities.

This is very nice if you are statically defining the UI for search and results display against a data source known at compile time. Not so nice if you are trying to build a system which attaches to existing data sources known only at runtime and defined by configuration data.

遥远的她 2024-08-26 14:17:44

如果您只需要一个值,只需调用 FirstOrDefault() 方法。

public void setdata (IQueryable mydata)
{
    textbox1.text = mydata.FirstOrDefault().PropertyName;
}

If you expect only one value just call FirstOrDefault() method.

public void setdata (IQueryable mydata)
{
    textbox1.text = mydata.FirstOrDefault().PropertyName;
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文