53.为了防止多次数据库 *** 作导致数据库不完整( )我们可以使用(colse)
54. connection 对象为我们提供了三个与事务相关的方法,请写上它们:开启事务:(connedtion.begintrans ),结束事务并保有更改:
connection(.committrans ),结束事务并却小更改:connection(.rollbacktrans )
55.如果我们查得到数据表中某个字段的信息需要用recordset对象的(fields )集合中的(name )对象。
56.取得field对象的方法是:set field=recordset.fields.item(i),我们可以通过field对象的(name)属性得到字段名,还可以通过(
type)属性得到字段的类型。
57.我们可以在记录集内移动指针,以便 *** 作不同的数据记录,如果我们要将指针移到最后一条记录,可以使用(recordset.movelast )方法
,将指针移到首记录使用(recordset.movefirst )方法,移动到上一条记录使用(recordset.previous )方法,移动到下一条记录可使用(
recordset.movenext )方法。
58.删除记录,我们可以直接使用SQL语句中的delete语句,也可以将记录查询到之后使用recordset对象的( delete)方法来删除当前记录。
虽然直接使用Delete语句删除记录非常方便,但有时对于一些需要进行复杂判断才决定是否删除记录的情况下,我们还是要使用recordset对象
的(delete )方法来删除记录。
59.更新一条记录除可以使用update语句外,还可以将记录查询到之后,改变各字段的值,然后使用recordset对象的( addnew )方法来更新
数据。虽然直接使用update语句更新数据十分方便,但有时对于需要进行一些不规则更新的时候还是要使用到recordset对象的(addnew )方
法来更新数据记录。
在数据库应用的设计中 我们往往会需要获取某些表的记录总数 用于判断表的记录总数是否过大 是否需要备份数据等 我们通常的做法是 select count(*) as c from tableA 然而对于记录数巨大的表 上述做法将会非常耗时 在DELL 服务器上做试验 MS Sqlserver 数据库对于 万记录的简单数据表执行上述语句 时间在 分钟以上 如果在表的某个字段上做聚簇索引 第一次执行该语句的时间和没有索引的时间差不多 之后执行上述语句 速度很快 在 秒中以内 但当表的记录数发生较大变化后 再执行该语句又会经历一次耗时的过程 而且不是每个表都适合做聚簇索引的 对于数量巨大的表 如果需要经常增删 *** 作 建聚簇索引是一个很不明智的做法 将会极大的影响增删的速度 那么有没有一个比较简单的方法快速获取表的记录总数呢?答案是有的
在MS SQL 数据库中每个表都在sysindexes 系统表中拥有至少一条记录 该记录中的rows 字段会定时记录表的记录总数 下面是sysindexes 表的相关记录的含义
列名 数据类型描述
id int 表ID(如果 indid = 或 ) 否则为索引所属表的ID
Indid *** allint 索引ID
=表
=聚簇索引
>=非聚簇索引
=具有text或image数据的表条目
rows int 基于indid= 和 indid= 地数据级行数 该值对于indid>重复 如果indid= rows设置为
当表没有聚簇索引时 Indid = 否则为
那么现在大家应该知道如何获取表的记录总数了 只需执行如下语句
select rows from sysindexes where id = object_id(tablename) and indid in ( )
lishixinzhi/Article/program/SQL/201311/16342sql中查询记录数用count函数。
1、创建测试表,插入数据:
create table test
(id int)
insert into test values (1)
insert into test values (2)
insert into test values (3)
insert into test values (null)2、查询记录数为两种,一种是count(*),一种是count(字段值):
测试一:
select count(*) from test结果:
测试二:
select count(id) from test结果:
说明:如果count(字段名)的字段中含有空值,则在count中不计数,而count(*)则是查询全部的行数。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)