文档详情

vfp的数据类型和存储类型

壹****1
实名认证
店铺
PPT
219.99KB
约37页
文档ID:608805468
vfp的数据类型和存储类型_第1页
1/37

单击此处编辑母版标题样式,单击此处编辑母版文本样式,第二级,第三级,第四级,第五级,*,第,三,章,VFP的数据类型与存储类型,Visual FoxPro 6.0,3.1,数据,类型,数据是反映客观事物属性的记录通常分为数值型和字符型两种基本类型数据类型一旦被定义,就确定了其存储方式和使用方式Visual FoxPro系统将数据细化分为以下十三种类型1),字符型,(Character)字符型(C型)数据可以包含任何可显示的ASCII码字符,包括字母、数字、汉字、符号、空格等,长度范围是0254个字符,使用时必须用定界符单引号,双引号,方括号括起来2),数值型,(Numeric)数值型(N型)是由数字(09)、小数点和正负号组成最大长度为20位(包括、和小数点)3),整型,(Integer)整型(N型)表示整数,仅用于字段变量,数据占4个字节4),浮点型,(Float)浮点型(N型)与数值型等价,为与其它软件的兼容而设5),双精度型,(Double)双精度型(N型)是更高精度的数值型数据,只用于字段变量,固定占用8个字节,并采用固定长度浮点格式存储6),货币型,(Currency)货币型(Y型)用来表示货币值,,系统默认的货币符号是“$”。

7),日期型,(Data)日期型(D型)用于表示日期,用默认格式mm/dd/yyyy来表示,长度固定为8位,yyyy表示年,占4字节,mm表示月,占2字节,dd表示日,占2字节8),日期时间型,(DataTime)日期时间型数据是描述日期和时间的数据其默认格式为mm/dd/yyyy hh:mm:ss其中yyyy代表年,前两个mm代表月,dd代表日,hh代表小时,后两个mm代表分钟,ss代表秒,长度固定为8位9),逻辑型,(Logical)逻辑型数据(Logic)是描述客观事物真假的数据,用于表示逻辑判断结果逻辑型数据只有真(.T.)和假(.F.)两种值,长度固定为1位,10),备注型,(Memo)备注型数据(Memo)用于存放较长的字符型数据类型可以把它看成是字符型数据的特殊形式备注型字段固定占4个字节,用来存储一个指向备注文件(.FPT)的指针,实际数据长度仅受限于现有的磁盘空间11),通用型,(General)通用型(G型)用于存储OLE对象,可以是电子表格、文档、图片等仅适用于表中的字段,固定占4个字节,实际数据长度仅受限于现有的磁盘空间12),字符型,(二进制)与字符类相似,但若代码页(不同语系代码)改变时,其值并不会随之改变,即VFP不会自动转换成相应国家的语系。

13),备注型,(二进制)与字符型(二进制)一样,当代码页改变时,其值不会随之改变3.2,数据,存储类型,(常量、变 量),常量,在数据处理过程中其值不发生变化的量叫常量1.,数值型,(N型),数值型常量是由数字09、小数点、正负号和 E(科学计数法)组成的数值如,整数,:100 ,-35,小数,:2.54358,科学计数法,如:1.2E+5 表示 1.2乘以10的5次方0.3926E1,2.7E02,2.,字符型,(C型),字符型常量是由“”、括起来的字符或字符串例如,“ABCD”、No_4、北京、“Im a student”等注意:引号和括号必须是英文字符,3.,逻辑型,(L型)只有逻辑“真”值和逻辑“假”值两个值,,真:.T.、.t.、.Y.、.y.,假:.F.、.f.、.N.、.n.,4.,货币型,(Y型)货币型常数是以“$”作为前缀的数值,,如$986.35、$1234.5678保留四位小数,如:$231.12345,实际在计算机里存放的是:$231.1235,5.,日期型,(D型)日期常量是用 括起来的日期形式的常量如 10/01/1992,10/01/92,10-01-92。

严格的日期格式YMD,(VFP默认),yyyy-mm-dd或yyyy/mm/dd如 2000-09-20,2000/10/016.,日期时间型,(T型)日期时间型常量也用 括起来表示,,如 10/01/92 8:45,严格的日期时间格式为:,yyyy-mm-dd hh:mm:ssa|p 或,yyyy/mm/dd hh:mm:ssa|p,如 2000-09-20 8:45,变 量,在命令操作和程序运行过程中其值允许变化的量称为变量一、,内存变量,定义内存变量时应取名并赋初值,变量建立后存储于内存中,并可以改变其值,直到清除该变量内存变量的命名规则:,变量名可以由字母、数字、下划线和汉字组成,但第一个字符不可以是数字,至多128个字符,不可与系统保留字同名内存变量的定义和赋值,在内存变量赋值同时,也定义了内存变量及数据类型格式1 STORE TO ,格式2 =,例:,NAME=李华,STORE 5*4 TO A,B,C,?NAME,?A,?NAME,?同志,?NAME=,NAME,结果:,李华,20,李华同志,NAME=李华,二、,数组变量,数组:按一定顺序排列的一组内存变量先定义后使用,如定义:DIMENSION|DECLARE a(2,3),b(4),赋值:,a=4,b(1)=“foxpro”,a(2,1)=3等价a(4)=3,三、,字段变量,表的各个字段都是字段变量,use 学生表,?学号,go 5,?姓名,内存变量和字段变量同名时:字段变量优先,若要显示内存变量,用?m.编号或?m-编号,四、,记录,记录是表中的一行字段的集合。

五、,对象,对象是构成程序的基本单位和运行实体3.3,函 数,函数是系统内部预先编制好的一组程序,分别实现某些特定的运算或操作函数的一般调用形式:(,),其中函数名是系统规定的,参数可以是一个或多个,也可为空,,即:函数名(),但圆括号不能省略VFP提供了200余种函数,常用函数 P50表2.7表2.11按功能可划分为:数学函数、字符串函数、日期和时间函数、类型转换函数、测试函数1、数学函数(数值函数),(1)求绝对函数ABS格式:ABS(数值表达式)?ABS(-4)结果为,(2)求整函数INT格式:INT(数值表达式)?INT(4.8)结果为,(3)四舍五入函数ROUND格式:ROUND(数值表达式,保留小数位)功能:按保留小数位指定的位数对数值表达式的数值进行四舍五入ROUND(3.14159,3)3.142?ROUND(3.14159,0)3,(4)指数函数EXP、平方根函数SQRT、格式:EXP|SQRT(数值表达式)?EXP(2)7.39?SQRT(9)3,(5)取模(求余数)函数MOD格式:MOD(数值表达式1,数值表达式2)功能:取数值表达式1除以数值表达式2的余数MOD(20,3)2,(6)求最大值MAX、最小值MIN格式:MAX|MIN(表达式1,表达式2)功能:求表达式1和表达式2中的大者、小者。

2、字符串函数,(1)判子字符串位置AT格式:AT(字符表达式1,字符表达式2,数值表达式)功能:求字符表达式1在字符表达式2中第数值表达式次出现的起始位置数值表达式 默认值为 1说明:,若字符表达式2中不包含字符表达式1,则函数值为零;大小写字母在检索中视为不同AT(OK,COMPUTER OKOK,2)12,?AT(数据,计算机数据管理系统)7?AT(BOOK,COMPUTER)0,(2)求子串函数SUBSTR格式:SUBSTR字符表达式,起始位置,长度功能:对字符表达式从给定的起始位置开始截取指定长度的字符,生成一个新的字符串;?,(3)取左、右子串函数格式:LEFT|RIGHT(字符表达式,数值表达式)功能:LEFT 从字符表达式左边截取由数值表达式的值指定的字符,生成一个新的字符串;RIGHT 从字符表达式右边截取由数值表达式的值指定的字符,生成一个新的字符串;,?LEFT(FOXPRO数据库管理系统,6)FOXPRO?RIGHT(FOXPRO数据库管理系统,14)数据库管理系统,(4)ALLTRIM删除首部和尾部空格,格式:ALLTRIM(字符表达式)功能:ALLTRIM删除字符串首部和尾部的空格,?ALLTRIM(“man ”)man,(5)构造空格函数SPACE格式:SPACE(数值表达式)功能:产生由数值表达式的值决定的空格数。

姓名”+SPACE(3)+“李宁”姓名 李宁,(6)字符串长度函数LEN格式:LEN(字符表达式)功能:测定字符串的长度(字符个数)LEN(FOXPRO数据库管理系统)20,(7)大小写字母转换函数LOWER|UPPER格式:(字符表达式)功能:LOWER把字符表达式中的大写字母转换为小写字母;UPPER把字符表达式中的小写字母转换为大写字母LOWER(FoxPro)foxpro?UPPER(FoxPro)FOXPRO,3、日期和时间函数,(1)系统日期函数DATE格式:DATE()?DATE()99/11/15(2)系统时间函数TIME格式:TIME()?TIME()08:50:43(3)年、月、日函数YEAR|MONTH|DAY格式:YEAR|MONTH|DAY(日期表达式)功能:从日期表达式中求出年份、月份、日份的数值DATE()99/11/15?YEAR(DATE()1999?MONTH(DATE()11?DAY(DATE()15,4、类型转换函数,(1)字符转换为数值函数VAL格式:VAL(字符表达式)功能:将字符型数据转换为数值型数据说明:,若由数字字符和小数点组成,则转换成相应的数值,但只保留两位小数,其余小数四舍五入。

若由非数字字符打头,则转换为0.00若由数字字符打头,且混有非数字字符时,则转换到第一个非数字字符VAL(1234.5678)1234.57?VAL(FoxPro)0.00?VAL(1234FOX.5678)1234.00,(2)数值转换为字符函数STR格式:STR(数值表达式,长度,小数位数)功能:把数值表达式的运算结果转换为指定长度的字符串STR(1234.5678,7,2)1234.57(3)字符转换为日期函数CTOD格式:CTOD(字符表达式)功能:将符合yy/mm/dd、mm/dd/yy日期格式的字符串转换为相应日期CTOD(99/11/15)99/11/15(4)日期转换为字符函数DTOC格式:DTOC(日期表达式)功能:将转换为相应的字符串说明:按mm/dd/yy格式转换;,?DTOC(DATE()99/11/15,(5)ASCII码值转换为字符函数CHR格式:CHR(数值表达式)功能:将所表示的ASCII码值转换为相应的字符CHR(65),CHR(97),CHR(48)A a 0(6)字符转换成ASCII码值函数ASC格式:ASC(字符表达式)功能:返回最左边的一个字符的ASCII码值。

ASC(A),ASC(a),ASC(0)65 97 48,5、测试函数,(1)记录号测试函数 RECNO格式:RECNO(数值型表达式)功能:给出指定的工作区中打开的数据库的当前记录号2)文件起始测试函数 BOF格式:BOF(数值型表达式)功能:测试指定的工作区中库文件记录指针是否指向起始位置是函数值为逻辑真(.T.),否则为假(.F.)3)文件结束测试函数 EOF格式:EOF(数值型表达式)功能:测试指定工作区中库文件记录指针是否指向结束位置是函数值为逻辑真(.T.),否则函数值为假(.F.)4)文件测试函数 FILE格式:FILE(文件名)功能:测试指定的磁盘文件是否存在,若存在,函数值为逻辑真(.T.),否则函数值为假(.F.)5)记录测试函数 RECOUNT格式:RECOUNT(数值型表达式)功能:测试指定的工作区中数据库的记录个数6)数据类型测试函数 TYPE TYPE(“字符表达式”)返回表达式类型,,如 N,C,D。

下载提示
相似文档
正为您匹配相似的精品文档
相关文档