java数据库Java有几种数据库连接方式

java数据库  时间:2021-09-04  阅读:()

java数据库

数据库的建立应该不用再讲了吧,现在讲使用JAVA与数据库进行交互

使用JDBC进行数据库的增删改查操作

1.下载Microsoft SQL Server 2005 JDBC 驱动包jar文件

将jar文件引入工程中

2.封装数据库链接的获取和关闭操作

import java.sql.*;

public class BaseDao {
/**
* 数据库驱动类的字符串,完整的包名加类名 在工程中查看添加的jar文件 能看到这个类
*/
private static final String DRIVE = .microsoft.sqlserver.jdbc.SQLServerDriver";

/**
* 数据库连接地址
*
* DataBaseName=数据库名称 其它固定
*/
private static final String URL = "jdbc:sqlserver://localhost:1433;DataBaseName=bbs";

/**
* 连接数据库的用户名
*/
private static final String USER = "sa";

/**
* 用户密码
*/
private static final String PASSWORD = "";

/**
* 获取连接 异常直接抛出 或者捕获后自定义异常信息再抛出
*/
public static Connection getConnection() throws Exception {
Class.forName(DRIVE);
return DriverManager.getConnection(URL, USER, PASSWORD);
}

/**
* 关闭与数据库的连接 释放资源
*/
public static void closeAll(ResultSet resultSet, PreparedStatement pst,
Connection connection) throws Exception {
if (resultSet != null)
resultSet.close();
if (pst != null)
pst.close();
if (connection != null)
connection.close();
}

}

3.创建图书的实体类

public class Book {
/**
* 数据库主键
*/
private Long id;

/**
* 作者
*/
private String author;

/**
* 书名
*/
private String name;
/**
* 默认构造
*
*/
public Book() {
}
/**
* 全字段构造
* @param id
* @param author
* @param name
*/
public Book(Long id, String author, String name) {
this.id = id;
this.author = author;
this.name = name;
}
/**
* 以下为读写属性的方法
* @return
*/
public String getAuthor() {
return author;
}
public void setAuthor(String author) {
this.author = author;
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
4.创建与图书表交互的工具类

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;

public class BookDao {
/**
* 添加新书
*
* @param book 要添加入数据库的图书 作者 书名 必须给定
*/
public void addBook(Book book) throws Exception {
// 连接
Connection connection = null;
// 执行语句
PreparedStatement pst = null;
try {
connection = BaseDao.getConnection();
// 构造执行语句
String sql = "insert into book values(" + book.getAuthor() + ","
+ book.getName() + ")";
pst = connection.prepareStatement(sql);
pst.executeUpdate();

} catch (Exception e) {
// 抛出异常
throw e;
} finally {
// 无论是否异常 均关闭数据库
BaseDao.closeAll(null, pst, connection);
}
}

/**
* 查询所有书籍列表
*/
public List<Book> getBooks() throws Exception {
// 用于存放查寻结果的集合
List<Book> books = new ArrayList<Book>();
// 连接
Connection connection = null;
// 执行语句
PreparedStatement pst = null;
// 查询结果
ResultSet resultSet = null;
try {
connection = BaseDao.getConnection();
// 构造查询语句
String sql = "select * from book";
pst = connection.prepareStatement(sql);
resultSet = pst.executeQuery();

// 循环读取查询结果行
while (resultSet.next()) {
// getXXX的参数为数据表列名
Book book = new Book(resultSet.getLong("id"), resultSet
.getString("author"), resultSet.getString("name"));
// 将封装好的图书对象存入集合
books.add(book);
}
} catch (Exception e) {
// 抛出异常
throw e;
} finally {
// 无论是否异常 均关闭数据库
BaseDao.closeAll(resultSet, pst, connection);
}
// 返回查询结果
return books;
}

/**

*其它方法类似上面 只是语句不同

*/
}

当然 以上只是简单的封装 初学者可以在理解以上代码的基础上 进行更高级的封装
5.使用BookDao添加书籍和获取所有书籍列表

import java.util.List;

/**
* 测试类
* @author Administrator
*
*/
public class Test {

/**
* @param args
* @throws Exception
*/
public static void main(String[] args) throws Exception {
//创建工具类对象
BookDao dao = new BookDao();
//创建一本图书
Book book = new Book(null,"QQ:495691293","编程菜鸟");
//添加书籍到数据库
dao.addBook(book);

//获取所有图书列表
List<Book> books = dao.getBooks();
//输出结果
for (Book b : books) {
System.out.println(b.getId()+" "+b.getAuthor()+" "+b.getName());
}
}

}

java数据库是什么

是个学生吧,还没有系统的学习: 1、Java是一门编程语言,为的实现如何连接客户与数据,之间的一种连接工具,你可以这么理解,你想要图书馆里面的所有的图书,查找某个资料,没有编程语言做的变成系统,你只能够通过自己去图书馆一本一本的去翻,去找。

有了编程语言,就可以专门的做出一个查询系统,这个系统将所有的图书的内容都融汇到一个地方,然后通过你用Java编写的查询系统,进行查找想要的资料,就是电子化,这样同时可以提供给更多的人去查找,也给更多的人省去了,单独查找的时间。

编程语言就是做这个的。

2、数据库是做什么的呢: 在上面我们提到了,就是把所有的书的内容都放置到一个地方,而数据库就是进行存放这个书籍内容的地方,有了数据库,我们可以更好的去管理书籍里面的内容,进行改写,进行备份,进行整理。

在一个企业里面:三分管理 七分技术 十二分数据,其实人们最注重的是数据的积累。

一家银行,有多少个客户,客户都各自存储了多少钱,什么时候存储的。

它并不关心你这系统是什么东西,它只想通过你的系统继续操作里面的数据。

数据库就是这个作用。

3、话又说回来了,就是存储数据,你完全可以用记事本,excel表格,或者自己随便的定义一种东西进行存储,但是,当级别达到几千,几万,几十万,几百万,几千万,几亿,你如何去存储,用什么东西进行查询历史的数据,如果你真的有本事能够做到查询的速度性,安全性以及便于管理性,你可以完全不用数据库,当然目前世界上还没有人能够弄成,能弄成的几个公司就是现在的数据库公司:oracle,db2等等 不知你是否明白,希望对你有帮助。

以上回答你满意么?

Java有几种数据库连接方式

/web/diary.html?uin=x25125x&diary_id=1711&refer=friend

标题:java 连接各种数据库方式 一、连接各种数据库方式速查表   下面罗列了各种数据库使用JDBC连接的方式,可以作为一个手册使用。

  1、Oracle8/8i/9i数据库(thin模式) Class.forName(“oracle.jdbc.driver.OracleDriver“).newInstance(); String url=“jdbc:oracle:thin:@localhost:1521:orcl“; //orcl为数据库的SID String user=“test“; String password=“test“; Connection conn= DriverManager.getConnection(url,user,password);   2、DB2数据库 Class.forName(.ibm.db2.jdbc.app.DB2Driver “).newInstance(); String url=“jdbc:db2://localhost:5000/sample“; //sample为你的数据库名 String user=“admin“; String password=““; Connection conn= DriverManager.getConnection(url,user,password);   3、Sql Server7.0/2000数据库 Class.forName(.microsoft.jdbc.sqlserver.SQLServerDriver“).newInstance(); String url=“jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb“; //mydb为数据库 String user=“sa“; String password=““; Connection conn= DriverManager.getConnection(url,user,password);   4、Sybase数据库 Class.forName(.sybase.jdbc.SybDriver“).newInstance(); String url =“ jdbc:sybase:Tds:localhost:5007/myDB“;//myDB为你的数据库名 Properties sysProps = System.getProperties(); SysProps.put(“user“,“userid“); SysProps.put(“password“,“user_password“); Connection conn= DriverManager.getConnection(url, SysProps);  5、Informix数据库 Class.forName(.informix.jdbc.IfxDriver“).newInstance(); String url = “jdbc:informix-sqli://123.45.67.89:1533/myDB:INFORMIXSERVER=myserver; user=testuser;password=testpassword“; //myDB为数据库名 Connection conn= DriverManager.getConnection(url);   6、MySQL数据库 Class.forName(.gjt.mm.mysql.Driver“).newInstance(); String url =“jdbc:mysql://localhost/myDB?user=soft&password=soft1234&useUnicode=true&characterEncoding=8859_1“ //myDB为数据库名 Connection conn= DriverManager.getConnection(url);   7、PostgreSQL数据库 Class.forName(.postgresql.Driver“).newInstance(); String url =“jdbc:postgresql://localhost/myDB“ //myDB为数据库名 String user=“myuser“; String password=“mypassword“; Connection conn= DriverManager.getConnection(url,user,password);   8、ess数据库直连用ODBC的 Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver“) ; String url=“jdbc:odbc:Driver={MicroSoft ess Driver (*.mdb)};DBQ=“+application.getRealPath(“/Data/ReportDemo.mdb“); Connection conn = DriverManager.getConnection(url,““,“”); Statement stmtNew=conn.createStatement() ;   二、JDBC连接MySql方式   下面是使用JDBC连接MySql的一个小的教程   1、查找驱动程序   MySQL目前提供的java驱动程序为Connection/J,可以从MySQL官方网站下载,并找到mysql-connector-java-3.0.15-ga-bin.jar文件,此驱动程序为纯java驱动程序,不需做其他配置。

2、动态指定classpath   如果需要执行时动态指定classpath,就在执行时采用-cp方式。

否则将上面的.jar文件加入到classpath环境变量中。

  3、加载驱动程序 try{  .mysql.jdbc.Driver);  System.out.println(ess loading Mysql Driver!); }catch(Exception e) {  System.out.println(Error loading Mysql Driver!);  e.printStackTrace(); }   4、设置连接的url jdbc:mysql://localhost/databasename[?pa=va][&pa=va]   三、以下列出了在使用JDBC来连接Oracle数据库时可以使用的一些技巧   1、在客户端软件开发中使用Thin驱动程序   在开发Java软件方面,Oracle的数据库提供了四种类型的驱动程序,二种用于应用软件、applets、servlets等客户端软件,另外二种用于数据库中的Java存储过程等服务器端软件。

在客户机端软件的开发中,我们可以选择OCI驱动程序或Thin驱动程序。

OCI驱动程序利用Java本地化接口(JNI),通过Oracle客户端软件与数据库进行通讯。

Thin驱动程序是纯Java驱动程序,它直接与数据库进行通讯。

为了获得最高的性能,Oracle建议在客户端软件的开发中使用OCI驱动程序,这似乎是正确的。

但我建议使用Thin驱动程序,因为通过多次测试发现,在通常情况下,Thin驱动程序的性能都超过了OCI驱动程序。

  2、关闭自动提交功能,提高系统性能   在第一次建立与数据库的连接时,在缺省情况下,连接是在自动提交模式下的。

为了获得更好的性能,可以通过调用带布尔值false参数的Connection类的setAutoCommit()方法关闭自动提交功能,如下所示:   conn.setAutoCommit(false);   值得注意的是,一旦关闭了自动提交功能,我们就需要通过调用Connection类mit()和rollback()方法来人工的方式对事务进行管理。

3、在动态SQL或有时间限制的命令中使用Statement对象   在执行SQL命令时,我们有二种选择:可以使用PreparedStatement对象,也可以使用Statement对象。

无论多少次地使用同一个SQL命令,PreparedStatement都只对它解析和编译一次。

当使用Statement对象时,每次执行一个SQL命令时,都会对它进行解析和编译。

这可能会使你认为,使用PreparedStatement对象比使用Statement对象的速度更快。

然而,我进行的测试表明,在客户端软件中,情况并非如此。

因此,在有时间限制的SQL操作中,除非成批地处理SQL命令,我们应当考虑使用Statement对象。

  此外,使用Statement对象也使得编写动态SQL命令更加简单,因为我们可以将字符串连接在一起,建立一个有效的SQL命令。

因此,我认为,Statement对象可以使动态SQL命令的创建和执行变得更加简单。

  4、利用helper函数对动态SQL命令进行格式化   在创建使用Statement对象执行的动态SQL命令时,我们需要处理一些格式化方面的问题。

例如,如果我们想创建一个将名字O‘Reilly插入表中的SQL命令,则必须使用二个相连的“‘‘”号替换O‘Reilly中的“‘”号。

完成这些工作的最好的方法是创建一个完成替换操作的helper方法,然后在连接字符串心服用公式表达一个SQL命令时,使用创建的helper方法。

与此类似的是,我们可以让helper方法接受一个Date型的值,然后让它输出基于Oracle的to_date()函数的字符串表达式。

  5、利用PreparedStatement对象提高数据库的总体效率   在使用PreparedStatement对象执行SQL命令时,命令被数据库进行解析和编译,然后被放到命令缓冲区。

然后,每当执行同一个PreparedStatement对象时,它就会被再解析一次,但不会被再次编译。

在缓冲区中可以发现预编译的命令,并且可以重新使用。

在有大量用户的企业级应用软件中,经常会重复执行相同的SQL命令,使用PreparedStatement对象带来的编译次数的减少能够提高数据库的总体性能。

如果不是在客户端创建、预备、执行PreparedStatement任务需要的时间长于Statement任务,我会建议在除动态SQL命令之外的所有情况下使用PreparedStatement对象。

  6、在成批处理重复的插入或更新操作中使用PreparedStatement对象   如果成批地处理插入和更新操作,就能够显著地减少它们所需要的时间。

Oracle提供的Statement和 CallableStatement并不真正地支持批处理,只有PreparedStatement对象才真正地支持批处理。

我们可以使用addBatch()和executeBatch()方法选择标准的JDBC批处理,或者通过利用PreparedStatement对象的setExecuteBatch()方法和标准的executeUpdate()方法选择速度更快的Oracle专有的方法。

要使用Oracle专有的批处理机制,可以以如下所示的方式调用setExecuteBatch(): PreparedStatement pstmt3D null; try {  ((OraclePreparedStatement)pstmt).setExecuteBatch(30);  ...  pstmt.executeUpdate(); }   调用setExecuteBatch()时指定的值是一个上限,当达到该值时,就会自动地引发SQL命令执行,标准的executeUpdate()方法就会被作为批处理送到数据库中。

我们可以通过调用PreparedStatement类的sendBatch()方法随时传输批处理任务。

7、使用Oracle locator方法插入、更新大对象(LOB)   Oracle的PreparedStatement类不完全支持BLOB和CLOB等大对象的处理,尤其是Thin驱动程序不支持利用PreparedStatement对象的setObject()和setBinaryStream()方法设置BLOB的值,也不支持利用setCharacterStream()方法设置CLOB的值。

只有locator本身中的方法才能够从数据库中获取LOB类型的值。

可以使用PreparedStatement对象插入或更新LOB,但需要使用locator才能获取LOB的值。

由于存在这二个问题,因此,我建议使用locator的方法来插入、更新或获取LOB的值。

  8、使用SQL92语法调用存储过程   在调用存储过程时,我们可以使用SQL92或Oracle PL/SQL,由于使用Oracle PL/SQL并没有什么实际的好处,而且会给以后维护你的应用程序的开发人员带来麻烦,因此,我建议在调用存储过程时使用SQL92。

  9、使用Object SQL将对象模式转移到数据库中   既然可以将Oracle的数据库作为一种面向对象的数据库来使用,就可以考虑将应用程序中的面向对象模式转到数据库中。

目前的方法是创建Java bean作为伪装的数据库对象,将它们的属性映射到关系表中,然后在这些bean中添加方法。

尽管这样作在Java中没有什么问题,但由于操作都是在数据库之外进行的,因此其他访问数据库的应用软件无法利用对象模式。

如果利用Oracle的面向对象的技术,可以通过创建一个新的数据库对象类型在数据库中模仿其数据和操作,然后使用JPublisher等工具生成自己的Java bean类。

如果使用这种方式,不但Java应用程序可以使用应用软件的对象模式

HostYun:联通AS9929线路,最低月付18元起,最高500Mbps带宽,洛杉矶机房

最近AS9929线路比较火,联通A网,对标电信CN2,HostYun也推出了走联通AS9929线路的VPS主机,基于KVM架构,开设在洛杉矶机房,采用SSD硬盘,分为入门和高带宽型,最高提供500Mbps带宽,可使用9折优惠码,最低每月仅18元起。这是一家成立于2008年的VPS主机品牌,原主机分享组织(hostshare.cn),商家以提供低端廉价VPS产品而广为人知,是小成本投入学习练手首选。...

CloudCone(20美元/年)大硬盘VPS云服务器,KVM虚拟架构,1核心1G内存1Gbps带宽

近日CloudCone商家对旗下的大硬盘VPS云服务器进行了少量库存补货,也是悄悄推送了一批便宜VPS云服务器产品,此前较受欢迎的特价20美元/年、1核心1G内存1Gbps带宽的VPS云服务器也有少量库存,有需要美国便宜大硬盘VPS云服务器的朋友可以关注一下。CloudCone怎么样?CloudCone服务器好不好?CloudCone值不值得购买?CloudCone是一家成立于2017年的美国服务...

建站选择网站域名和IP主机地址之间关系和注意要点

今天中午的时候有网友联系到在选择网站域名建站和主机的时候问到域名和IP地址有没有关联,或者需要注意的问题。毕竟我们在需要建站的时候,我们需要选择网站域名和主机,而主机有虚拟主机,包括共享和独立IP,同时还有云服务器、独立服务器、站群服务器等形式。通过这篇文章,简单的梳理关于网站域名和IP之间的关系。第一、什么是域名所谓网站域名,就是我们看到的类似"www.laozuo.org",我们可以通过直接记...

java数据库为你推荐
expireredis expire 命令有什么好处xhtmlHTML4,HTML5,XHTML 之间有什么区别fast路由器FAST无线路由器要怎么设置fast路由器FAST/迅捷无线路由器怎么设置文件损坏文件损坏是由哪些原因造成的?有什么办法修复吗?图片修改工具推荐个好用的修改图片的工具东西网如何在网上购买东西?淘宝推广网站有没有淘宝第三方推广平台好用的?里程碑2里程碑2 如何。?科学计算器说明书计算器的使用方法?
俄罗斯vps 最便宜的vps 域名备案信息查询 如何申请免费域名 lighttpd 国外php空间 发包服务器 丹弗 百兆独享 100m空间 cn3 支持外链的相册 中国电信宽带测速器 cxz 电信网络测速器 德讯 稳定空间 国外免费网盘 重庆联通服务器托管 九零网络 更多