vb常用函数与语句
第一篇:vb常用函数与语句
SQL语句常用函数
、字符转换函数
1、ASCII()
返回字符表达式最左端字符的ASCII 码值。在ASCII()函数中,纯数字的字符串可不用‘’括起来,但含其它字符的字符串必须用‘’括起来使用,否则会出错。
2、CHAR()
将ASCII 码转换为字符。如果没有输入0 ~ 255 之间的ASCII 码值,CHAR() 返回NULL 。
3、LOWER()和UPPER()
LOWER()将字符串全部转为小写;UPPER()将字符串全部转为大写。
4、STR()
把数值型数据转换为字符型数据。
STR ([,length[, ]])
length 指定返回的字符串的长度,decimal 指定返回的小数位数。如果没有指定长度,缺省的length 值为10, decimal 缺省值为0。
当length 或者decimal 为负值时,返回NULL;
当length 小于小数点左边(包括符号位)的位数时,返回length 个*; 先服从length ,再取decimal ;
当返回的字符串位数小于length ,左边补足空格。
二、去空格函数
1、LTRIM() 把字符串头部的空格去掉。
2、RTRIM() 把字符串尾部的空格去掉。
三、取子串函数
1、left()
LEFT (, )
返回character_expression 左起 integer_expression 个字符。
2、RIGHT()
RIGHT (, )
返回character_expression 右起 integer_expression 个字符。
3、SUBSTRING()
SUBSTRING (, , length)
返回从字符串左边第starting_ position 个字符起length个字符的部分。
四、字符串比较函数
1、CHARINDEX()
返回字符串中某个指定的子串出现的开始位置。
CHARINDEX (<’substring_expression’>, )
其中substring _expression 是所要查找的字符表达式,expression 可为字符串也可为列名表达式。如果没有发现子串,则返回0 值。
此函数不能用于TEXT 和IMAGE 数据类型。
2、PATINDEX()
返回字符串中某个指定的子串出现的开始位置。
PATINDEX (<’%substring _expression%’>, )其中子串表达式前后必须有百分号“%”否则返回值为0。
与CHARINDEX 函数不同的是,PATINDEX函数的子串中可以使用通配符,且此函数可用于CHAR、 VARCHAR 和TEXT 数据类型。
五、字符串操作函数
1、QUOTENAME()
返回被特定字符括起来的字符串。
QUOTENAME (<’character_expression’>[, quote_ character]) 其中quote_ character 标明括字符串所用的字符,缺省值为“[]”。
2、REPLICATE()
返回一个重复character_expression 指定次数的字符串。
REPLICATE (character_expression integer_expression) 如果
integer_expression 值为负值,则返回NULL 。
3、REVERSE()
将指定的字符串的字符排列顺序颠倒。
REVERSE () 其中character_expression 可以是字符串、常数或一个列的值。
4、REPLACE()
返回被替换了指定子串的字符串。
REPLACE (, , ) 用string_expression3 替换在string_expression1 中的子串string_expression2。
5、SPACE()
返回一个有指定长度的空白字符串。
SPACE () 如果integer_expression 值为负值,则返回NULL 。
6、STUFF()
用另一子串替换字符串指定位置、长度的子串。
STUFF (, , ,)
如果起始位置为负或长度值为负,或者起始位置大于
character_expression1 的长度,则返回NULL 值。
如果length 长度大于character_expression1 中 start_ position 以右的长度,则character_expression1 只保留首字符。
六、数据类型转换函数
1、CAST()
CAST ( AS [ length ])
2、CONVERT()
CONVERT ([ length ], [, style])
1)data_type为SQL Server系统定义的数据类型,用户自定义的数据类型不能在此使用。
2)length用于指定数据的长度,缺省值为30。
3)把CHAR或VARCHAR类型转换为诸如INT或SAMLLINT这样的INTEGER类型、结果必须是带正号或负号的数值。
4)TEXT类型到CHAR或VARCHAR类型转换最多为8000个字符,即CHAR或VARCHAR数据类型是最大长度。
5)IMAGE类型存储的数据转换到BINARY或VARBINARY类型,最多为8000个字符。
6)把整数值转换为MONEY或SMALLMONEY类型,按定义的国家的货币单位来处理,如人民币、美元、英镑等。
7)BIT类型的转换把非零值转换为1,并仍以BIT类型存储。
8)试图转换到不同长度的数据类型,会截短转换值并在转换值后显示“+”,以标识发生了这种截断。
9)用CONVERT()函数的style 选项能以不同的格式显示日期和时间。style 是将DATATIME 和SMALLDATETIME 数据转换为字符串时所选用的由SQL Server 系统提供的转换样式编号,不同的样式编号有不同的输出格式。
七、日期函数
1、day(date_expression)
返回date_expression中的日期值
2、month(date_expression)
返回date_expression中的月份值
3、year(date_expression)
返回date_expression中的年份值
4、DATEADD()
DATEADD (, , )
返回指定日期date 加上指定的额外日期间隔number 产生的新日期。
5、DATEDIFF()
DATEDIFF (, , )
返回两个指定日期在datepart 方面的不同之处,即date2 超过date1的差距值,其结果值是一个带有正负号的整数值。
6、DATENAME()
DATENAME (, )
以字符串的形式返回日期的指定部分此部分。由datepart 来指定。
7、DATEPART()
DATEPART (, )
以整数值的形式返回日期的指定部分。此部分由datepart 来指定。 DATEPART (dd, date) 等同于DAY (date)
DATEPART (mm, date) 等同于MONTH (date)
DATEPART (yy, date) 等同于YEAR (date)
8、GETDATE()
以DATETIME 的缺省格式返回系统当前的日期和时间。
八、统计函数
AVG ( ) -返回的平均价值
count( ) -返回的行数
first( ) -返回第一个值
last( ) -返回最后一个值
max( ) -返回的最大价值
min( ) -返回最小的价值
total( ) -返回的总和
九、数学函数
abs(numeric_expr)求绝对值
ceiling(numeric_expr)取大于等于指定值的最小整数 exp(float_expr)取指数
floor(numeric_expr)小于等于指定值得最大整数 pi()3.1415926.........
power(numeric_expr,power)返回power次方
rand([int_expr])随机数产生器
round(numeric_expr,int_expr)安int_expr规定的精度四舍五入 sign(int_expr)根据正数,0,负数,,返回+1,0,-1 sqrt(float_expr)平方根
十、系统函数
suser_name()用户登录名
user_name()用户在数据库中的名字 user用户在数据库中的名字 show_role()对当前用户起作用的规则
db_name()数据库名object_name(obj_id) 数据库对象名
col_name(obj_id,col_id) 列名
col_length(objname,colname) 列长度
valid_name(char_expr)是否是有效标识符
第二篇:VB循环语句
注:被中括号(“[”、“]”)括起来的都是可选参数!
For Each ... Next 语句: 语句格式
For Each Variant In Collection Or Array
[Statement(s)]
[Exit For]
[Statement(s)] Next [Variant] 参数解释
Variant: 如果In后面是一个集合(Collection),Variant可以是任何数据类型的一个变量;如果In后面是一个数组(Array),Variant就只能是一个Variant变量。
Collection: 可以是任何一个对象集合。 Array: 可以是任何一个数组(Type数组除外)。 Statement(s): 可以是任何一句或多句语句。
Exit For: 可以强制退出循环体。 For Each ... Next 语句的作用
集合/数组里面有多少对象/多少维,For Each ... Next 语句就会执行多少次Statement(s)。
Do ... Loop 语句: 语句格式
Do [{While | Until} Condition]
[Statement(s)]
[Exit Do]
[Statement(s)] Loop [{While | Until} Condition] 参数解释
While: 如果While在Do后面,那么循环体一开始就会检查Condition的值,如果Condition的值为False,就退出循环体;否则,执行Statement(s);如果While在Loop后面,则在执行完第一次Statement(s)时才检查Condition的值,如果Condition的值为False,就退出循环体;否则,继续循环。
Until: 如果Until在Do后面,那么循环体一开始就会检查Condition的值,如果Condition的值为True,就退出循环体;否则,执行Statement(s);如果Until在Loop后面,则在执行完第一次Statement(s)时才检查Condition的值,如果Condition的值为True,就退出循环体;否则,继续循环。
Condition: 可以是任何一个表达式。 Statement(s): 可以是任何一句或多句语句。
Exit Do: 可以强制退出循环体。 Do ... Loop 语句的作用
重复循环Statement(s),直到Condition为True或False(在指定了While或Until的情况下)。
For ... Next 语句: 语句格式
For Counter = Start To End [Step Step]
[Statement(s)]
[Exit For]
[Statement(s)] Next [Counter] 参数解释
Counter: 可以是任何一个变量(但不能是Boolean或者是数组),用来做计数器。 Start: Counter的初值。 End: Counter的终值。
Step: Counter一次增加多少,默认为1。1次增加n: For ... = ... To ... Step n;1次减n: For ... = ... To ... Step -n。
Statement(s): 可以是任何一句或多句语句。
Exit For: 可以强制退出循环体。 For ... Next 语句的作用
重复执行((End - Counter) Step)次Statement(s)。
While ... Wend 语句: 语句格式
While Condition
[Statement(s)] Wend 参数解释
Condition: 可以是任何一个表达式。 Statement(s): 可以是任何一句或多句语句。
While ... Wend 语句的作用
重复执行语句,直到Condition不为True。
第三篇:VB数据库SQL语句学习
1.Select * from student查询所有原始记录
2. Select StudentID, StudentName from student 只查询学号和姓名
3. Select StudentID as 学号, StudentName as 姓名, Sex as 性别,Class as 班级,NormalScore as 平时成绩,ExperimentScore as 实验成绩, ExaminationScore as 考试成绩 from student
4. Select * from student where sex=’男’只需要查看男生的成绩
5. Select * from student where NormalScore>80只需要查看平时成绩大于80分的记录
6. Select * from student where studentname like ‘陈%’查询姓陈的同学的记录
7. Select * from student order by examinationScore根据考试成绩排序
8. Select * from student order by examinationScore排序---降序
9. Select Sum(examinationScore) as 总成绩 from student求总成绩
10. Select Avg(examinationScore) as 平均成绩 from student求平均成绩
11. Select count(*) as 总记录数 from student求总记录数
12. Select Max(ExaminationScore) as 最高分 from student求最高分
13. Select Min(ExaminationScore) as 最高低分 from student求最低分
14. Select Class as 班级, Avg(ExaminationScore) as 平均成绩 from student group by class各班级成绩的分类汇总
Public Class frmMain
Private ObjCnn As New OleDbConnection
Private ObjCmd As OleDbCommand
Private StrDir As String = "D:MIS1025StudentMgr.accdb"
Private Sub frmMain_Load(ByVal sender As System.Object, ByVal e As
System.EventArgs) Handles MyBase.Load
ObjCnn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" & StrDir
ObjCnn.Open()
ObjCmd = New OleDbCommand
ObjCmd.Connection = ObjCnn
End Sub
Private Sub FindRecord(ByVal StrSQL As String)
ObjCmd.CommandText = StrSQL
Dim rd As OleDbDataReader = ObjCmd.ExecuteReader
Dim tbl As New DataTable
tbl.Load(rd)
DataGridView1.DataSource = tbl
End Sub
Private Sub CmdFind_Click(ByVal sender As System.Object,
System.EventArgs) Handles CmdFind.Click
FindRecord(txtSQL.Text)
End Sub ByVal e As
第四篇:常用Excel函数
一、与求和有关的函数的应用
SUM函数是Excel中使用最多的函数,利用它进行求和运算可以忽略存有文本、空格等数据的单元格,语法简单、使用方便。相信这也是大家最先学会使用的Excel函数之一。但是实际上,Excel所提供的求和函数不仅仅只有SUM一种,还包括SUBTOTAL、SUM、SUMIF、SUMPRODUCT、SUMSQ、SUMX2MY
2、SUMX2PY
2、SUMXMY2几种函数。
这里笔者将以某单位工资表为例重点介绍SUM(计算一组参数之和)、SUMIF(对满足某一条件的单元格区域求和)的使用。(说明:为力求简单,示例中忽略税金的计算。) SUM
1、行或列求和
以最常见的工资表(如上图)为例,它的特点是需要对行或列内的若干单元格求和。 比如,求该单位2001年5月的实际发放工资总额,就可以在H13中输入公式: =SUM(H3:H12)
2、区域求和
区域求和常用于对一张工作表中的所有数据求总计。此时你可以让单元格指针停留在存放结果的单元格,然后在Excel编辑栏输入公式"=SUM()",用鼠标在括号中间单击,最后拖过需要求和的所有单元格。若这些单元格是不连续的,可以按住Ctrl键分别拖过它们。对于需要减去的单元格,则可以按住Ctrl键逐个选中它们,然后用手工在公式引用的单元格前加上负号。当然你也可以用公式选项板完成上述工作,不过对于SUM函数来说手工还是来的快一些。比如,H13的公式还可以写成: =SUM(D3:D12,F3:F12)-SUM(G3:G12)
3、注意
SUM函数中的参数,即被求和的单元格或单元格区域不能超过30个。换句话说,SUM函数括号中出现的分隔符(逗号)不能多于29个,否则Excel就会提示参数太多。对需要参与求和的某个常数,可用"=SUM(单元格区域,常数)"的形式直接引用,一般不必绝对引用存放该常数的单元格。 SUMIF
SUMIF函数可对满足某一条件的单元格区域求和,该条件可以是数值、文本或表达式,可以应用在人事、工资和成绩统计中。
仍以上图为例,在工资表中需要分别计算各个科室的工资发放情况。 要计算销售部2001年5月加班费情况。则在F15种输入公式为 =SUMIF($C$3:$C$12,"销售部",$F$3:$F$12) 其中"$C$3:$C$12"为提供逻辑判断依据的单元格区域,"销售部"为判断条件即只统计$C$3:$C$12区域中部门为"销售部"的单元格,$F$3:$F$12为实际求和的单元格区域。
二、常见数学函数使用技巧--四舍五入
在实际工作的数学运算中,特别是财务计算中常常遇到四舍五入的问题。虽然,excel的单元格格式中允许你定义小数位数,但是在实际操作中,我们发现,其实数字本身并没有真正的四舍五入,只是显示结果似乎四舍五入了。如果采用这种四舍五入方法的话,在财务运算中常常会出现几分钱的误差,而这是财务运算不允许的。那是否有简单可行的方法来进行真正的四舍五入呢?其实,Excel已经提供这方面的函数了,这就是ROUND函数,它可以返回某个数字按指定位数舍入后的数字。
在Excel提供的"数学与三角函数"中提供了一个名为ROUND(number,num_digits)的函数,它的功能就是根据指定的位数,将数字四舍五入。这个函数有两个参数,分别是number和num_digits。其中number就是将要进行四舍五入的数字;num_digits则是希望得到的数字的小数点后的位数。如图3所示:
单元格B2中为初始数据0.123456,B3的初始数据为0.234567,将要对它们进行四舍五入。在单元格C2中输入"=ROUND(B2,2)",小数点后保留两位有效数字,得到0.
12、0.23。在单元格D2中输入"=ROUND(B2,4)",则小数点保留四位有效数字,得到0.12
35、0.2346。
对于数字进行四舍五入,还可以使用INT(取整函数),但由于这个函数的定义是返回实数舍入后的整数值。因此,用INT函数进行四舍五入还是需要一些技巧的,也就是要加上0.5,才能达到取整的目的。仍然以图3为例,如果采用INT函数,则C2公式应写成:"=INT(B2*100+0.5)/100"。
最后需要说明的是:本文所有公式均在Excel97和Excel2000中验证通过,修改其中的单元格引用和逻辑条件值,可用于相似的其他场合。 附注:Excel的数学和三角函数一览表
ABS 工作表函数 返回参数的绝对值 ACOS 工作表函数 返回数字的反余弦值 ACOSH 工作表函数 返回参数的反双曲余弦值 ASIN 工作表函数 返回参数的反正弦值 ASINH 工作表函数 返回参数的反双曲正弦值 ATAN 工作表函数 返回参数的反正切值 ATAN2 工作表函数
返回给定的 X 及 Y 坐标值的反正切值 ATANH 工作表函数 返回参数的反双曲正切值 CEILING 工作表函数
将参数 Number 沿绝对值增大的方向,舍入为最接近的整数或基数 COMBIN 工作表函数
计算从给定数目的对象集合中提取若干对象的组合数 COS 工作表函数 返回给定角度的余弦值 COSH 工作表函数 返回参数的双曲余弦值 COUNTIF 工作表函数
计算给定区域内满足特定条件的单元格的数目 DEGREES 工作表函数 将弧度转换为度 EVEN 工作表函数
返回沿绝对值增大方向取整后最接近的偶数 EXP 工作表函数
返回 e 的 n 次幂常数 e 等于 2.71828182845904,是自然对数的底数 FACT 工作表函数
返回数的阶乘,一个数的阶乘等于 1*2*3*...*该数 FACTDOUBLE 工作表函数 返回参数 Number 的半阶乘 FLOOR 工作表函数
将参数 Number 沿绝对值减小的方向去尾舍入,使其等于最接近的 significance 的倍数 GCD 工作表函数
返回两个或多个整数的最大公约数 INT 工作表函数 返回实数舍入后的整数值 LCM 工作表函数 返回整数的最小公倍数 LN 工作表函数
返回一个数的自然对数自然对数以常数项 e(2.71828182845904)为底 LOG 工作表函数
按所指定的底数,返回一个数的对数 LOG10 工作表函数 返回以 10 为底的对数 MDETERM 工作表函数 返回一个数组的矩阵行列式的值 MINVERSE 工作表函数 返回数组矩阵的逆距阵 MMULT 工作表函数 返回两数组的矩阵乘积结果 MOD 工作表函数
返回两数相除的余数结果的正负号与除数相同 MROUND 工作表函数
返回参数按指定基数舍入后的数值 MULTINOMIAL 工作表函数
返回参数和的阶乘与各参数阶乘乘积的比值 ODD 工作表函数
返回对指定数值进行舍入后的奇数 PI 工作表函数
返回数字 3.14159265358979,即数学常数 pi,精确到小数点后 15 位 POWER 工作表函数 返回给定数字的乘幂 PRODUCT 工作表函数
将所有以参数形式给出的数字相乘,并返回乘积值 QUOTIENT 工作表函数
回商的整数部分,该函数可用于舍掉商的小数部分 RADIANS 工作表函数 将角度转换为弧度 RAND 工作表函数
返回大于等于 0 小于 1 的均匀分布随机数 RANDBETWEEN 工作表函数 返回位于两个指定数之间的一个随机数 ROMAN 工作表函数
将阿拉伯数字转换为文本形式的罗马数字 ROUND 工作表函数
返回某个数字按指定位数舍入后的数字 ROUNDDOWN 工作表函数
靠近零值,向下(绝对值减小的方向)舍入数字 ROUNDUP 工作表函数
远离零值,向上(绝对值增大的方向)舍入数字 SERIESSUM 工作表函数 返回基于以下公式的幂级数之和: SIGN 工作表函数
返回数字的符号当数字为正数时返回 1,为零时返回 0,为负数时返回 -1 SIN 工作表函数 返回给定角度的正弦值 SINH 工作表函数 返回某一数字的双曲正弦值 SQRT 工作表函数 返回正平方根 SQRTPI 工作表函数
返回某数与 pi 的乘积的平方根 SUBTOTAL 工作表函数
返回数据清单或数据库中的分类汇总 SUM 工作表函数
返回某一单元格区域中所有数字之和 SUMIF 工作表函数
根据指定条件对若干单元格求和 SUMPRODUCT 工作表函数
在给定的几组数组中,将数组间对应的元素相乘,并返回乘积之和 SUMSQ 工作表函数 返回所有参数的平方和 SUMX2MY2 工作表函数
返回两数组中对应数值的平方差之和 SUMX2PY2 工作表函数
返回两数组中对应数值的平方和之和,平方和加总在统计计算中经常使用 SUMXMY2 工作表函数
返回两数组中对应数值之差的平方和 TAN 工作表函数 返回给定角度的正切值 TANH 工作表函数 返回某一数字的双曲正切值 TRUNC 工作表函数
将数字的小数部分截去,返回整数
希望能帮到您!
第五篇:Excel的常用函数
VLOOKUP纵向查找函数«
=VLOOKUP(要查找的值,要查找的区域,返回数据在查找区域的第几列数,模糊匹配) VLOOKUP最容易出错的地方是查找区域的首列必须含有查找的内容。
注意:第二个参数“要查找的区域”,要使用绝对引用符号$,如$A$3:$C$20 例如:如下图所示,要求根据表二中的姓名,查找姓名所对应的年龄。
B13=VLOOKUP(A13,$B$2:$D$8,3,0)
If判断函数
=IF(条件表达式,表达式为真时执行,表达式为假时执行) 例如:如果数字小于等于100,则公式将显示“Withinbudget”。否则,公式显示“Overbudget”。
=IF(A2<=100,"Withinbudget","Overbudget")
Mid返回文本字符串中从指定位置开始的特定数目的字符
=MID(字符串,起始位置,长度) =MID(A2,1,5)从第一个字符开始的5个字符 =MID(A2,7,20)从第七个字符开始的20个字符
Value将数字的文本字符串转换成数字
=Value(文本) 例如=Value("001")得到数字1。
LEFT返回文本字符串中第一个字符或前几个字符
=LEFT(文本,返回的字符数) LEFT(A2,4)返回A2单元格的前4个字符。
ROUND按指定位数取整后的数字。«
=Round(需要进行四舍五入的数字,指定的位数) 指定的位数大于0,则四舍五入到指定的小数位。指定的位数等于0,则四舍五入到最接近的整数。
指定的位数小于0,则在小数点左侧进行四舍五入。 =Round(3.4567,2)返回3.46 相近的函数,Roundup(向上取整),Rounddown(向下取整)
=MOD(被除数,除数)
如MOD(5,2),得1
INT将数字向下舍入到最接近的整数
=INT(8.9)将8.9向下舍入到最接近的整数(8) =INT(-8.9)将-8.9向下舍入到最接近的整数(-9)
NUMBERSTRING正整数转大写
=NUMBERSTRING(要转化的数字,返回结果的类型) 返回结果的类型有
1、
2、3共三种,其中:1为汉字小写,2为汉字大写,3为汉字读数。
=NumberString(1234567890,1)结果为:一十二亿三千四百五十六万七千八百九十
=NumberString(1234567890,2)结果为:壹拾贰亿叁仟肆佰伍拾陆万柒仟捌佰玖拾
=NumberString(1234567890,3)结果为:一二三四五六七八九○
TODAY显示当前计算机系统设置的日期,年月日
WEEKDAY返回某个日期是一周中的星期几«
=WEEKDAY(日期,返回类型) 返回类型决定一周中哪一天开始的数字。默认值为1 返回类型1或省略:代表数字1(星期日)到数字7(星期六)。 返回类型2:代表数字1(星期一)到数字7(星期日)。 返回类型3:代表数字0(星期一)到数字6(星期日)。 =WEEKDAY("2001/8/28",2)返回2(星期二) =WEEKDAY("2003/02/23",3)返回6(星期日)
MONTH返回日期值中的月份
=MONTH("2000/5/20")返回5 =MONTH("2000年5月20日")返回5
DATEDIF计算两个日期间隔的函数«
=DATEDIF(起始日期,终结日期,返回类型)
起始日期、终结日期可以为任意合法的日期格式,或者单元格数值。
返回类型有下面几种:"Y"时间段中的整年数。"M"时间段中的整月数。"D"时间段中的天数。
"MD"日期中天数的差。忽略日期中的月和年。"YM"日期中月数的差。忽略日期中的日和年。
"YD"日期中天数的差。忽略日期中的年。 =DATEDIF("2005-5-3","2008-11-28","Y") 返回2008-5-3到2008-11-28之间的年数,