当前位置:  技术问答>java相关

连接数据库的问题,有点急~~~~

    来源: 互联网  发布时间:2015-05-01

    本文导语:  写了好久,总觉得这个JavaBeans不好, 请各位大虾说一说自己怎样连接数据库的?(Oracle) 谢谢! | package database; import java.sql.*; import java.util.*; import sun.io.*; public class OPDB{ DBConnectionMannager connMg...

写了好久,总觉得这个JavaBeans不好,
请各位大虾说一说自己怎样连接数据库的?(Oracle)
谢谢!

|
package database;

import java.sql.*;

import java.util.*;
import sun.io.*;



public class OPDB{

DBConnectionMannager connMgr;
Connection conn =null;

Statement sqlStatement =null;

ResultSet results =null;

ResultSet retemp =null; 

ResultSetMetaData resultsMeta =null;

boolean status;

String sql;

int columns;

long rowcount =0;



//连接数据库



public void connection(){

try{
/*DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());

this.conn =DriverManager.getConnection ("jdbc:oracle:thin:@10.10.10.220:1521:market","sz_hk", "sz_hk");
*/
connMgr = DBConnectionMannager.getInstance();
conn =connMgr.getConnection("sz_hk");
this.status =true;

}catch(Exception e)

{

this.status =false;

}

}

//连接数据库

public void connection(String con,String username,String password){

try{

DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());

this.conn =DriverManager.getConnection (con,username,password);

this.status =true;

}catch(SQLException e)

{

this.status =false;

}

}





// 返回连接 

public Connection getConn(){

/* try{
DBConnectionMannager connMgr;
connMgr = DBConnectionMannager.getInstance();
Connection conn =connMgr.getConnection("sz_hk");
if(conn !=null)
this.status =true;

else 
this.status =false;
}catch(Exception e){
System.out.println( e.toString());
}*/
return this.conn ;

}





// 关闭对数据库的连接等。 

public void Close(){

try{

if(this.conn !=null)

this.conn.close();

if(this.sqlStatement !=null)

this.sqlStatement.close();

if(this.results !=null)

this.results.close();

this.connMgr.release();
this.status =true;


}catch(SQLException e){

this.status =false;

}



}



//从数据库中选择数据



public synchronized ResultSet select(Connection c,String sql){

int index =0;

//Assign passed arguments

this.conn =c;

this.sql =sql;

try{



//Create Statement Object and Execute SQL

sqlStatement =this.conn.createStatement();

retemp =sqlStatement.executeQuery(this.sql);

this.rowcount =0;

//Get the column count for the result set

this.rowcount =0;

while(this.retemp.next())

this.rowcount++;

if(retemp!=null)

retemp.close();

results =sqlStatement.executeQuery(this.sql);

resultsMeta =results.getMetaData();

this.columns =resultsMeta.getColumnCount();

this.status =true;

return results;



}catch(SQLException e){

this.status =false;

return null;

}

}

//返回结果集的列数目 

public int getColumns(){

return this.columns;

}



//返回结果集的行数目 

public long getRowcount(){

return this.rowcount;

}



// 修改数据库中的记录。

public synchronized void update(Connection c,String sql){

try{

Statement sqlStatement =c.createStatement();

sqlStatement.executeUpdate(sql);

status =true;

}catch(SQLException e){

//set status to flase

status =false;

}

}



//向数据库中插入记录。 

public synchronized void insert(Connection c,String sql){

try{

Statement sqlStatement =c.createStatement();

sqlStatement.executeUpdate(sql);



//set status variable to true

this.status =true;

}catch(SQLException e){

//set status variable to true

this.status =false;

}





// 删除记录 。

public synchronized void delete(Connection c,String sql){

try{

sqlStatement =this.conn.createStatement();

sqlStatement.executeUpdate(sql);

status =true;

}catch(SQLException e){

//set status to flase

status =false;

}

}



//删除所有记录。

public void deleteAll(String table){

String sql ="delete from "+table;

try{

sqlStatement =this.conn.createStatement();

sqlStatement.executeUpdate(sql);

status =true;

}catch(SQLException e){

status =false;

}

}



//返回对数据库的操作是否成功

public boolean getSuccess(){

return this.status;

}



//转换为中文字符

public String GBK(String action){

try{

byte[] b =action.getBytes("GB2312");

String convert =new String(b,"8859_1");

return convert;

}catch(Exception e){

}

return null;

}
public static String AsciiToChineseString(String s)
{
char[] orig =s.toCharArray();

byte[] dest =new byte[orig.length];

for(int i=0;i

    
 
 

您可能感兴趣的文章:

  • php中内置的mysql数据库连接驱动mysqlnd简介及mysqlnd的配置安装方式
  • java数据库连接池和数据库连接示例
  • mysql jdbc连接mysql数据库步骤及常见参数详解
  • 通过JDBC连接数据库,执行抄作后,关闭了连接,数据服务器端的进程还在,怎麽处理?
  • 请问连接本机数据库的JDBC,和连接远程的JDBC有没有区别?
  • 在jbuilder中调用一bean连接数据库没有问题,在jsp中调用就连接不上数据库
  • 大家有多少web application是直接连接数据库的?又有多少是通过weblogic或websphere之类连接的?
  • 紧急求助,我的程序连接数据库时,用localhost完全正常,而外部可以访问,但不能访问连接数据的那部分
  • 在linux下可以使用dao方式连接数据库吗?可以连接musql吗?回答就给分!急
  • linux 下连接创建连接数据库程序,什么都可以 。谁知道300分
  • 一个方法中,用Connection con变量连接数据库,执行完sql以后,关闭con,返回resultset,报错“关闭的连接: next”
  • JSP连接MySql/MS SQL Server/Oracle数据库连接方法[整理]
  • 如何建立一个连接数据库的应用?例如连接access、和sql sever.
  • C#连接Excel2003和Excel2007以上版本做数据库的连接字符串
  • NaviCat连接时提示"不支持远程连接的MySql数据库"解决方法
  • Linux 下的C语言实现数据库连接池操作。
  • 请教,TOMCAT4中连接池怎样应用?数据库厂商连接池又如何应用?
  • 数据库连接的问题
  • 关于使用数据库连接的问题。
  • 用JDBC连接Oracle数据库时,如何向数据库中写日期型数据(格式)?谢了!
  • 论坛 iis7站长之家
  • 建立一个ftp数据连接并传送或接受完毕一些数据后,能否不关闭此数据连接,下次接着用?
  • 怎样调出ORACLE数据库中的数据,该如何连接?
  • 不用数据源,如何写数据库连接的代码?
  • 请问,如果连接一个Mssql的数据库。并操作里面的数据。谢谢了:)
  • 请问谁有Applet连接远程Access数据库并且显示数据库内容的例子!
  • TCP连接中创建的监听描述字和已连接描述字(套接字)对应的是同一个套接口么,如果是的话,读写数据时系统怎么区分是哪个套接字的?
  • ftp数据连接如何安全阻断??
  • linux下用什么办法连接oracle数据库并且读取数据呢?(用c++代码实现时)
  • 请问各位朋友:在JAVA的数据库应用管理系统中,如何不在操作系统忠建立数据源便能连接数据库(如ACCESS、MS SQL 等等
  • 请教:关于[linux/unix环境下连接到Oracle数据库后断开连接]的问题
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • mysql中如何查看最大连接数(max_connections)和修改最大连接数
  • 什么是socket的长连接,以及如何实现长连接,长连接和短连接有什么区别?
  • 如何在windows上远程连接centOS桌面
  • 建立长连接的SOCET通讯后,如何检查长连接的有效性,如何获知连接状态
  • Myeclipse中自带Tomcat的JDBC连接池配置(mysql和mssql)
  • Oracle 表连接方式(内连接/外连接/自连接) 详解
  • php中操作memcache的类及成员列表及php下如何连接memched服务器
  • 关于inetd。我做了一个测试程序,想计算ftp最多能有多少了连接,我发现当连接到1020次就不可以连接了,哪位大侠知道如何做才能将连接数量增加至10000呢??
  • 哪位给解释一下长连接和短连接的区别?
  • ssh连接得通虚拟机,连接不通隔壁宿舍?
  • windows server2012无法连接无线网络解决方法(windows无线连接)
  • 请问unix/linux下动态连接库和静态连接库有什么区别?
  • fedora15 KDE桌面下能连接WLAN,GNOME下能搜到信号,就是连接不上,。。。。
  • linux 有线连接了却显示有线连接断开是怎么回事
  • oracle远程连接服务器出现 ORA-12170 TNS:连接超时 解决办法
  • LINUX中连接C++的库怎么连接.库在什么位置,还有什么特殊命令吗?
  • socket 断开连接如何再恢复连接
  • 如何控制Corba客户端的连接?(比如在服务器上可以关掉客户端的连接)(发言就给分)
  • 一个连接池使用的问题:这种写法没用上连接池?
  • 网间Oracle的连接,远程连接Oracle服务器??
  • 硬连接和符号连接有什么区别啊?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3