ImageVerifierCode 换一换
格式:DOCX , 页数:29 ,大小:857.75KB ,
资源ID:7209807      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/7209807.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(java连接数据库及数据库的查询.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

java连接数据库及数据库的查询.docx

1、java连接数据库及数据库的查询第7章 java连接数据库及数据库的查询 jdbc与数据库概述 访问数据库 一个查询数据库的WEB示例7.1 jdbc与数据库概述数据库是一个有组织的数据集合,它由一个或多个表组成。每一个表中都存储了对一类对象的数据描述。数据库管理系统(database management system,DBMS)以一种与数据库格式一致的方式,提供了存储和组织数据的机制。7.11数据库编程 1)当前主流数据库当前最流行的数据库是关系型数据库,它是将数据表示为表的集合,通过建立简单表之间的关系来定义结构的一种数据库。数据库中的表按照行和列的形式来存储信息。行表示关系型数据库中的

2、记录,列表示数据属性。比较著名的关系数据库管理系统有Oracle、Sybase、DB2、MySQL、Microsoft SQL Server、Microsoft Access等。 2)sql语言SQL是一个国际化标准语言,几乎所有关系型数据库都用SQL语言执行数据查询和操纵。 理解SQL语句时要注意几点:(1) SQL语言中的语句都是独立执行的,无上下文联系;(2) 每条语句都有自己的主关键字,语句中可包含若干子句;(3) SQL语句本身不区分大小写。为突出语句格式,下面例子中保留字采用大写。1. 建表语句格式:CREATE TABLE table_name (column1 type not

3、 null,)功能:在当前数据库中创建一张名为的table_name表格结构。2. 删除表格式:DROP table_name功能:在当前数据库中删除名为table_name的表。3. 查询语句格式:SELECT col1,col2,.,coln FROM table_name WHERE condition_expression功能:从数据库表中检索满足条件的记录。WHERE子句是可选项,它可以包含、 =、 =、和LIKE运算符。LIKE运算符用于带有通配符百分号(%)和下划线(_)的模式匹配。4. 插入语句格式:INSERT INTO table_name (col1,col2,.,col

4、n) VALUES(v1,v2,.,vn)功能:在表table_name中插入一条记录,各列的值依次分别为v1、v2、vn等,若某列的列名未给,则值为NULL。注意:(1)如果所有的列名都未给,则在Values中必须依次给出所有列的值。(2)给出的值的类型必须与对应的列的类型相一致。 5. 更新语句格式:UPDATE table_name SET col1=v1 ,col2=v2,.,coln=vnWHERE condition_expression功能:更新表table_name中满足条件的记录,使列col1的值为v1、列col2的值为v2、列coln的值为vn等。注意:如不给出条件,则更新

5、表中所有记录。例如,假如银行账户系统中有一张account(账户)表中,账号为“1280316401“的账户取款200元后应更新余额,使用语句如下:UPDATE account SET accountAmount=accountAmount-200 WHERE accountNumber =12803164016. 删除语句格式:DELETE FROM table_name WHERE condition_expression功能:删除表table_name中满足条件的记录。特别注意:如果不给出条件,则删除表中所有记录。例如,对account表中,账号为“1280316401“的账户进行销户处

6、理,语句如下:DELETE FORM account WHERE accountNumber=1280316401 7.12 JDBC框架结构 1)ODBC数据源 ODBC是OpenDatabaseConnectivity的英文简写。它是由Microsoft提出的为连接不同数据库而制定的一种接口标准,是用C语言实现的,标准应用程序数据接口。通过ODBC API,应用程序可以存取保存在多种不同数据库管理系统(DBMS)中的数据,而不论每个DBMS使用了何种数据存储格式和编程接口。 几乎所有的数据库都支持这一标准。 ODBC有其不足之处,比如它并不容易使用,没有面向对象的特性等等。 ODBC的结构

7、包括四个主要部分:应用程序接口、驱动器管理器、数据库驱动器和数据源。 进行ODBC数据源设置,在Windows XP环境下,可按路径开始菜单-设置-控制面板-管理工具-数据源(ODBC),双击可打开如图11.3所示的对话框。 单击系统DSN-单击添加按钮,可以添加不同的odbc数据源。 2) 通过JDBC访问数据库 JDBC与 ODBC的工作原理非常类似。JDBC与ODBC都是基于X/Open的SQL调用级接口, JDBC的设计在思想上沿袭了ODBC,同时在其主要抽象和SQL CLI实现上也沿袭了ODBC,这使得JDBC容易被接受。JDBC的总体结构类似于ODBC,也有四个组件:应用程序、驱动

8、程序管理器、驱动程序和数据源。 JDBC保持了ODBC的基本特性,也独立于特定数据库。使用相同源代码的应用程序通过动态加载不同的JDBC驱动程序,可以访问不同的DBMS。连接不同的DBMS时,各个DBMS之间仅通过不同的URL进行标识。JDBC的 DatabaseMetaData接口提供了一系列方法,可以检查DBMS对特定特性的支持,并相应确定有什么特性,从而能对特定数据库的特性予以支持。与ODBC一样,JDBC也支持在应用程序中同时建立多个数据库连接,采用JDBC可以很容易地用SQL语句同时访问多个异构的数据库,为异构的数据库之间的互操作奠定基础。 但是,JDBC除了具有ODBC的上述特点外

9、,更具有对硬件平台、操作系统异构性的支持。这主要是因为ODBC使用的是C语言,而JDBC使用的是Java语言。Java语言具有与平台无关、移植性强、安全性高、稳定性好、分布式、面向对象等众多优点,而JDBC确保了“100纯Java”的解决方案,利用Java的平台无关性, JDBC应用程序可以自然地实现跨平台特性,因而更适合于Internet上异构环境的数据库应用。 此外,JDBC驱动程序管理器是内置的,驱动程序本身也可通过Web浏览器自动下载,无须安装、配置;而ODBC驱动程序管理器和ODBC驱动程序必须在每台客户机上分别安装、配置。1. JDBC数据库驱动程序 JDBC数据库驱动程序的功能是

10、:一面用底层协议与数据库服务器进行对话;一面用JDBC API与用户程序进行对话。 为实现 “与平台无关”的特点,JDBC为我们提供了一个“驱动程序管理器”,它能动态维护数据库查询所需的所有驱动程序对象。 用户可以从数据库供应商那里获得JDBC数据库驱动程序。 2. JDBC驱动程序类型(1) JDBC-ODBC Bridge将对JDBC的调用转化为ODBC的调用,要求本地机必须安装ODBC驱动程序,然后注册一个ODBC数据源名 。(2) JDBC-Native API Bridge直接将用户的调用转化为对数据库客户端API的调用,要求本地机必须安装好特定的驱动程序,显然限制了应用程序对其它数

11、据库的使用。(3) JDBC-MiddleWare它是独立于数据库服务器的,它和一个中间件服务器通讯,由中间件负责与数据库通讯。 (4) Pure JDBC Driver使用该类型的应用程序无需安装附加的软件,所有对数据库的操作都直接由JDBC驱动程序完成。 如上图所示:我们一般通过(1) JDBC-ODBC Bridge和(4) Pure JDBC Driver的方式访问数据库7.13 JDBC典型应用模型 1)两层模型 2)三层模型 7.14 JDBC中的主要类和接口简单地说,JDBC主要完成下列三项任务:1 同一个数据库建立连接;2 向数据库发送SQL语句;3 处理数据库返回的结果。 这

12、些任务由JDBC API来完成。JDBCAPI被描述成为一组抽象的Java接口。这些接口都可能产生异常,如:ClassNotFoundException、SQLException异常,因而编写程序时必须对抛出的异常进行捕获。主要的JDBC API如下: (1) 驱动程序管理器Drvier Manager用来加载驱动程序,管理应用程序和已注册的驱动程序的连接。(2) 连接Connection 封装了应用程序与数据库之间的连接信息。(3) 驱动程序Driver负责定位并访问数据库,建立数据库连接和处理所有与数据库的通讯。(4) 语句Statement 用来在数据库中执行一条SQL语句。(5) 结果

13、集ResultSet 负责保存执行查询后返回的数据。 7.2 访问数据库7.21 访问数据库的步骤 1)载入jdbc数据库驱动程序 2)建立与数据库的连接 3)在建立数据库连接的前提下执行sql语句 4)取结果集和结果信息 5)关闭数据库连接7.22 连接数据库1)JDBC URL: jdbc:例如连接到oracle 10g的orcl数据库实例的URL是 jdbc:oracle:thin:10.0.0.13:1521:orcl再例如连接到sqlserver 2008的master数据库的URL是 jdbc:sqlserver:/ 10.0.0.13:1433;databaseName=mast

14、er2)建立连接 /加载驱动 Class.forName(oracle.jdbc.driver.OracleDriver); /定义URL String url=jdbc:oracle:thin:10.0.0.13:1521:orcl; /建立连接 Connection conn = DriverManager.getConnection(url,username,password);7.23 执行sql语句 取得各列信息 getColumns 取得索引信息 getIndexInfo7.24 Statement语句 7.25 取结果集中的数据 7.26 一个简单例子该例把sqlserver20

15、08的master数据库中的spt_monitor表中的数据查询出来,并打印到控制台上import java.sql.*;public class DataOperate /* *函数功能:获取连接数据库的对象*/ public Connection getConn() throws Exception Connection conn =null; /加载驱动 Class.forName(com.microsoft.sqlserver.jdbc.SQLServerDriver); /定义URLString url= jdbc:sqlserver:/localhost:1433;database

16、Name=master;/建立连接 conn = DriverManager.getConnection(url,sa,123456); return conn; /*函数功能:获取执行sql语句的对象*/ public Statement getStmt(Connection conn) throws SQLException Statement stmt =null; stmt = conn.createStatement(); return stmt; /*函数功能:执行sql语句,获取结果集*/public ResultSet execQuery(String sql,Statemen

17、t stmt) throws SQLException ResultSet rs=null; rs=stmt.executeQuery(sql); return rs; /*main方法,程序入口*/ public static void main(String args) /定义查询的sql语句 String sql=select * from spt_monitor; /实例化当前类的对象 DataOperate dopt=new DataOperate(); Connection conn=null; Statement stmt=null; ResultSet rs=null; try

18、 /调用函数获取连接类的对象 conn=dopt.getConn(); /调用函数获取执行sql语句的对象 stmt=dopt.getStmt(conn); /调用函数取得结果集 rs=dopt.execQuery(sql, stmt); /循环打印出数据库中每一行数据 while(rs.next() System.out.print(rs.getString(cpu_busy)+ +rs.getString(io_busy); catch(Exception e) e.printStackTrace(); try if(conn !=null) /关闭连接对象 conn.close(); c

19、atch(Exception e) e.printStackTrace(); 7.3一个查询数据库的WEB示例本小节以一个实际例子引导大家开发一个简单的查询数据库的web示例。开发工具:MyEclipse 6.5数据库:SqlSever2008Web服务器:Tomcat 6.0JDBC数据库驱动包:sqljdbc4.jar以上软件包请同学们自行下载安装。第一步:打开sqlserver2008、建库、建表,插入数据。建立student数据库,建立student表,字段如下图所示:插入如下图所示数据:以上步骤请同学自己完成。也可以完全用sql代码的方式完成,参考代码如下:-一.建库 (注意:C:d

20、ata是需要手工建立的目录)create database STUDENT on ( name= STUDENT_data, filename=C:dataSTUDENT_data.mdf, maxsize=50MB, size=3MB, filegrowth=1MB)log on(name= STUDENT_log, filename=C:dataSTUDENT_log.ldf, maxsize=50MB, size=2MB, filegrowth=1MB ) ;USE STUDENT;-二、建表create table Student.dbo.Student(sno char(4) pri

21、mary key, name varchar(20) not null, sex varchar(2), age smallint, native varchar(20), department varchar(50), address varchar(200) ); -三、插入数据insert into dbo.Student values (1101,王燕,女,20,北京,工程系,null);insert into dbo.Student values (1102,张军,男,21,上海,工程系,null);insert into dbo.Student values (1104,张栋,男,

22、21,南京,工程系,null);insert into dbo.Student values (1201,吴华,女,20,成都,计算机系,null);insert into dbo.Student values (1202,李波,男,21,上海,计算机系,null);insert into dbo.Student values (1203,陈建,男,19,长沙,计算机系,null);insert into dbo.Student values (1204,王江洪,男,19,邵阳,基建系,null);insert into dbo.Student values (1205,潘将,男,19,常德,

23、艺术系,null);insert into dbo.Student values (1303,张斌,男,22,上海,经管系,null);insert into dbo.Student values (1305,张斌,女,20,武汉,经管系,null);第二步:打开MyEclipse,建立一个web工程webquery,并载入驱动包sqljdbc4.jar。如下图所示:新建web工程添加驱动包添加驱动包步骤三 建立源代码文件。分别新建三个包和三个java类文件还有一个jsp文件,如图所示:源代码及注解如下:StudentBean.javapackage beans;/* *javabean 文件

24、,定义一些变量,跟数据库中相关表的字段一致,并设置get/set方法,*用来封装数据库表中的数据 */public class StudentBean private String sno; private String name; private String sex; private String age; private String nativeplace; private String department; private String address; public String getSno() return sno; public void setSno(String sno

25、) this.sno = sno; public String getName() return name; public void setName(String name) this.name = name; public String getSex() return sex; public void setSex(String sex) this.sex = sex; public String getAge() return age; public void setAge(String age) this.age = age; public String getNativeplace()

26、 return nativeplace; public void setNativeplace(String nativeplace) this.nativeplace = nativeplace; public String getDepartment() return department; public void setDepartment(String department) this.department = department; public String getAddress() return address; public void setAddress(String add

27、ress) this.address = address; DataOperate.javapackage dboperate;import java.sql.*;/* *一些操作数据库方法的集合 */public class DataOperate /* *函数功能:获取连接数据库的对象*/ public Connection getConn() throws Exception Connection conn =null; /加载驱动 Class.forName(com.microsoft.sqlserver.jdbc.SQLServerDriver); /定义URLString url=

28、 jdbc:sqlserver:/localhost:1433;databaseName=master;/建立连接 conn = DriverManager.getConnection(url,sa,123456); return conn; /*函数功能:获取执行sql语句的对象*/ public Statement getStmt(Connection conn) throws SQLException Statement stmt =null; stmt = conn.createStatement(); return stmt; /*函数功能:执行sql语句,获取结果集*/public

29、 ResultSet execQuery(String sql,Statement stmt) throws SQLException ResultSet rs=null; rs=stmt.executeQuery(sql); return rs; ExecQuery.javapackage servlets;import java.io.*;import java.sql.*;import java.util.*;import dboperate.DataOperate;import beans.StudentBean;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;/* *

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1