Vf知识点总结
一、有效性规则和参照完整性
1.有效性规则
      先选中要求设置的字段,
1)“规则”:逻辑型表达式即SQL格式表达式。
例:年龄是15-20 年龄>=15 and 年龄<=20
2)“信息”:字符型表达式,直接摘抄加“”(英文状态)
3)“默认值”:看选中的字段是什么类型
2.参照完整性
  1)判断一方(没有重复字段的表)和多方(有重复字段的表)
  2)一方建主索引,多方建普通索引
  3)由一方向多方扯一条线
  4)清理数据库(数据库清理数据库,如果遇到“文件正在使用暂不能发布pack命令,” 此时close all,再重新以独占方式打开数据库再进行一次清理)
  5)右键编辑参照完整性(两个永久性联系须一一设置其参照完整性)
二、 SQL语句
1.格式:
格式一:
Select [top]字段1/字段2…… from 1,2. where 连接条件 and(or) 筛选条件 {group by 某一字段 [haing count(字段)] } order by 字段1 asc/desc, 字段2 asc/desc…… into table
格式二:
Select [top]字段1/字段2…… from 1 join2 join 3. on 连接条件(返回来写) where 筛选条件 {group by 某一字段 [haing count(字段)] } order by 字段1 asc/desc, 字段2 asc/desc…… into table
.“字段1/字段2……”,根据题目要求,搜索什么字段写什么字段,若其中某一字段在表中没有则认定为是起的新名字,在该字段前加as,之后向函数avg()sum()max()min()count()
⑵.“group by 某一字段 [haing count(字段”为难点。考虑用不用group by,首先在草稿纸上或脑海生成题目要求的表,选取一个个例填写分析是否用得到group by,按什么分组。
国家名称
奖牌数
中国
10
美国
4
俄罗斯
7
……

……

……

(3)select * from where 某一字段 is null
(4)运行过程中碰到“XX不唯一”到该字段在其前面加上表名。
2.查询设计器与视图设计器区别更新条件
⑴函数和表达式:右侧……
查询去向:右键---输出设置查询去向---
        或菜单查询---查询去向----
3.其他
(1)insert into 表名 values(……)
insert 表名(字段1,字段2……) values(……)
(2)update 表名 set 字段 where 条件
  Vf命令:replace 字段 with for 条件
(3)delete from 表名 where 条件
  Pack 删除打逻辑删除标记记录 
  Zap  删除全部记录只留表结构
(4)alter table 表名 add (column) 字段 C(6)
  alter table 表名 drop 字段
alter table 表名 rename 字段1 to 字段2
(5)select * from into array/table/cursor  数组名/新表名/临时表
select * from to fiel 文件名(.txt
三、菜单
1      加访问键-----\<字母(笔试中填)| 选项处打Ⅴ 
加分隔线-----\-
2.显示-常规选项
1)位置:“替换”、“追加”、“在…之前”等。
2)作为顶层表单
3.菜单先保存(.mnx)再生成后运行(do 菜单名.mpr)
四、 表单
1 文件名---保存时的名字  标题---caption
名,名称,控件名---name   
2.各控件常用属性
(1)  命令按钮commad1:
enabledvisible等。
(2)  命令组按钮commandgroup1(右键--编辑):
buttoncountbuttons(指定选第几个按钮)、
value(选中的按钮)visible等。
(3)  标签label1
(4)  文本框text1
value(输入的内容)passwordcharinputmarkcontrolsource等。
(5)  复选框check1
value(选中为1,不选中为0)
6)选项组按钮buttongroup1(右键--编辑):
buttoncountbuttons(指定选第几个按钮)、value(选中的按钮)visible等。
7  表格grid1(右键--编辑):
columncountrecordsourcetyperecordsource
(8)页框pageframe(右键--编辑):
pagecountpages等。
(9)列表框list1:
value(选中的条目)list(数值)---选中第几项、listindex---列表索引、multiselect rowsourcetyperowsource 等。
(10) 组合框combo1:
value(选中的条目)list(数值)---选中第几项、listindex---列表索引、multiselect rowsourcetyperowsource style等。
(11)时钟timer1:
enabledinterval
3.表单中顶层表单步骤:
1)表单showwindows-2
(2)loadinit事件:do 菜单名.mpr with this
4.表单中快捷菜单:
rightclick事件:do 菜单名.mpr
5.布局工具栏:
先全部选中要求的控件,显示布局工具栏
6.新建方法程序或属性:
    表单---新建方法程序/新建属性
7
close all
open database 数据库名
use
go top
do while not eof()do while eof()=.f.
变量赋予初值
    do case                if 条件 (then)
    case 条件                    语句块1
        表达式1        else
    case 条件                    语句块2
        表达式2            endif
    …………              …………
    otherwise
      表达式n
    endcase
语句块
skip
enddo
五、 杂项
1.          函数:
Str()数值型转换为字符型
Val()字符型转换为数值型
CtoD()字符型转换为日期型
DtoC()日期型转换为字符型
CtoT()字符型转换为日期时间型
TtoC()日期时间型转换为字符型
abs()----绝对值   
sign()---正数为1,负数为-100
sqrt()---开平方
pi()---圆周率
int()---整数部分
ceiling()---比他大的最小整数  ceiling(4.9)---5
floor()---比他小的最大整数    floor(4.9)---4
round()---四舍五入      round(123.453,0)---123
round(123.453,-1)---120
round(123.453,-2)---100
mod()---余数            mod(13,-12)----11
max()min()
len()---字符串长度        x=book,len(x)—4  len(x)--1
lower()---大写变小写、upper()---小写变大写
space()---测空格
trim()---去掉字符串尾部
ltrim()---去掉字符串头部
alltrim()---去掉字符串头部和尾部
left()---从左边取规定个字符
right()---从右边取规定个字符
substr()---从规定位置起取规定个字符
occurs()---第一个字符串在第二个字符串中出现的次数
at()---第一个字符串在第二个字符串中出现的位置(区分大小写)
atc()---第一个字符串在第二个字符串中出现的位置(不区分大小写)
stuff()---替换 stuff(abcdefg,2,0,xyz)---axyzbcdefg
stuff(abcdefg,2,5,xyz)---axyzg
stuff(abcdefg,2,4,””)---afg
chrtran()—单换
chrtran(abacadad,ad,xw)---xbxcxwxw
like()---是否完全相等
date()time()datetime()year()month()day()hour()minute()second()
between()---值测试函数
isnull()---是否是null
empty()---是否是0
varitype()---测试类型
eof()---文件末尾、bof()---文件开头
recno()---当前记录的记录号
recount()---文件中记录个数
iff()--- 相当于ifelse..
deleted()---当前指针所指记录是否打删除标记 
2.字段类型:
字符型  C      数值型  N      货币型  Y
日期型  D    日期时间型  逻辑型  L
3. 扩展名后缀:
数据库:.dbc        表文件:.dbf 
菜单定义文件:.mnx 
菜单程序(执行)文件:.mpr(不能省)
程序文件:.qpr          表单文件:.scx
查询文件:.qpr(不能省项目文件:.pjx
报表文件:frx            连编文件:.app
report form 报表文件名.frx preview
分享
一、主要命令: 1CREATE 作用:建立一个新的表。 格式:CREATE [<文件>|?](注意,命令字符可取前面四个字符,后面可省略不写,即CREA ,下同;中括号表示其中的参数是可选的;|管道符号表示两个参数只能选择一个,不能同 时选择,下同。) 说明:文件指建立以.db...
常用命令函数程序汇总 2008-09-10 21:23 | (分类:默认分类)
一、主要命令:
1CREATE
作用:建立一个新的表。
格式:CREATE [<文件>|?](注意,命令字符可取前面四个字符,后面可省略不写,即CREA
,下同;中括号表示其中的参数是可选的;|管道符号表示两个参数只能选择一个,不能同
时选择,下同。)
说明:文件指建立以.dbf为扩展名的VFP数据库文件,在命令后面加上一个问号表示系统会弹出对话框,要求用户输入想要建立的表名。在命令中不加文件名或问号系统也会弹出对话框,要求用户输入想要建立的表名。
2MODIFY STRUCTURE
作用:显示表文件结构,并允许修改此表的结构。
格式:MODIFY STRUCTURE
说明:只有在用USE命令打开表文件以后,才能显示或修改表文件的结构。
3APPEND
作用:在当前表的尾部(无论表中有无记录)追加记录(在当前表指当前正使用的表)。
格式:APPEND [BLANK]
说明:在APPEND命令后面加上BLANK参数表示在当前表的尾部添加一条空白记录。无BLANK参数时,表示在当前表的尾部添加一条记录并要求用户输入相应的字段内容。
4INSERT
作用:在表文件中间插入一个新记录。
格式:INSERT [BEFORE] [BLANK]
说明:INSERT 在当前记录后插入一记录;
INSERT BEFORE 在当前记录前插入一记录;
INSERT BEFORE BLANK 在当前记录前插入一空记录。
5BROWSE
作用:主要用于打开浏览窗口,查阅表文件并同时进行修改。
格式:BROWSE
6USE
作用:打开和关闭表文件。
格式:USE [<文件名>]
USE
说明:前一个命令用来打开<文件名>指定的表文件,该表如有备注型字段,则同时打开相应的备注文件(.fpt文件);后一个命令关闭当前打开的表文件。
7LISTDISPLAY
作用:显示表(.dbf)的内容、结构或状态。
格式:LIST|DISPLAY [OFF] [<范围>] [FIELDS] <表达式表> [WHILE <条件>] [FOR <条件
>]
[TO PRINT|TO FILE <文件>]
LIST|DISPLAY STRUCTURE TO PRINT|TO FILE <文件>]
LIST|DISPLAY STATUS [TO PRINT|TO FILE <文件>]
说明:命令带OFF参数表示不显示记录号,范围指定对哪些记录进行操作,范围包括:
RECORD n
第几号记录、NEXT n 当前记录开始的几个记录、REST 自当前记录开始至文件末尾的所有记录、ALL所有的记录。不选范围则隐含范围为ALLFIELDS后跟字段名,字段名与字段名之间用逗号分隔。WHILE后跟条件,FOR后面也跟条件,区别是,WHILE后的条件如果满足,便停止查;FOR后的条件查所有满足条件的记录。TO PRINTTO FILE <文件>分别表示将显示结果在打印机上打印出来和将显示结果输出到文件。DISPLAY命令在显示记录满屏后,要求用户按任意键继续显示 ,并且在 该命令中,如果省略范围仅显示当前
记录。格式中,下面两个命令分别为显示表结构(STRUCTURE)和工作状态(STATUS)。
8、记录的定位
作用:用记录指针(POINTER)定位记录。
格式:GO[TO] RECORD n|TOP|BOTTOM
n
SKIP [+|-]
说明:第一个命令又叫绝对定位,其中,RECORD n定位到n号记录,TOP定位到第1个记录,BOTTOM定位到最后一个记录。第二个命令定位到第n个记录,n是一个数值。第三个命令又叫相对定位,它以当前记录为基准前移(-)或后移(+n个记录,不选任选项,则默认记录指针后移一个记录。
9CHANGEEDIT
作用:显示要编辑或修改的字段。
格式:CHANGE|EDIT [<范围>] [FIELDS <字段名表>] [WHILE <条件>] [FOR <条件>]
10BROWSE
作用:打开一个"浏览"窗口,供用户浏览或修改记录。
格式:BROWSE [FIELDS <字段名表>]
11REPLACE
作用:用表达式的值代替命令中与之相对应的字段的内容。
格式:REPLACE [<范围>] <字段1> WITH <表达式1>[<字段2> WITH <表达式2>] [FOR <条件> ] [WHILE<条件>]
12DELETEPACKZAPRECALL
作用:分别是给要删除的记录作删除标记、彻底删除、删除所有记录和取消被选中的表记
录的删除标志。
格式:DELETE [<范围>] [WHILE<条件>] [FOR <条件>] (特例:DELETE FILE FILENAME.DBF,该命令删除指定的表文件)
PACK
ZAP
RECALL [<范围>] [FOR <条件>] [WHILE<条件>]
13SORTINDEX
作用:分别是建立一个其记录以新的物理顺序排列的新表文件和对当前表根据关键字表达式
的值从小到大排列,并存入TO后指定的索引文件名的文件或复合索引文件的一个标识中。
格式:SORT TO <文件名> ON <字段名1> [/A] [/C] [/D][<字段名2> [/A] [/C] [/D]]...
trim函数的作用是删除文本的什么空格
[ASCENDING|DESCENDING] [<范围>] [FOR <条件>] [WHILE<条件>] [FIELDS<字段表>]
INDEX ON <关键字表达式> TO <文件名>
INDEX ON <关键字表达式> TAG <标识名> [OF <文件名>] [FOR <条件>]
说明:第1个命令中,/A按字段名升序排序,/D按字段名降序排序,/C忽略大小写,针对字符型关键字而言,ASCENDINGDESCENDING分别表示升序和降序。第1个命令建立.dbf表文件,第2个命令建立.idx单一索引文件,第3个命令建立.cdx复合索引文件(Compound Index)。
14USE <表文件名> INDEX <索引文件名表>SET INDEX TOSET ORDER TO
作用:分别是打开表文件的同时打开索引文件、打开索引文件和改变主索引。
格式:USE <表文件名> INDEX <索引文件名表>
SET INDEX TO [<索引文件名表>]
SET ORDER TO [<索引文件名>](特例:重新索引命令:REINDEX
15FINDSEEKLOCATECONTINUE
作用:前两个命令FINDSEEK是在一个已经建立了索引文件的表中,定位到关键字中的内容与命令行中字符串相同的第一个记录。后一个命令在用USE打开表文件以后,直接查询表中字段内容。
格式:FIND <"字符串">|<字符串>
SEEK <表达式>
LOCATE [<范围>] [FOR <条件>] [WHILE<条件>]
CONTINUE
说明:FIND命令与SEEK命令的区别是前者后跟字符串,而后者后跟表达式。在用LOCATE命令到一个匹配记录后,可用CONTINUE命令搜索表的剩余部分来寻其他匹配的记录。
16COUNT
作用:统计当前表文件中符合条件的记录数。
格式:COUNT [<范围>] [FOR <条件>] [WHILE<条件>] [TO <内存变量名>]
说明:内存变量名可用除参数外的任意字符。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。