-
C#教程之使用Outlook对象筛选的_Items.Restrict方法时,“不支持使用like的模糊查询”
本站最新发布 C#从入门到精通
试听地址 https://www.xin3721.com/eschool/CSharpxin3721/
试听地址 https://www.xin3721.com/eschool/CSharpxin3721/
现象:
用Microsoft.Office.Interop.Outlook取得日历项,然后根据业务要求筛选。
items.Restrict方法中的筛选器,使用like进行模糊查询时,会出COMException异常。
代码:
1 //folder取得前略 2 3 Outlook.Items items = folder.Items; 4 string rstFilter = ""; 5 try 6 { 7 rstFilter = string.Format("[Subject] like '%{0}%'", "会議"); 8 items = items.Restrict(rstFilter);//此处报异常 9 } 10 catch (Exception ex) 11 { 12 MessageBox.Show(this 13 , ex.Message + Environment.NewLine + rstFilter 14 , this.Name 15 , MessageBoxButtons.OK 16 , MessageBoxIcon.Error); 17 return; 18 }
异常:
原因:
将属性名括在方括号内的写法叫做“Jet 筛选器”。在 Jet 查询中,只能对关键字属性进行短语匹配。
不能通过 Jet 查询进行开头或子字符串匹配。 即不支持like模糊查询。
为了克服使用 Jet 查询语法时关键字限制条件的局限性,请使用允许开头或子字符串限制条件的 DASL 语法。
解决:
使用与 Keywords 属性的比较筛选项目
将筛选器字符串改为如下:
rstFilter = string.Format("@SQL=http://schemas.microsoft.com/mapi/proptag/0x0037001f ci_phrasematch '{0}' ", "会議");
详情:
Docs / Office VBA 参考 / Outlook / 操作说明主题 / 搜索和筛选 / 筛选 / 概述
其中使用DASL语法时,命名空间相关介绍:
Docs / Office VBA 参考 / Outlook / 操作说明主题 / 导航 / 属性概述 / 按命名空间引用属性
栏目列表
最新更新
C# 面向对象
假设客车的座位数是9行4列,使用二维数
C#基于接口设计三层架构Unity篇
C#线程 入门
C#读取静态类常量属性和值
C# 插件式编程
C# 委托与事件有啥区别?
C#队列学习笔记:队列(Queue)和堆栈(Stack
linq 多表分组左连接查询查询统计
C#队列学习笔记:MSMQ入门一
C# 在Word中添加Latex 数学公式和符号
inncheck命令 – 检查语法
基于UDP的服务器端和客户端
再谈UDP和TCP
在socket编程中使用域名
网络数据传输时的大小端问题
socket编程实现文件传输功能
如何优雅地断开TCP连接?
图解TCP四次握手断开连接
详细分析TCP数据的传输过程
SqlServer 利用游标批量更新数据
BOS只读状态修改
SQL Server等待事件—PAGEIOLATCH_EX
数据库多行转换为单一列
获取数据表最后最后访问,修改,更新,
计算经历的时间
SQL查询结果自定义排序
修改数据库默认位置
日期简单加或减
从日期获取年,月或日