最近在做一个项目,数据库需要用到Access,平时习惯了MYSQL、SQL server数据库,用起Access数据库还是有一些不习惯,特别是SQL系列数据库都能支持存储过程、自定义函数、视图、触发器等功能,而Access就不支持这些功能,而自带函数也极有限。
下面小小总结一下在项目过程中遇到的几个问题
1、在查询中需要用到类似Substring函数的功能,Access不支持Substring函数。但可以用Mid函数代替这个功能。
Mid函数原型:Mid(列名,起始位置,长度), 起始位置从1索引,这点与Substring一致。
如:
用一个表(tArea)来存储一个区域多级层次,
广东省 ID=001
广州市 ID=001001
天河区 ID=001001001
--表设计的采用ID实现多级子父类关系
现在如果知道一个区域的代码(ID=001001001)要查询它的父类名称,那么
SELECT Name FROM tArea WHERE ID=Mid('001001001',1,6)
删除父级的时候,子级所有节点都要删除(假如现在删除广东省所有数据ID=001)
DELETE FROM tArea WHERE Mid(ID,1,3)='001'
2、case... when... then... else...
在SQL系列数据库中,可以用这个表达式在查询语句中实现一些特殊功能。
如,一个bool类型字段(IsSend),数据库存放1或0,现在要求在查询结果中实现用“是”或“否”显示。
在MSSQL中 : SELECT (case IsSend when IsSend=1 then '是' else '否') AS IsSend FROM t
在Access中: SELECT IIF(IsSend=1,'是','否') AS IsSend FROM t
3、SQL系列数据库Case或者Convert函数在Access中不支持
用一个字段(takeDate)来存储日期时间,现在需要在查询语句中格式化显示时间。
在Access数据库中可以用format函数格式化。
Format函数原型
format$ 强制返回为文本
Long Date 操作系统定义的长日期
Format$(Now,"Long Date") 返回值 2006年5月25日
Medium Date 中日期(yy/mmm/dd)
Format$(Now,"Medium Date") 返回值 06-5月-25
Short Date 操作系统定义的短日期
Format$(Now,"Short Date") 返回值 2006-5-25
Long Time 操作系统定义的长时间
Format$(Now,"Long Time") 返回值 15:06:36
Medium Time 带AM/PM的12小时制,不带秒
Format$(Now,"Medium Time") 返回值 03:08 PM
Short Time 24时制的时间,不带秒
Format$(Now,"Short Time") 返回值 15:08
自定义格式参数
: 用来标识时间字符的间隔
Format$(Time(),"hh:nn") 返回值 15:25
/ 用来标识日期字符的间隔
Format$(now,"yyyy/mm/dd") 返回值 2006-05-25
c 格式化为国标的日期和时间
Format$(Now,"c") 返回值 2006-5-25 14:56:15
y 一年中的第几天
Format$(Now,"y") 返回值 145
d 一个月中的第几天(1-366)
Format$(Now,"d") 返回值 25
dd 当小于10时前面带0的天数(01-31)
Format$("2006-1-7","dd") 返回值 07
ddd 周几
Format$(Now,"ddd") 返回值 周四
dddd 星期几
Format$(Now,"dddd") 返回值 星期四
ddddd 显示标准日期
Format$(Now,"ddddd") 返回值 2006-05-25
dddddd 长日期
Format$(Now,"dddddd") 返回值 2006年5月25日
w 一个星期中的第几天
Format$(Now,"w") 返回值 5
ww 一年中的第几周
Format$(Now,"ww") 返回值 21
m 月数(注:当用于时间时,也可以表时为分钟)
Format$(Now,"m") 返回值 5
Format$(Now,"h:m") 返回值 16:11
mm 当小于10时前面带0的月数(注:当用于时间时,也可以表时为带0的分钟)
Format$(Now,"m") 返回值 05
Format$(Now,"hh:mm") 返回值 16:09
mmm 月份
Format$(Now,"mmm") 返回值 五月
q 一年中的第几季(1-4)
Format$(Now,"q") 返回值 2
yy 两位数的年份(00-99)
Format$(Now,"yy") 返回值 06
yyyy 四位数的年份(0100-9999)
Format$(Now,"yyyy") 返回值 2006
h 一天中的第N小时(0-23)
Format$(Now,"h") 返回值 16
hh 当小于10时带0的小时数(00-23)
Format$("7:30:28","hh") 返回值 07
n 一小时的分钟数(0-59)
Format$("7:30:28","n") 返回值 30
nn 当小于10时带0的分钟数(00-59)
Format$("7:3:28","n") 返回值 03
s 一分钟中的秒数(0-59)
Format$("7:30:8","s") 返回值 8
ss 当小于10时带0的分钟数(00-59)
Format$("7:3:8","ss") 返回值 08
ttttt 标准时间,小时数当小于10时不带0,与h:mm:ss相同
Format$("7:3:28","ttttt") 返回值 7:03:28
AM/PM 显示当前为AM或为PM
Format$(Now,"AM/PM") 返回值 PM
A/P 显示当前为A或为P
Format$(Now,"A/P") 返回值 P
AMPM 对0至2359的数值进行判断是AM还是PM,可以看作是同等于对00:00至23:59的数字进行判断,如1000可以看作是10:00。
Format$(1000,"AMPM") 返回值 AM
联合格式化
m/d/yy Format$(Now,"m/d/yy") 返回值 5-25-06
d-mmm-yy Format$(Now,"d-mmm-yy") 返回值 25-5月-06
d-mmmm Format$(Now,"d-mmmm") 返回值 25-五月
mmmm-yy Format$(Now,"mmmm-yy") 返回值 五月-06
hh:mm AM/PM Format$(Now,"hh:mm AM/PM") 返回值 04:50 PM
h:mm:ss a/p Format$(Now,"h:mm:ss a/p") 返回值 4:51:38 p
h:mm Format$(Now,"h:mm") 返回值 16:51
h:mm:ss Format$(Now,"h:mm:ss") 返回值 16:51:38
m/d/yy h:mm Format$(Now,"m/d/yy h:mm") 返回值 5-25-06 16:54
4、多表查询问题
连接可以在Select 语句的FROM子句或Where子句中建立,在FROM子句中指出连接时有助于将连接操作与Where子句中的搜索条件区分开来。
SQL-92标准所定义的FROM子句的连接语法格式为:
FROM join_table join_type join_table [ON (join_condition)]
其中join_table指出参与连接操作的表名,连接可以对同一个表操作,也可以对多表操作,对同一个表操作的连接又称做自连接。
join_type 指出连接类型,
可分为三种:内连接、外连接和交叉连接。
内连接(INNER JOIN)使用比较运算符进行表间某(些)列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。
根据所使用的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。
外连接分为:
左外连接(LEFT OUTER JOIN或LEFT JOIN)、
右外连接(RIGHT OUTER JOIN或RIGHT JOIN)
全外连接(FULL OUTER JOIN或FULL JOIN)
三种。
与内连接不同的是,外连接不只列出与连接条件相匹配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的数据行。
根据SQL语法规则,写出如下代码:
1). 内查询(查询三个表中均存在的ID记录,任何一个表中不存在的id将均被过滤掉)
select * from a表 inner join b表 on a表.id=b表.id inner join c表 on a表.id=c表.id where …… --where 条件暂时省略
2). 外查询(left join ,列出左表中的全部ID,不管b、c表中有无该ID)
select * from a表 left join b表 on a表.id=b表.id left join c表 on a表.id=c表.id where …… ---where 条件暂时省略
可是运行结果均为查询失败,如果仅仅两个表,查询则成功,三个或三个以上的表就会失败。
原因:Access对SQL的支持有些不同,将上述代码改为如下代码,问题解决!
select * from (a表 inner join b表 on a表.id=b表.id) inner join c表 on a表.id=c表.id where …… ---where 条件暂时省略
select * from (a表 left join b表 on a表.id=b表.id) left join c表 on a表.id=c表.id where …… --where 条件暂时省略
如果有四张表,可以写为:
select * from ((a表 inner join b表 on a表.id=b表.id) inner join c表 on a表.id=c表.id) inner join d表 on a表.id=d表.id where …… ---where 条件暂时省略