如何为CriteriaOperator过滤对象转换为lambda表达式,即:linq to xpo的动态where语句
How to convert the CriteriaOperator to a lambda expression, so, the latter expression can be used in the IQueryable source
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 DevExpress.Xpo; using DevExpress.Data.Filtering; using System.Collections; using DevExpress.XtraEditors; using DevExpress.Data.Linq.Helpers; using DevExpress.XtraEditors.Filtering; using DevExpress.XtraEditors.Repository; using DevExpress.Data.Filtering.Helpers; using DevExpress.Data.Linq; namespace DXSample { public partial class Form1 : XtraForm { public Form1() { InitializeComponent(); } IQueryable<Products> source; private void OnLoad(object sender, EventArgs e) { var products = new XPQuery<Products>(unitOfWork1); source = from product in products where product.Quantity >= 20 select product; gridControl1.DataSource = source.ToList(); CreateFilterColumns(); } private void CreateFilterColumns() { filterControl1.FilterColumns.Add(new UnboundFilterColumn("ProductID", "ProductID", typeof(int), new RepositoryItemSpinEdit(), FilterColumnClauseClass.Generic)); filterControl1.FilterColumns.Add(new UnboundFilterColumn("Quantity", "Quantity", typeof(int), new RepositoryItemSpinEdit(), FilterColumnClauseClass.Generic)); filterControl1.FilterColumns.Add(new UnboundFilterColumn("Price", "Price", typeof(decimal), new RepositoryItemSpinEdit(), FilterColumnClauseClass.Generic)); filterControl1.FilterColumns.Add(new UnboundFilterColumn("ProductName", "ProductName", typeof(string), new RepositoryItemTextEdit(), FilterColumnClauseClass.String)); filterControl1.FilterColumns.Add(new UnboundFilterColumn("Discontinued", "Discontinued", typeof(bool), new RepositoryItemCheckEdit(), FilterColumnClauseClass.Generic)); } private void OnUpdateFilter(object sender, EventArgs e) { gridControl1.BeginUpdate(); try { CriteriaToExpressionConverter converter = new CriteriaToExpressionConverter(); IQueryable<Products> filteredData = source.AppendWhere(converter, filterControl1.FilterCriteria) as IQueryable<Products>; gridControl1.DataSource = null; gridControl1.DataSource = filteredData.ToList(); } finally { gridControl1.EndUpdate(); } } private void OnSaveButtonClick(object sender, EventArgs e) { try { unitOfWork1.CommitChanges(); } catch (Exception exc){ MessageBox.Show(exc.ToString()); unitOfWork1.ReloadChangedObjects(); } } } }
using System; using DevExpress.Xpo; namespace DXSample { public class Products : XPLiteObject { int fProductID; [Key(true)] public int ProductID { get { return fProductID; } set { SetPropertyValue<int>("ProductID", ref fProductID, value); } } int fQuantity; public int Quantity { get { return fQuantity; } set { SetPropertyValue<int>("Quantity", ref fQuantity, value); } } decimal fPrice; public decimal Price { get { return fPrice; } set { SetPropertyValue<decimal>("Price", ref fPrice, value); } } string fProductName; public string ProductName { get { return fProductName; } set { SetPropertyValue<string>("ProductName", ref fProductName, value); } } bool fDiscontinued; public bool Discontinued { get { return fDiscontinued; } set { SetPropertyValue<bool>("Discontinued", ref fDiscontinued, value); } } public Products(Session session) : base(session) { } public Products() : base(Session.DefaultSession) { } public override void AfterConstruction() { base.AfterConstruction(); } } }
using System; using System.Collections.Generic; using System.Linq; using System.Windows.Forms; using DevExpress.Xpo; using DevExpress.Xpo.DB; using DevExpress.Skins; namespace DXSample { static class Program { /// <summary> /// The main entry point for the application. /// </summary> [STAThread] static void Main() { string connectionString = AccessConnectionProvider.GetConnectionString("MyDB.mdb"); XpoDefault.DataLayer = XpoDefault.GetDataLayer(connectionString, AutoCreateOption.DatabaseAndSchema); XpoDefault.Session = null; CreateData(); SkinManager.EnableFormSkins(); Application.EnableVisualStyles(); Application.SetCompatibleTextRenderingDefault(false); Application.Run(new Form1()); } static void CreateData() { using (UnitOfWork uow = new UnitOfWork()) { if (uow.FindObject<Products>(null) == null) { Products product = new Products(uow); product.Discontinued = false; product.Price = 100; product.Quantity = 20; product.ProductName = "Orange"; product = new Products(uow); product.Discontinued = true; product.Price = 140; product.Quantity = 50; product.ProductName = "Apple"; product = new Products(uow); product.Discontinued = false; product.Price = 30; product.Quantity = 120; product.ProductName = "Banana"; product = new Products(uow); product.Discontinued = true; product.Price = 200; product.Quantity = 80; product.ProductName = "Grape"; product = new Products(uow); product.Discontinued = false; product.Price = 300; product.Quantity = 10; product.ProductName = "Garnet"; product = new Products(uow); product.Discontinued = true; product.Price = 120; product.Quantity = 320; product.ProductName = "Mandarin"; product = new Products(uow); product.Discontinued = false; product.Price = 250; product.Quantity = 60; product.ProductName = "Kiwi"; uow.CommitChanges(); } } } } }
示例地址:https://www.devexpress.com/Support/Center/Example/Details/E2596
XAF开发成品案例参考
如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!欢迎各位转载,但是未经作者本人同意,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利。
作者博客: http://www.cnblogs.com/foreachlife
欢迎加入CIIP框架\XAF技术应用交流群: 336090194 群文件中有更多相关工具及文档资料
转载请注明出处。多谢!
欢迎加我微信: admiralcn 或扫码:

【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端