分享
 
 
 

数据库操作

王朝厨房·作者佚名  2007-01-04
窄屏简体版  字體: |||超大  

数据库操作可以中WEB开发中最常用到的,很多Java开发工具都提供了自动的Data bean WinZard.只要数据库建立好,相应的操作数据库的Bean就基本可以自动完成,本人使用Jcreator开发bean,手工录入觉得也不是很麻烦的事情,下面我常用的数据库操作bean,完全可以对付访问量不是很大的系统 :

Mysql类:

import java.sql.*;

import java.io.*;

/**

* 处理数据库的连接和访问

* @author sanware bqlr

* @version 1.01

*/

public class Mysql {

private Connection conn = null;

private Statement stmt = null;

private PreparedStatement prepstmt = null;

//这是一个全局类,里面放置数据库的参数,如数据库主机 访问用户名 密码等

private static BeansConstants CONST = BeansConstants.getInstance();

/**

* 构造数据库的连接和访问类

*/

public Mysql() throws Exception {

Class.forName(CONST.dbdriver);

conn = DriverManager.getConnection(CONST.dburl);

stmt = conn.createStatement();

}

public Mysql(String sql) throws Exception {

Class.forName(CONST.dbdriver);

conn = DriverManager.getConnection(CONST.dburl);

this.prepareStatement(sql);

}

/**

* 返回连接

* @return Connection 连接

*/

public Connection getConnection() {

return conn;

}

/**

* PreparedStatement

* @return sql 预设SQL语句

*/

public void prepareStatement(String sql) throws SQLException {

prepstmt = conn.prepareStatement(sql);

}

/**

* 设置对应值

* @param index 参数索引

* @param value 对应值

*/

public void setString(int index,String value) throws SQLException {

prepstmt.setString(index,value);

}

public void setInt(int index,int value) throws SQLException {

prepstmt.setInt(index,value);

}

public void setBoolean(int index,boolean value) throws SQLException {

prepstmt.setBoolean(index,value);

}

public void setDate(int index,Date value) throws SQLException {

prepstmt.setDate(index,value);

}

public void setLong(int index,long value) throws SQLException {

prepstmt.setLong(index,value);

}

public void setFloat(int index,float value) throws SQLException {

prepstmt.setFloat(index,value);

}

//File file = new File("test/data.txt");

//int fileLength = file.length();

//InputStream fin = new java.io.FileInputStream(file);

//mysql.setBinaryStream(5,fin,fileLength);

public void setBinaryStream(int index,InputStream in,int length) throws SQLException {

prepstmt.setBinaryStream(index,in,length);

}

public void clearParameters()

throws SQLException

{

prepstmt.clearParameters();

}

/**

* 返回预设状态

*/

public PreparedStatement getPreparedStatement() {

return prepstmt;

}

/**

* 返回状态

* @return Statement 状态

*/

public Statement getStatement() {

return stmt;

}

/**

* 执行SQL语句返回字段集

* @param sql SQL语句

* @return ResultSet 字段集

*/

public ResultSet executeQuery(String sql) throws SQLException {

if (stmt != null) {

return stmt.executeQuery(sql);

}

else return null;

}

public ResultSet executeQuery() throws SQLException {

if (prepstmt != null) {

return prepstmt.executeQuery();

}

else return null;

}

/**

* 执行SQL语句

* @param sql SQL语句

*/

public void executeUpdate(String sql) throws SQLException {

if (stmt != null)

stmt.executeUpdate(sql);

}

public void executeUpdate() throws SQLException {

if (prepstmt != null)

prepstmt.executeUpdate();

}

/**

* 关闭连接

*/

public void close() throws Exception {

if (stmt != null) {

stmt.close();

stmt = null;

}

if (prepstmt != null) {

prepstmt.close();

prepstmt = null;

}

conn.close();

conn = null;

}

}

Mysql建立好后,以后涉及数据库的操作,只要对象化Mysql就可以:

private String page_navlink_insert="insert into page_navlink values (?,?,?,?)";

public void insertnavlink() throws Exception

{

ResultSet rs=null;

try {

Mysql mysql = new Mysql(page_navlink_insert);

mysql.setInt(1,this.siteid);

mysql.setInt(2,this.pageid);

mysql.setString(3,this.navlinkname);

mysql.setString(4,this.pagefile);

mysql.executeUpdate();

mysql.close();

mysql = null;

} catch (Exception ex) {

throw new Exception("insertnavlink()"+ex.getMessage());

}

}

在Jsp中,就可以直接使用一句语句使用insertnavlink()了:

<jsp:useBean id="NAV" scope="session" class="mysite.Navlink" />

<jsp:setProperty name="NAV" property="*" />

........

NAV.insertnavlink();

......

频繁访问数据库,需要使用连接池,在tomcat 4.0中配置JNDI,稍微修改一下上面程序就可使用连接池.Tomcat的连接池配置和J2EE类似,因此程序不用修改,也可直接运行在J2EE上.

也可以使用第三方连接池, 如很有名的Poolman.

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有