




已阅读5页,还剩66页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第九讲,1,PPT学习交流,课题JDBC与数据库(原理、JDBC与数据库的连接)目的要求掌握JDBC的基本概念及JDBC类的的基本方法教学重点JDBC的概念、JDBC驱动程序的类型及与数据库的连接教学难点JDBC与不同数据库的连接与处理教学课时4(含2课时上机)教学方法讲解、示例与启发式教学相结合,2,PPT学习交流,教学内容和步骤9.1JDBC与数据库9.1.1什么是JDBCTM?JDBCTM是一种用于执行SQL语句的JavaTMAPI(有意思的是,JDBC本身是个商标名而不是一个缩写字;然而,JDBC常被认为是代表“Java数据库连接(JavaDatabaseConnectivity)”)。它由一组用Java编程语言编写的类和接口组成。JDBC为工具/数据库开发人员提供了一个标准的API,使他们能够用纯JavaAPI来编写数据库应用程序。,3,PPT学习交流,有了JDBC,向各种关系数据库发送SQL语句就是一件很容易的事。换言之,有了JDBCAPI,就不必为访问Sybase数据库专门写一个程序,为访问Oracle数据库又专门写一个程序,为访问Informix数据库又写另一个程序,等等。您只需用JDBCAPI写一个程序就够了,它可向相应数据库发送SQL语句。而且,使用Java编程语言编写的应用程序,就无须去忧虑要为不同的平台编写不同的应用程序。将Java和JDBC结合起来将使程序员只须写一遍程序就可让它在任何平台上运行。,4,PPT学习交流,Java具有坚固、安全、易于使用、易于理解和可从网络上自动下载等特性,是编写数据库应用程序的杰出语言。所需要的只是Java应用程序与各种不同数据库之间进行对话的方法。而JDBC正是作为此种用途的机制。,5,PPT学习交流,JDBC扩展了Java的功能。例如,用Java和JDBCAPI可以发布含有applet的网页,而该applet使用的信息可能来自远程数据库。企业也可以用JDBC通过Intranet将所有职员连到一个或多个内部数据库中(即使这些职员所用的计算机有Windows、Macintosh和UNIX等各种不同的操作系统)。随着越来越多的程序员开始使用Java编程语言,对从Java中便捷地访问数据库的要求也在日益增加。,6,PPT学习交流,MIS管理员们都喜欢Java和JDBC的结合,因为它使信息传播变得容易和经济。企业可继续使用它们安装好的数据库,并能便捷地存取信息,即使这些信息是储存在不同数据库管理系统上。新程序的开发期很短。安装和版本控制将大为简化。程序员可只编写一遍应用程序或只更新一次,然后将它放到服务器上,随后任何人就都可得到最新版本的应用程序。对于商务上的销售信息服务,Java和JDBC可为外部客户提供获取信息更新的更好方法。,7,PPT学习交流,9.1.2JDBC的用途是什么?简单地说,JDBC可做三件事:与数据库建立连接,发送SQL语句,处理结果。下列代码段给出了以上三步的基本示例:,8,PPT学习交流,9,PPT学习交流,9.1.3JDBCAPI简介JDBC是个“低级”接口,也就是说,它用于直接调用SQL命令。在这方面它的功能极佳,并比其它的数据库连接API易于使用,但它同时也被设计为一种基础接口,在它之上可以建立高级接口和工具。高级接口是“对用户友好的”接口,它使用的是一种更易理解和更为方便的API,这种API在幕后被转换为诸如JDBC这样的低级接口。在编写本文时,正在开发两种基于JDBC的高级API:,10,PPT学习交流,一种用于Java的嵌入式SQL。至少已经有一个提供者计划编写它。DBMS实现SQL:一种专门设计来与数据库联合使用的语言。JDBC要求SQL语句必须作为String传给Java方法。相反,嵌入式SQL预处理器允许程序员将SQL语句直接与Java混在一起使用。例如,可在SQL语句中使用Java变量,用以接受或提供SQL值。然后,嵌入式SQL预处理器将通过JDBC调用把这种Java/SQL的混合物转换为Java。关系数据库表到Java类的直接映射。JavaSoft和其它提供者都声称要实现该API。在这种“对象/关系”映射中,表中的每行对应于类的一个实例,而每列的值对应于该实例的一个属性。于是,程序员可直接对Java对象进行操作;存取数据所需的SQL调用将在“掩盖下”自动生成。此外还可提供更复杂的映射,例如将多个表中的行结合进一个Java类中。,11,PPT学习交流,随着人们对JDBC的兴趣日益增涨,越来越多的开发人员一直在使用基于JDBC的工具,以使程序的编写更加容易。程序员也一直在编写力图使最终用户对数据库的访问变得更为简单的应用程序。例如,应用程序可提供一个选择数据库任务的菜单。任务被选定后,应用程序将给出提示及空白供填写执行选定任务所需的信息。所需信息输入后,应用程序将自动调用所需的SQL命令。在这样一种程序的协助下,即使用户根本不懂SQL的语法,也可以执行数据库任务。,12,PPT学习交流,JDBC与ODBC和其它API的比较目前,Microsoft的ODBC(开放式数据库连接)API可能是使用最广的、用于访问关系数据库的编程接口。它能在几乎所有平台上连接几乎所有的数据库。为什么Java不使用ODBC?对这个问题的回答是:Java可以使用ODBC,但最好是在JDBC的帮助下以JDBC-ODBC桥的形式使用,这一点我们稍后再说。现在的问题已变成:“为什么需要JDBC”?回答如下:ODBC不适合直接在Java中使用,因为它使用C语言接口。从Java调用本地C代码在安全性、实现、坚固性和程序的自动移植性方面都有许多缺点。,13,PPT学习交流,从ODBCAPI到JavaAPI的字面翻译是不可取的。例如,Java没有指针,而ODBC却对指针用得很广泛(包括很容易出错的指针void*)。您可以将JDBC想象成被转换为面向对象接口的ODBC,而面向对象的接口对Java程序员来说较易于接收。ODBC很难学。它把简单和高级功能混在一起,而且即使对于简单的查询,其选项也极为复杂。相反,JDBC尽量保证简单功能的简便性,而同时在必要时允许使用高级功能。启用“纯Java”机制需要象JDBC这样的JavaAPI。如果使用ODBC,就必须手动地将ODBC驱动程序管理器和驱动程序安装在每台客户机上。如果完全用Java编写JDBC驱动程序则JDBC代码在所有Java平台上(从网络计算机到大型机)都可以自动安装、移植并保证安全性。,14,PPT学习交流,总之,JDBCAPI对于基本的SQL抽象和概念是一种自然的Java接口。它建立在ODBC上而不是从零开始。因此,熟悉ODBC的程序员将发现JDBC很容易使用。JDBC保留了ODBC的基本设计特征;事实上,两种接口都基于X/OpenSQLCLI(调用级接口)。它们之间最大的区别在于:JDBC以Java风格与优点为基础并进行优化,因此更加易于使用。,15,PPT学习交流,最近,Microsoft又引进了ODBC之外的新API:RDO、ADO和OLEDB。这些设计在许多方面与JDBC是相同的,即它们都是面向对象的数据库接口且基于可在ODBC上实现的类。但在这些接口中,我们未看见有特别的功能使我们要转而选择它们来替代ODBC,尤其是在ODBC驱动程序已建立起较为完善的市场的情况下。它们最多也就是在ODBC上加了一种装饰而已。这并不是说JDBC不需要从其最初的版本再发展了;然而,我们觉得大部份的新功能应归入诸如前一节中所述的对象/关系映射和嵌入式SQL这样的高级API。,16,PPT学习交流,两层模型和三层模型JDBCAPI既支持数据库访问的两层模型,同时也支持三层模型。在两层模型中,Javaapplet或应用程序将直接与数据库进行对话。这将需要一个JDBC驱动程序来与所访问的特定数据库管理系统进行通讯。用户的SQL语句被送往数据库中,而其结果将被送回给用户。数据库可以位于另一台计算机上,用户通过网络连接到上面。这就叫做客户机/服务器配置,其中用户的计算机为客户机,提供数据库的计算机为服务器。网络可以是Intranet(它可将公司职员连接起来),也可以是Internet。,17,PPT学习交流,在三层模型中,命令先是被发送到服务的“中间层”,然后由它将SQL语句发送给数据库。数据库对SQL语句进行处理并将结果送回到中间层,中间层再将结果送回给用户。MIS主管们都发现三层模型很吸引人,因为可用中间层来控制对公司数据的访问和可作的的更新的种类。中间层的另一个好处是,用户可以利用易于使用的高级API,而中间层将把它转换为相应的低级调用。最后,许多情况下三层结构可提供一些性能上的好处。,18,PPT学习交流,到目前为止,中间层通常都用C或C+这类语言来编写,这些语言执行速度较快。然而,随着最优化编译器(它把Java字节代码转换为高效的特定于机器的代码)的引入,用Java来实现中间层将变得越来越实际。这将是一个很大的进步,它使人们可以充分利用Java的诸多优点(如坚固、多线程和安全等特征)。JDBC对于从Java的中间层来访问数据库非常重要。,19,PPT学习交流,SQL的一致性结构化查询语言(SQL)是访问关系数据库的标准语言。困难之处在于:虽然大多数的DBMS(数据库管理系统)对其基本功能都使用了标准形式的SQL,但它们却不符合最近为更高级的功能定义的标准SQL语法或语义。例如,并非所有的数据库都支持储存程序或外部连接,那些支持这一功能的数据库又相互不一致。人们希望SQL中真正标准的那部份能够进行扩展以包括越来越多的功能。但同时JDBCAPI又必须支持现有的SQL。,20,PPT学习交流,JDBCAPI解决这个问题的一种方法是允许将任何查询字符串一直传到所涉及的DBMS驱动程序上。这意味着应用程序可以使用任意多的SQL功能,但它必须冒这样的风险:有可能在某些DBMS上出错。事实上,应用程序查询甚至不一定要是SQL,或者说它可以是个为特定的DBMS设计的SQL的专用派生物(例如,文档或图象查)。,21,PPT学习交流,JDBC处理SQL一致性问题的第二种方法是提供ODBC风格的转义子句。转义语法为几个常见的SQL分歧提供了一种标准的JDBC语法。例如,对日期文字和已储存过程的调用都有转义语法。对于复杂的应用程序,JDBC用第三种方法来处理SQL的一致性问题。它利用DatabaseMetaData接口来提供关于DBMS的描述性信息,从而使应用程序能适应每个DBMS的要求和功能。,22,PPT学习交流,由于JDBCAPI将用作开发高级数据库访问工具和API的基础API,因此它还必须注意其所有上层建筑的一致性。“符合JDBC标准TM代表用户可依赖的JDBC功能的标准级别。要使用这一说明,驱动程序至少必须支持ANSISQL-2EntryLevel(ANSISQL-2代表美国国家标准局1992年所采用的标准。EntryLevel代表SQL功能的特定清单)。驱动程序开发人员可用JDBCAPI所带的测试工具包来确定他们的驱动程序是否符合这些标准。,23,PPT学习交流,“符合JDBC标准TM”表示提供者的JDBC实现已经通过了JavaSoft提供的一致性测试。这些一致性测试将检查JDBCAPI中定义的所有类和方法是否都存在,并尽可能地检查程序是否具有SQLEntryLevel功能。当然,这些测试并不完全,而且JavaSoft目前也无意对各提供者的实现进行标级。但这种一致性定义的确可对JDBC实现提供一定的可信度。随着越来越多的数据库提供者、连接提供者、Internet提供者和应用程序编程员对JDBCAPI的接受,JDBC也正迅速成为Java数据库访问的标准。,24,PPT学习交流,9.1.4JDBC产品在编写本文时,有几个基于JDBC的产品已开发完毕或正在开发中。当然,本节中的信息将很快成为过时信息。因此,有关最新的信息,请查阅JDBC的网站,可通过从以下URL开始浏览找到:JavaSoft提供三种JDBC产品组件,它们是Java开发工具包(JDK)的组成部份:,25,PPT学习交流,JDBC驱动程序管理器JDBC驱动程序管理器是JDBC体系结构的支柱。它实际上很小,也很简单;其主要作用是把Java应用程序连接到正确的JDBC驱动程序上,然后即退出。JDBC驱动程序测试工具包,26,PPT学习交流,JDBC驱动程序测试工具包为使JDBC驱动程序运行您的程序提供一定的可信度。只有通过JDBC驱动程序测试包的驱动程序才被认为是符合JDBC标准TM的。JDBC-ODBC桥。JDBC-ODBC桥使ODBC驱动程序可被用作JDBC驱动程序。它的实现为JDBC的快速发展提供了一条途径,其长远目标提供一种访问某些不常见的DBMS(如果对这些不常见的DBMS未实现JDBC)的方法。,27,PPT学习交流,9.1.5JDBC驱动程序的类型我们目前所知晓的JDBC驱动程序可分为以下四个种类:JDBC-ODBC桥加ODBC驱动程序:JavaSoft桥产品利用ODBC驱动程序提供JDBC访问。注意,必须将ODBC二进制代码(许多情况下还包括数据库客户机代码)加载到使用该驱动程序的每个客户机上。因此,这种类型的驱动程序最适合于企业网(这种网络上客户机的安装不是主要问题),或者是用Java编写的三层结构的应用程序服务器代码。,28,PPT学习交流,本地API-部份用Java来编写的驱动程序:这种类型的驱动程序把客户机API上的JDBC调用转换为Oracle、Sybase、Informix、DB2或其它DBMS的调用。注意,象桥驱动程序一样,这种类型的驱动程序要求将某些二进制代码加载到每台客户。,29,PPT学习交流,JDBC网络纯Java驱动程序:这种驱动程序将JDBC转换为与DBMS无关的网络协议,之后这种协议又被某个服务器转换为一种DBMS协议。这种网络服务器中间件能够将它的纯Java客户机连接到多种不同的数据库上。所用的具体协议取决于提供者。通常,这是最为灵活的JDBC驱动程序。有可能所有这种解决方案的提供者都提供适合于Intranet用的产品。为了使这些产品也支持Internet访问,它们必须处理Web所提出的安全性、通过防火墙的访问等方面的额外要求。几家提供者正将JDBC驱动程序加到他们现有的数据库中间件产品中。,30,PPT学习交流,本地协议纯Java驱动程序:这种类型的驱动程序将JDBC调用直接转换为DBMS所使用的网络协议。这将允许从客户机机器上直接调用DBMS服务器,是Intranet访问的一个很实用的解决方法。由于许多这样的协议都是专用的,因此数据库提供者自己将是主要来源,有几家提供者已在着手做这件事了。最后,我们预计第3、4类驱动程序将成为从JDBC访问数据库的首选方法。第1、2类驱动程序在直接的纯Java驱动程序还没有上市前将会作为过渡方案来使用。对第1、2类驱动程序可能会有一些变种,这些变种要求有连接器,但通常这些是更加不可取的解决方案。第3、4类驱动程序提供了Java的所有优点,包括自动安装(例如,通过使用JDBC驱动程序的appletapplet来下载该驱动程序)。,31,PPT学习交流,9.2JDBC常用类和方法9.2.1四种驱动程序概念JDBC-ODBCBridge桥接器型的驱动程序,这类驱动程序的特色是必须在使用者端的计算机上事先安装好ODBC驱动程序,然后通过JDBC-ODBC的调用方法,进而通过ODBC来存取数据库。作为JDK1.1后的一部分,是sun.jdbc.odbc包的一部分Application-JDBC-ODBCBridge-JDBC-ODBCLibrary-ODBCDriver-Database适用于快速的原型系统,没有提供JDBC驱动的数据库如Access,32,PPT学习交流,JDBC-NativeAPIBridge也是桥接器驱动程序之一,这类驱动程序也必须先在使用者计算机上先安装好特定的驱动程序(类似ODBC),然后通过JDBC-NativeAPI桥接器的转换,把JavaAPI调用转换成特定驱动程序的调用方法,进而存取数据库。利用开发商提供的本地库来直接与数据库通信。Application-JDBCDriver-NativeDatabaselibrary-Database比A类性能略好。,33,PPT学习交流,JDBC-middleware这类型的驱动程序最大的好处就是省去了在使用者计算机上安装任何驱动程序的麻烦,只需在服务器端安装好middleware,而middleware会负责所有存取数据库必要的转换。Application-JdbcDriver-javamiddleware-JDBCDriver-Database具有最大的灵活性,通常由那些非数据库厂商提供,是四种类型中最小的。PureJDBCdriver这类型的驱动程序是最成熟的JDBC驱动程序,不但无需在使用者计算机上安装任何额外的驱动程序,也不需要在服务器端安装任何中介程序(middleware),所有存取数据库的操作,都直接由驱动程序来完成。,34,PPT学习交流,Application-Jdbcdriver-databaseengine-database最高的性能,通过自己的本地协议直接与数据库引擎通信,具备在Internet装配的能力。9.2.2常用的JDBC类与方法DriverManager类:负责管理JDBC驱动程序。使用JDBC驱动程序之前,必须先将驱动程序加载并向DriverManager注册后才可以使用,同时提供方法来建立与数据库的连接。方法:,35,PPT学习交流,Class.forName(Stringdriver);/加载注册驱动程序staticConnectiongetConnection(Stringurl,Stringuser,Stringpassword)throwsSQLException;/取得对数据库的连接StaticDrivergetDriver(Stringurl)throwsSQLExcetion;/在已经向DriverManager注册的驱动程序中寻找一个能够打开url所指定的数据库的驱动程序,36,PPT学习交流,Connection类负责维护JSP/JAVA数据库程序和数据库之间的联机。可以建立三个非常有用的类对象。方法:StatementcreateStatement()throwsSQLException;/建立Statement类对象StatementcreateStatement(intresultSetType,intresultSetConcurrency)throwsSQLException;/建立Statement类对象resultSetType值,37,PPT学习交流,TYPE_FORWARD_ONLY结果集不可滚动TYPE_SCROLL_INSENSITIVE结果集可滚动,不反映数据库的变化TYPE_SCROLL_SENSITIVE结果集可滚动,反映数据库的变化resultSetConcurrency值CONCUR_READ_ONLY不能用结果集更新数据CONCUR_UPDATABLE能用结果集更新数据JDBC2.0中才支持滚动的结果集,而且可以对数据进行更新,38,PPT学习交流,PreparedStatementprepareStatement(Stringsql)throwsSQLException;/建立PreparedStatement类对象booleangetAutoCommit()throwsSQLException/返回Connection类对象的AutoCommit状态voidsetAutoCommit(booleanautoCommit)throwsSQLException/设定Connection类对象的AutoCommit状态voidcommit()throwsSQLException/确定执行对数据库新增、删除或修改记录的操作,39,PPT学习交流,voidrollback()throwsSQLException/取消执行对数据库新增、删除或修改记录的操作voidclose()throwsSQLException/结束Connection对象对数据库的联机booleanisClosed()throwsSQLException/测试是否已经关闭Connection类对象对数据库的联机Statement类通过Statement类所提供的方法,可以利用标准的SQL命令,对数据库直接新增、删除或修改操作方法:,40,PPT学习交流,ResultSetexecuteQuery(Stringsql)throwsSQLException/使用SELECT命令对数据库进行查询intexecuteUpdate(Stringsql)throwsSQLException/使用INSERTDELETEUPDATE对数据库进行新增、删除和修改操作。voidclose()throwsSQLException/结束Statement类对象对数据库的联机,41,PPT学习交流,例1:access.jsp,43,PPT学习交流,PreparedStatement类PreparedStatement类和Statement类的不同之处在于PreparedStatement类对象会将传入的SQL命令事先编好等待使用,当有单一的SQL指令要多次执行时,用PreparedStatement类会比Statement类有效率方法:ResultSetexecuteQuery()throwsSQLException/使用SELECT命令对数据库进行查询,44,PPT学习交流,intexecuteUpdate()throwsSQLException/使用INSERTDELETEUPDATE对数据库进行新增、删除和修改操作。voidsetInt(intparameterIndex,intx)throwsSQLException/设定整数类型数值给PreparedStatement类对象的IN参数voidsetFloat(intparameterIndex,floatx)throwsSQLException/设定浮点数类型数值给PreparedStatement类对象的IN参数voidsetNull(intparameterIndex,intsqlType)throwsSQLException,45,PPT学习交流,/设定NULL类型数值给PreparedStatement类对象的IN参数voidsetString(intparameterIndex,Stringx)throwsSQLException/设定字符串类型数值给PreparedStatement类对象的IN参数voidsetDate(intparameterIndex,Datex)throwsSQLException/设定日期类型数值给PreparedStatement类对象的IN参数voidsetTime(intparameterIndex,Timex)throwsSQLException/设定时间类型数值给PreparedStatement类对象的IN参数,46,PPT学习交流,DatabaseMetaData类DatabaseMetadata类保存了数据库的所有特性,并且提供许多方法来取得这些信息。方法:StringgetDatabaseProductName()throwsSQLException/取得数据库名称StringgetDatabaseProductVersion()throwsSQLException/取得数据库版本代号StringgetDriverName()throwsSQLException/取得JDBC驱动程序的名称,47,PPT学习交流,StringgetDriverVersion()throwsSQLException/取得JDBC驱动程序的版本代号StringgetURL()throwsSQLException/取得连接数据库的JDBCURLStringgetUserName()throwsSQLException/取得登录数据库的使用者帐号,48,PPT学习交流,ResultSet类负责存储查询数据库的结果。并提供一系列的方法对数据库进行新增、删除和修改操作。也负责维护一个记录指针(Cursor),记录指针指向数据表中的某个记录,通过适当的移动记录指针,可以随心所欲的存取数据库,加强程序的效率。方法:booleanabsolute(introw)throwsSQLException/移动记录指针到指定的记录voidbeforeFirst()throwsSQLException/移动记录指针到第一笔记录之前,49,PPT学习交流,voidafterLast()throwsSQLException/移动记录指针到最后一笔记录之后booleanfirst()throwsSQLException/移动记录指针到第一笔记录booleanlast()throwsSQLException/移动记录指针到最后一笔记录booleannext()throwsSQLException/移动记录指针到下一笔记录booleanprevious()throwsSQLException/移动记录指针到上一笔记录,50,PPT学习交流,voiddeleteRow()throwsSQLException/删除记录指针指向的记录voidmoveToInsertRow()throwsSQLException/移动记录指针以新增一笔记录voidmoveToCurrentRow()throwsSQLException/移动记录指针到被记忆的记录voidinsertRow()throwsSQLException/新增一笔记录到数据库中voidupdateRow()throwsSQLException/修改数据库中的一笔记录,51,PPT学习交流,voidupdate类型(intcolumnIndex,类型x)throwsSQLException/修改指定字段的值intget类型(intcolumnIndex)throwsSQLException/取得指定字段的值ResultSetMetaDatagetMetaData()throwsSQLException/取得ResultSetMetaData类对象ResultSetMetaData类ResultSetMetaData类对象保存了所有ResultSet类对象中关于字段的信息,提供许多方法来取得这些信息。,52,PPT学习交流,方法:intgetColumnCount()throwsSQLException/
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 小学英语课堂流动摊贩英语口语交际能力培养策略论文
- 高中数学建模竞赛中的数学建模问题发现与解决研究论文
- 芜湖分公司管理制度
- 苹果店规章管理制度
- 蛋白粉与免疫力提升
- 课标专用5年高考3年模拟A版2024高考物理专题十一电磁感应试题
- 教学目标知识与能力1培养观察日常生活中的景物事物的
- 山东省济宁市邹城市第一中学2024-2025学年高一下学期5月月考地理试卷(含答案)
- 江苏省南通市2024-2025学年八年级下学期数学期末考试模拟试卷(含答案)
- 设计与共享经济
- 自然保护地勘界立标技术指引
- 《论文写作》课件 第1章 论文写作的基本概念
- 2025山东产权交易中心招聘21人易考易错模拟试题(共500题)试卷后附参考答案
- 广东省省级政务信息化服务预算编制标准(运维服务分册)
- 心肺复苏课件2024
- 2025年1月福建省普通高中学业水平合格性考试语文仿真模拟卷02(春季高考适用)(考试版)
- PMCAD(V31)用户手册标准版
- 《粉尘分散度和游离》课件
- 物业管理会务服务方案
- GB/T 35601-2024绿色产品评价人造板和木质地板
- 新就业形态劳动者的风险识别及治理机制研究
评论
0/150
提交评论