ACCESS中的参数查询与自定义函数的实现
?
1.?????? 带参数的查询 有一个数据表,表名为myTEST,表结构及内容如下: 需要创建一个查询实现功能:指定月的数据统计。因为要用于GROUP BY ,所以无法在创建查询后使用条件来完成指定月的数据统计,例如: 创建查询:myView? 查询的功能:显示指定月每天每个项目的完成数量情况(这里还需要用于交叉表),需要显示的结果如下: 如果发实现这样的结果,用简单的交叉表和统计功能可以实现,但如果你需要单独列出指定的月份(用Where 或having)则不能实现,这个时候我们可以利用ACCESS数据库中的PARAMETERS 来实现,详细的语句如下:
在这里我们要注意: l???????? TRANSFORM 语句,它是用来生成交叉表的,详细说明请参考ACCESS帮助文件 l???????? PARAMETERS 声明,是用来定义查询中的参数,详细说明请参考ACCESS帮助文件 ? 2.?????? 在查询或SQL语句中使用自定义函数功能 在大型的数据库系统中(例如SQLServer),可以使用自定义函数功能来扩展数据处理功能,而在ACCESS数据库中没有存储过程、函数、触发器等功能。如何在SQL语句或定义查询使得到自定义的函数,用于扩展自己的数据库功能,可以使用ACCESS提供的模块功能来实现 首先,我们新建一个模块,取名为modMain(可选意取)。然后打开这个模块,在打开VBA环境下编写相应的代码来完成需要的功能。例如:需要获取某个列的所有值,并生成一个字串:
下面我们可以看下实现的效果: 首先创建一数据表,取名person 然后创建一个查询,取名Person_V,内容如下: SELECT Company,combstr("Person","Name","Company",Company) AS CombName,"sex",Company) AS CombSex FROM Person GROUP BY Company; 执行查询Person_V,结果如下: (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 安装 SQL2005 的COM+错误的避免方法
- 在SQLserver中如何获得两个日期相减的天数及日期函数
- sql – 为什么是IsNull(LTrim(RTrim(Lower(null))),-1)是*?
- SQLSERVER2005 跨数据库访问 -- 建立链接服务器
- Linq2SQL“本地序列不能在LINQ to SQL中使用”错误
- sql – 为什么我得到“游标的名称已经存在”?
- sql-server – 为安全(SSL)连接配置的MS SQL Server允许从J
- SQLite教程(六):表达式详解
- 数据库 – 数据仓库和大数据之间的实际区别是什么?
- sqlserver中通过osql/ocmd批处理批量执行sql文件的方法