如何使用打印机_如何使用ADO.NET轻松操纵数据库
【shitiku.jxxyjl.com--软件水平学习指南】
ado.net提供了connection来连接数据库,同时也提供了command对象来查询数据库。同connection对象一样,command也有两种:oledbcommand和sqlcommand.其区别同connection对象。要操纵数据库,必须先使用connection来连接到数据库,再创建一个command来查询。有几种创建方式,例:
sqlcommand cmd;
string strcon="server=localhost;database=northwind;trusted_connection=yes;";
string strqry="select * from categories";
sqlconnection con=new sqlconnection(strcon);
con.open();
¹cmd=con.createcommand(); //这里使用用connection对象的createcommand方法来创建一个command对象。
cmd.commandtext=strqry;
// sqldatareader reader=cmd.executereader();
² cmd=new sqlcommand(); //直接使用new 关键字来创建
cmd.commandtext=strqry;
cmd.connection=con; //设置与数据库的连接
³cmd=new sqlcommand(strqry,con); //直接在new的时候带两个参数来创建
执行方式:
(主要有这么几种,cmd.executereader();cmd.executenonquery();cmd.executescalar();cmd.executexmlreader();)
1,executereader();返回一个sqldatareader对象或oledbdatareader对象,这个看你的程序的需要去 做。可以通过这个对象来检查查询结果,它提供了“游水”式的执行方式,即从结果中读取一行之后,移动到另一行,则前一行就无法再用。有一点要注意的是执行之后,要等到手动去调用read()方法之后,datareader对象才会移动到结果集的第一行,同时此方法也返回一个bool值,表明下一行是否可用,返回true则可用,返回false则到达结果集末尾。
使用datareader可以提高执行效率,有两种方式可以提高代码的性能:一种是基于序号的查找,一个是使用适当的get方法来查找。因为查询出来的结果一般都不会改变,除非再次改动查询语句,因此可以通过定位列的位置来查找记录。用这种方法有一个问题,就是可能知道一列的名称而不知道其所在的位置,这个问题的解决方案是通过调用datareader 对象的getordinal()方法,此方法接收一个列名并返回此列名所在牧泻拧@?
int id=reader.getordinal("categoryname");
while(reader.read())
{
response.write(reader[id]);
}
reader.close();
劣诘诙址绞胶苤惫郏?
while(reader.read())
{
response.write(reader.getint32(0).tostring() " " reader.getstring(1).tostring() " < br>");
}
datareader的getint32()和getstring()通过接收一个列号来返回一个列的值,这两种是最常用的,其中 还有很多其它的类型。
(注:datareader对象在调用close()方法即关闭与数据库的连接,如果在没有关闭之前又重新打开第二个连接,则会产生一条异常信息)
2.,executenonquery() 这个方法并不返回一个datareader对象,而是返回一个int类型的值,即在执行之后在数据库中所影响的行数。
例:
int affectrows=cmd.executenonquery();
response.write(affectrows " 条记录受影响");
3,executescalar() 这个方法不接受任何参数,仅仅返回查询结果集中的第一行第一列,而忽略了其它的行和列,而且返回的是一个object类型,在使用之前必须先将它强制转换为所需类型。如果返回的仅仅是一个单独的数据元,则可以使用此方法来提高代码的性能。例:
string strcon="server=localhost;database=northwind;trusted_connection=yes;";
string strqry="select count(*) from categories";
sqlconnection con=new sqlconnection(strcon);
con.open();
sqlcommand cmd=con.createcommand();
int i=convert.toint32(cmd.executescalar()); //必须强制转换
4,executexmlreader() 此方法用于xml操作,返回一个xmlreader对象,由于系统默认没有引用 system.xml名空间,因此在使用前必须前引入。例:
string strcon="server=localhost;database=northwind;trusted_connection=yes;";
sqlconnection con=new sqlconnection(strcon);
con.open();
sqlcommand cmd = new sqlcommand("select * from categories for xml auto, xmldata", con);
xmlreader xr=cmd.executexmlreader();
response.write(xr.attributecount); //这里获取当前节点上的属性个数
xr.close();
执行完毕之后,照样要显式地调用close()方法,否则会抛出异常。
使用参数化的查询
先看一段sql语句:select categoryid,description from categories where categoryid=? 其中的问号就是一个参数。但在使用的时候必须是带有@前缀的命名参数,因为.net数据提供程序不支持这个通用的参数标记“?”.使用参数化的查询可以大大地简化编程,而且执行效率也比直接查询字符串要高,也更方便,很多情况下都需要更改查询字符串,这种方式就提供了方便,只需更改参数的值即可。例:
string strcon="server=localhost;database=northwind;trusted_connection=yes;";
sqlconnection con=new sqlconnection(strcon);
con.open();
string strqry="select * from categories where categoryid=@categoryid"; //带参数的查询
sqlcommand cmd=new sqlcommand(strqry,con);
cmd.parameters.add("@categoryid",sqldbtype.int,4); //给参数赋于同数据库中相同的类型
cmd.parameters["@categoryid"].value="3"; //给参数赋值,可灵活改变
sqldatareader r=cmd.executereader();
while(r.read())
{
response.write(r.getstring(2) "< br>"); //取出指定参数列的值
}
con.close(); //切记关闭
ado.net提供了connection来连接数据库,同时也提供了command对象来查询数据库。同connection对象一样,command也有两种:oledbcommand和sqlcommand.其区别同connection对象。
要操纵数据库,必须先使用connection来连接到数据库,再创建一个command来查询。有几种创建方式,例:
sqlcommand cmd;
string strcon="server=localhost;database=northwind;trusted_connection=yes;";
string strqry="select * from categories";
sqlconnection con=new sqlconnection(strcon);
con.open();
¹cmd=con.createcommand(); //这里使用用connection对象的createcommand方法来创建一个command对象。
cmd.commandtext=strqry;
// sqldatareader reader=cmd.executereader();
² cmd=new sqlcommand(); //直接使用new 关键字来创建
cmd.commandtext=strqry;
cmd.connection=con; //设置与数据库的连接
³cmd=new sqlcommand(strqry,con); //直接在new的时候带两个参数来创建
执行方式:
(主要有这么几种,cmd.executereader();cmd.executenonquery();cmd.executescalar();cmd.executexmlreader();)
1,executereader();返回一个sqldatareader对象或oledbdatareader对象,这个看你的程序的需要去 做。可以通过这个对象来检查查询结果,它提供了“游水”式的执行方式,即从结果中读取一行之后,移动到另一行,则前一行就无法再用。有一点要注意的是执行之后,要等到手动去调用read()方法之后,datareader对象才会移动到结果集的第一行,同时此方法也返回一个bool值,表明下一行是否可用,返回true则可用,返回false则到达结果集末尾。
本文来源:https://shitiku.jxxyjl.com/ruanjianshuipingxuexizhinan/49051.html
-
445端口常见漏洞|常见端口的作用、漏洞和操作建议(2)详细阅读
21端口:21端口主要用于ftp(file transfer protocol,文件传输协议)服务。 端口说明:21端口主要用于ftp(file transfer protocol,文件传输协议)服务,ftp服务主要是为了在两台计算机之间实现文件的上传与下载,一台计算机作为ftp客户...
-
如何使用打印机_如何使用ADO.NET轻松操纵数据库详细阅读
ado net提供了connection来连接数据库,同时也提供了command对象来查询数据库。同connection对象一样,command也有两种:oledbcommand和sqlcommand 其区别同connection对象。 要操纵数据库,必须先使用connect...
-
软考考前卖答案_软考考前心理调整八种方法详细阅读
随软考的临近,不知道是不是有考生会很紧张,出现以下症状:对考试产生害怕、忧虑、不安等情绪,对考试结果缺乏信心,精神处于高度紧张状态,有时还伴有头痛、失眠、食欲不振、脾气暴躁、焦躁不安、注意力不集中、头脑发木等反应,甚至对考试产生严重的恐惧感。这就是我们常说的考试焦虑。心理学研究表明,...
-
[程序员逻辑思维培养]职业程序员培养之道详细阅读
软件开发是以人为核心的过程,对人的依赖性远高于传统的硬件生产企业,为了保持开发能力的稳定性,一方面需要定义软件过程,以过程为枢纽将人、技术、工具衔接起来,另一方面也要加强人才的培养,使人的工作能力能够稳定、提高人员的自治性。随着社会需求的膨胀,对程序员的需求量、对熟练的程序员的需求量在剧...
-
【指针万用表的使用方法】C++指针使用方法解惑详细阅读
c++指针使用方法解惑 void clearlist(lnode * & hl) 仔细看一下这种声明方式,确实有点让人迷惑。 下面以 void func1( myclass *&pbuildingelement ); 为例来说明这个问题。在某种意义上,*和&是意思相对的两个东西,把它们放在...
-
【ctoc模式什么意思】CtoC++新手指南详细阅读
c++技术固然是很时髦的,许多c用户都想在尽可能短的时间内为自己贴上c++的标签。介绍c++的书很多,但只有那些已经侥幸入门的用户才偶尔去翻翻,仍有不少在c++门口徘徊的流浪汉。 本文只针对c用户,最好是一位很不错的老用户(譬如他在遇到最简单的问题时都尝试着使用指针),通过一些c和更好的c++(本文...
-
线性表的顺序实现_使用C++实现线性表的基本功能详细阅读
include include include typedef int elemtype; 线性表的基本操作void initiallist(elemtype *l); int isempty(elemtype *l);void l...
-
计算机软件水平考试与计算机四级|计算机软件水平考试:《数据结构》是核心详细阅读
从2004年起,计算机与软件考试纳入全国专业技术人员职业资格证书制度的统一规划,报考任何级别的考生都不受学历、资历限制,这使得该考试报考人数骤增。而20%通过率无疑使该考试的竞争非常激烈,怎样能顺利通过考试已成为广大参考人员的热门话题。 为了让考生更好的备考,我们特走访了多位已经通过考试的朋...
-
软考 软考_软考专家谈软考趋势和复习要点详细阅读
2005 年上半年全国计算机技术与软件专业技术资格(水平)考试(简称软考)报考人数最多的专业级别是软件设计师和程序员。这两个级别是软件考试中最经典、考题最稳定和考生最多的级别,同时也是社会认同度最高的两个级别。近年来,随着信息技术的发展,考试内容的重点已作较大调整,考试更能体现出技术的进...
-
[路由器与交换机的主要区别]深入了解路由器与交换机的区别3详细阅读
2 负载集中:交换机之间只能有一条通路,使得信息集中在一条通信链路上,不能进行动态分配,以平衡负载。而路由器的路由协议算法可以避免这一点,ospf路由协议算法不但能产生多条路由,而且能为不同的网络应用选择各自不同的最佳路由。 3 广播控制:交换机只能缩小冲突域,而不能缩小广播域。整个交换...