根据条件检索表中的数据,有多种查询方式,等值查询,模糊查询等。
等值查询就是将输入数据,于数据库中数据进行比较,若数据库表中某一个记录的字段值等于此数据,那么就找到了需要数据;
等值查询又分单个条件查询和多个条件查询。
模糊查询,就是在不清楚数据库表中,某一字段确切数据时,进行的一种模糊匹配查询。
例如:查询客户信息CUSTINFO表中,地址字段ADDR中包含“长春”两个字的记录,
就可以使用这样的查询语句:SELECT * FROM CUSTINFO WHERE ADDR LIKE ‘%长春%’。
模糊查询,分为单个字符匹配和多字符匹配,上面用到的LIKE ‘%长春%’,是一种多个字符匹配的例子,单个字符使用单个下划线“_”进行匹配,
例如LIKE ‘_ABC’就是匹配,长度为4,且后三个字符为ABC的数据。
搜索引擎对于CUSTINFO表中的数据,是逐个的进行比较,即在读取到一条数据的时候,根据WHERE谓词后面的条件进行比较。
在ILE RPG中,多条件等值查询也是常用到的,下面分析一个例子。
--先将指针定位到物理文件的第一条数据
I_STRDAT SETLL ABCD23
READ ABCD23
--①读取到一条记录
DOW NOT %EOF
--②对当前读取的数据进行处理
--a