当前位置: 首页 > 编程日记 > 正文

VB6基本数据库应用(五):数据的查找与筛选

同系列的第五篇,上一篇在:http://blog.csdn.net/jiluoxingren/article/details/9633139

 

数据的查找与筛选

第4篇发布到现在已经过了4天,很抱歉,学生党,还是悲催的高三,没办法,8月1就开学了。以后更新文章的速度可能会更慢,而且出完这套数据库教程之后,未来一年都可能不会有新的教程了。就我而言是想写下去,多写点的,一是记录下自己会的,另一方面把自己会的知识传播出去,不过高三这段时间可能力不从心了。

 

继续吧,看标题“包含表中局部数据的数据集,数据的查找”,看上去是两项内容,实际上是一项。查找,筛选,实际上都是为了获取我们需要的数据,而不是将所有数据都提取出来。在这一章,我们将再次体会到SQL:Select语句的强大。

 

取得表中前n个或前n%的记录

之前,我说过SQL:Select语句的一个简化的语法,这已经是第三章的内容了,还记得吗?复习一下:

SELECT fieldnamelist  FROM  tablename

要获得表中前n个或前n%个记录,尽管我们可以打开整张表的数据,然后在用循环显示数据的时候最大值为n,n为我们想要的条数这种方式来实现,但是SQL:Select语句提供一个直接的方法来让我们获得表中前n个或前n%个记录。这时候我们要扩充SQL:Select语句的语法了。我们来看新的语法:

SELECT TOP n [PRECENT] fieldnamelist  FROM  tablename

 

我们发现新的语法在fieldnamelist前面加入了TOP n [PRECENT]这一部分,TOP和PRECENT都是SQL的关键字,所以我也按照我之前所说的习惯:SQL语句的关键字用大写。需要先说[PRECENT],[]这样的语法表示的是可选,也就是说TOP这样一个关键字加进去之后,n是必须的了,但是PRECENT依然是可选的,如果写上他,那n就代表前n%,是一个百分数,可取的范围是0<n<100;而如果没有PRECENT,那么n就代表前n条,可取的范围是0<n<4294967295,也就是说如果表中有10000000000(不用数了,比4294967295多一位数字)条记录(假设吧,Access一张表最多能有多少条记录真没查过,说不定最多只能有4294967295条,知道确切数字的告诉我一下,不过先假设他能储存不止4294967295条吧),那么你最多也只能选出前面4294967295条。

 

让我们来实践一下吧,假设我们要取出前30%的记录,那么我们可以这样写(还是在Student表,取出全部字段)

SELECT  TOP 30PRECENT  * FROM Student

前面说到的[PRECENT]的[]代表的是可省略,其实[]仅仅是语法表达的需要,实际上写SQL语句是不需要写上去的。就像我上面的SQL语句一样。

 

说完语法,照例是要上VB代码的。不上代码的话大家可能会产生疑惑,SQL的语法换了,那么这个SQL语句又应该写在哪里??别急,下面会回答你这个问题。

 

数据的条件查找

要实现数据的查找,就必须要使用更复杂语法的SQL:Select语句。我们来看下面的语法:

SELECT fieldnamelist  FROM  tablename WHERE 条件

 

会发现,这个语法比最初的语法多了一个“WHERE 条件”,但又没有了第一节的TOP n [PRECENT]这一部分,实际上除了最初给出来的语法内容是必须的,其他都是可以根据需要增添上去的。就是这个条件实现了数据的查找,也就是实现了把我们需要的数据从表里面取出来,而不是像之前那样取出一张表的全部数据。语法中“条件”两个字实际上很虚无,到底这个条件怎么写呢?最简单的是“ 字段名='内容'”,留意里面的一对单引号,当内容是中文的时候就需要用单引号引起来,如果不是的话与一般来说可以不用单引号。一定要注意这是单引号!

 

我们来写一个语句实践一下吧。假设我们要找出Student表中的StudentName为“黄飞鸿”的记录,我们可以这样写:

SELECT  *  FROM Student  WHERE  StudentName='黄飞鸿'

前面 SELECT * FROMStudent 的部分之前已经说过,光是这样没有Where关键字就是选出全部的记录。WHEREStudentName='黄飞鸿',就表示选出StudentName字段中内容为“黄飞鸿”的记录。

 

还是上面的实践中的例子,需要留意的是,认真看一下实践中我所写的SQL语句,Select后面跟着的字段名列表是用*的,也就是全部字段都选出来。然后再看我SQL语句后面的解释:“我们选出的是……的记录”,注意是记录,一个记录有多个字段的数据组成。所以,上面我写的语句的作用不仅仅是把StudentName字段中的“黄飞鸿”这个文本内容选了出来,同时还有StudentID字段中他所对应的的数据662356也被选了出来。这体现了数据库的对应关系。

现在来回答上一节的最后,提出的语法改变了,那么新的SQL语句又要写在什么地方的问题。其实还是老地方,其实每调用一次SQL:Select语句,无论是之前的简单语法,还是现在有Where的语法,甚至以后更复杂的语法,SQL:Select语句的作用都是返回一个数据集(如果符合Where条件的记录找不到,那这个数据集就是空的)。所以,所有的SQL:Select语句都可以作为参数传递给Recordset对象的Open方法。

 

照样,现在我们把实践中写的那个SQL语句作为参数传递给Recordset对象的Open方法,并显示在表格里。这个还是写在Load事件里吧。这次我把Load事件里的代码全都列出来,包括之前的连接数据库的,还有打开整张表的代码,这样做是为了给大家一个提醒,具体提醒是什么?认真看看注释吧,代码后面还会说的。

VB代码开始:

Private SubForm_Load()

'创建新的Connection对象

Set Cnn = NewADODB.Connection

 

'注意要记住该数据库目录为你数据库文件当前的位置

Cnn.Open "Provider=Microsoft.Jet.OLEDB.4.0;DataSource=E:\Sample.mdb;Persist Security Info=False"

'创建新的Recordset对象

Set rec = NewADODB.Recordset

 

'打开student表的全部字段的全部内容

rec.Open"SELECT * FROM Student", Cnn, adOpenStatic, adLockOptimistic

 

'---------------------------------------------------------------------

'“----”注释里的是第五章新加的代码

'---------------------------------------------------------------------

 

'注意了!!如果使用之前的Recordset对象变量rec

'而且之前的rec已经被Open过了,那么必须调用Close

'将其关闭之后才能再调用Open方法

rec.Close

 

'打开student表中StudentName为“黄飞鸿”的记录

rec.Open"SELECT * FROM Student Where StudentName='黄飞鸿'", Cnn, adOpenStatic, adLockOptimistic

 

'---------------------------------------------------------------------

'这一章新加的代码就到这里,下面的还是之前的代码

'---------------------------------------------------------------------

 

'数据的提取

Do Until rec.EOF =True

    List1.AddItemrec.Fields("StudentID").Value

        'Fields对象,括号里的是索引(Index),索引填写的内容为字段的名称

        'Item属性是Fields对象的默认属性,他的一个参数就是Index

        'Fields("Student")表示一个Field对象

        'Fields("Student")等价于

        'rec.Fields.Item ("Student")或

        'rec.Fields! ("Student")

        '!表示默认属性

 

    List2.AddItemrec.Fields("StudentName").Value

    '移动下一条记录为当前记录

    rec.MoveNext

Loop

End Sub

VB代码结束:

这里我们可以看到3行的红色注释(虽然VB的IDE里的注释是用绿色显示的,不过这里为了强调就用红色),非常显眼。这就是我要提醒大家的地方。实际的数据库应用里,往往需要将Recordset对象回收再用。例如这里我需要显示出全部的人名,待会我可能又根据用户的需要去找某个人的记录,或者待会可能还要排一下序。我们不可能创建那么多的Recordset对象,如果要的话就意味着我们需要声明很多个Recordset对象变量,这很可能会很混乱。所以Close之后重新用Open执行其他的操作,这样的手段是经常用到的。

 

我们可以看到,之前的打开整张表的代码我没有去掉,然后就是在一堆注释之后直接Close,再用Open来写今天的代码了。而后面的输出到List控件的代码也被保留了下来,接在了今天新的代码之后。所以现在的输出List1里就只有662356,List2就只有”黄飞鸿“了。

 

当前的代码运行结果如下图:


最后,给大家留个作业吧。第一节“取得表中前n个或前n%的记录”的SQL语句我一直没写用在VB上的代码,既然都知道了还是作为参数传递给Recordset对象的Open方法,那么自己去试一下吧。以为WHERE关键字的作用就怎么点??还没完呢!下一章,我们将来讲述:多重条件搜索,模糊搜索和给定范围内的搜索。本套教程未完,待续。


相关文章:

学习进度条(第一周)

学习进度条&#xff1a; 第一周 所花时间&#xff08;包括上课&#xff09; 5h 代码量&#xff08;行&#xff09; 150 博客量&#xff08;篇&#xff09; 2 了解到的知识点 这种主要是对上学期web知识的一个回顾&#xff0c;进行了第一次开学测验&#xff0c;了解了实…

设计模式 之美 -- 单例模式

为什么要使用单例&#xff1f; 一个类只允许创建一个对象或者实例。 背景简介&#xff1a;使用多线程并发访问同一个类&#xff0c;为了保证类的线程安全&#xff0c;可以有两种方法&#xff1a; 将该类定义为单例模式&#xff0c;即该类仅允许创建一个实例为该类的成员函数添…

(int),Int32.Parse() 和 Convert.toInt32() 的区别

在 C# 中&#xff0c;(int)&#xff0c;Int32.Parse() 和 Convert.toInt32() 三种方法有何区别? int 关键字表示一种整型&#xff0c;是32位的&#xff0c;它的 .NET Framework 类型为 System.Int32。 (int)表示使用显式强制转换&#xff0c;是一种类型转换。当我们从 int 类型…

MySQL留言板怎么创建_如何使用JSP+MySQL创建留言本(三)

如何使用JSPMySQL创建留言本(三)推荐查看本文HTML版本下面我们开始建立留言的页面&#xff01;import "java.util.*"import "java.text.*"import"java.sql.*"import "java.io.*"import "java.lang.*"contentType"t…

刚子扯谈:微信 今天你打飞机了嘛吗?

文/刚子 2013年8月5日 开片语:昨日爆爬二坨山后&#xff0c;精神豁然靓丽。虽然晒伤的不算厉害&#xff0c;但是还是有同事关切。说刚子你真黑了。好吧&#xff01;当然今天咱不扯爬山涉水&#xff0c;也不扯刚子咋就黑了&#xff0c;咱扯今天那个“热”。也许有部分朋友已经猜…

OMS API

plot cd("C:/……/") 转载于:https://www.cnblogs.com/Pusteblume/p/10467200.html

设计模式 之美 -- 简单工厂模式

文章目录1. 解决问题2. 应用场景3. 实现C实现&#xff1a;C语言实现4. 缺点1. 解决问题 举例如下&#xff1a; 我们实现一个卖衣服的功能&#xff0c;衣服的种类有很多&#xff1a;帽子&#xff0c;裤子&#xff0c;T恤。。。 每卖一种衣服&#xff0c;我们都要进行一次实例化…

mysql 分表原理_MYSQL 分表原理(转)

简介:引用MySQL官方文档中的一段话:MERGE存储引擎,也被认识为MRG_MyISAM引擎,是一个相同的可以被当作一个来用的MyISAM表的集合."相同"意味着所有表同样的列和索引信息.你不能合并列被以不同顺序列于其中的表,没有恰好同样列的表,或有不同顺序索引的表.而且,任何或者…

popStar手机游戏机机对战程序

DFS算&#xff0c;五分钟如果答案没有更新&#xff0c;那个解一般来说就很优了。 #include <cstdio> #include <iostream> #include <string.h> #include <cstdlib> #include <algorithm> #include <queue> #include <vector> #incl…

ps aux参数说明

运行 ps aux 的到如下信息&#xff1a; ps auxUSER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMANDsmmsp 3521 0.0 0.7 6556 1616 ? Ss 20:40 0:00 sendmail: Queue runner01:00:00 froot 3532 0.0 0.2 2428 …

myeclipse使用maven整合ssh配置

最近写项目&#xff0c;由于公司需求&#xff0c;使用myeclispe来开发maven项目&#xff0c;关于maven就不再介绍,无论是jar包管理功能&#xff0c;还是作为版本构建工具&#xff0c;优点自然是很多&#xff0c;下面先贴出所需要的配置文件。 maven所需要的 pom.xml 1 <proj…

C语言 #ifndef 引起的redefinition of xxx 问题解决

问题如下 多个.c和.h文件 其中cloth.h分布被hat.h和paths.h包含&#xff0c;编译时出现如下问题&#xff1a; error: redefinition of struct _Cloth 我的cloth.h定义如下&#xff1a; #include <stdio.h> #include <stdlib.h> #include "retval.h"…

mysql如何下载连接到visual_Visual Studio 2015 Community连接到Mysql

Visual Studio 2015 Community连接到MySQL&#xff0c;步骤很简单&#xff0c;但刚弄的时候一脸懵&#xff0c;现在记录如下以作备忘&#xff1a;安装好VS2015和Mysql后&#xff0c;只需要再安装两个东西即可。一个是SDK&#xff1a;MySQL for Visual Studio另一个是驱动&#…

web.py下获取get参数

比较简单&#xff0c;就直接上代码了&#xff1a; import web urls (/, hello ) app web.application(urls, globals()) class hello: def GET(self):print web.input()return "GET hello world"def POST(self):print web.input()return "POST hello w…

ORACLE 体系结构知识总结

ORACLE 体系结构.Oracle 体系结构图&#xff1a;.1.ORACLE 实例.1.1. Oracle 实例Oracle实例包括内存结构和后台进程System Global Area(SGA) 和Background Process 称为数据库实例文件。.2. Oracle 数据库一系列物理文件的集合&#xff08;数据文件&#xff0c;控制文件&#…

余额宝技术架构读后感

本次阅读文章为&#xff1a;余额宝技术架构及演讲 文章地址&#xff1a;https://mp.weixin.qq.com/s?__bizMzAwMDU1MTE1OQ&mid2653547540&idx1&snb3f568ba4bd1c4a0a2d35c0e5ef033cc&scene21#wechat_redirect 通过阅读“余额宝技术架构及演讲”&#xff0c;了解…

网络故障排查命令

ping #检测目标主机是否畅通traceroute #追踪路由mtr #检查到目标主机之间是否有数据包丢失nslookup #查看域名并解析&#xff0c;获取IP地址telnet #检查端口链接状态tcpdump #细致分析数据包发送接收 的详细内容netstat #查看网络端口连接状态ss #另外一种各式的查看网络端口…

Java程序猿面试题集(181- 199)

Java面试题集&#xff08;181-199&#xff09; 摘要&#xff1a;这部分是包括了Java高级玩法的一些专题&#xff0c;对面试者和新入职的Java程序猿相信都会有帮助的。 181. 182. 183. 184. 185. 186. 187. 188. 189. 190. 191. 192. 193. 194. 195. 196. 197. 198. 199. 转载于…

mysql四维数组_MySQL如何实现数组功能

前段时间想要用数组功能实现某些需求&#xff0c;结果发现mysql不支持数组&#xff0c;这个确实让人很头痛。查阅官方文档&#xff0c;也没有这一方面的资料。结果在网上&#xff0c;看到了某仁兄贴出了变相实现的一种方法&#xff0c;代码如下&#xff1a;DELIMITER ;DROP DAT…

在iOS上使用ffmpeg播放视频

国外靠谱的有这几个&#xff1a;1、Mooncatventures group https://github.com/mooncatventures-group2、KxMoviePlayer (use OpenGLES, Core Audio) https://github.com/kolyvan/kxmovie3、FFmpeg for ios (with OpenGLES, AudioQueue) https://github.com/flyhawk007/FFmpeg-…

shell --- trap 抓取信号

1. 解决问题 针对部分运行在生产环境中的脚本来说&#xff0c;有一些脚本运行的过程是不能被中断的&#xff0c;比如&#xff1a;生产环境 定期备份脚本&#xff0c;为了保证备份安全&#xff0c;备份期间不能被 SIGTERM和SIGINT 之类的中断信号中断。 该种类型的脚本逻辑增加…

python运行错误怎么查找_求助,python的二分法查找,按照视频上的代码写下来,结果运行错误...

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼def bsearch(s,e,first,last,calls):print(first,last,calls)if (last-first) < 2: return s[first] e or s[last]mid first (last - first)/2if s[mid] e: return Trueif s[mid] > e: return bsearch(s,e,first,mid-1,c…

system.out 汉字乱码

使用sts时&#xff0c;文件编码都设置成了UTF-8&#xff0c;使用system.out.println输出汉字时&#xff0c;出现乱码。 解决方案&#xff1a; run>run configurations>common>encoding修改为gbk就可以了。转载于:https://www.cnblogs.com/javaleon/p/4075341.html

三阶段day1

1、动态网页 和 静态网页动态网页&#xff1a;数据可以进行交互 动态改变数据2、nodenode是基于chrome的V8引擎的Javscript运行环境node中的事件机制以及非阻塞式的I/O式模型 使其轻量又高效node中的npm 是全球最大的包管理器 &#xff08;全球最大的垃圾网站&#xff09;I:inp…

Oracle 12c DG备库Alert报错ORA-01110

环境是12.2.0.1 version, Oracle Data Guard备库近段时间一直报错&#xff0c;但是备库主库同步一致&#xff0c;数据一致。2019-03-06T23:42:22.18404808:00 Errors in file /u01/app/oracle/diag/rdbms/ccdb/ccdb/trace/ccdb_m000_129832.trc: ORA-01110: data file 7: /u01/…

linux的 计划任务机制,自己带节奏

文章目录1. 解决问题2. 计划任务分类3. 一次性计划任务实现添加计划步骤注意事项4. 周期性计划任务实现cron和crontab命令5. 延时计划任务6. flock脚本加锁&#xff0c;保证单实例运行1. 解决问题 环境中有脚本需求&#xff0c;周期性运行或者固定时间运行脚本&#xff0c;为了…

erlang的tcp服务器模板

改来改去&#xff0c;最后放github了&#xff0c;贴的也累&#xff0c;蛋疼 还有一个tcp批量客户端的&#xff0c;也一起了 大概思路是 混合模式 使用erlang:send_after添加recv的超时处理 send在socket的option里面可以设置超时 accept&#xff0c;connect都可以在调用的时候传…

react select默认选项_reactjs – 如何为Picker提供默认的“Please select …”选项?

我想让我的Picker在启动时显示“默认选项”.这意味着&#xff1a;像“请选择一个选项”之类的东西.我试图用这个短语手动添加一个选项,但是,这样在选择其他选项后可以重新选择“默认选项”,就像它是真正的选项之一.有一些方法可以做到这一点&#xff1f;selectedValue{this.sta…

Git创建本地分支并关联远程分支

创建本地分支git branch 分支名 例如&#xff1a;git branch dev&#xff0c;这条命令是基于当前分支创建的本地分支&#xff0c;假设当前分支是master(远程分支)&#xff0c;则是基于master分支创建的本地分支dev。 切换到本地分支git checkout 分支名 例如&#xff1a;git ch…

shell --- awk规范 系统总结

文章目录awk和sed的区别awk脚本的流程控制awk 记录和字段字段的引用awk表达式赋值操作符算数操作符系统变量&#xff08;awk本身自定义的系统变量&#xff09;关系操作符布尔操作符awk 条件和循环条件语句循环awk 的数组数组的定义数组的遍历删除数组举例&#xff0c;编写awk脚…