MyEclipse web项目连接数据库
1、Build path添加jdbc驱动包
2、编写驱动类
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException; public class Connect {
public Connection getconnect(){
Connection con=null;
String driver = "com.mysql.jdbc.Driver";
String url = "jdbc:mysql://localhost:3306/bs?serverTimezone=UTC";
String user = "root"; //自己数据库的用户名
String password = "1234"; //自己数据库的密码
try {
Class.forName(driver);
con = DriverManager.getConnection(url, user, password);
if (!con.isClosed())
System.out.println("\n\t\t成功以 " + user + " 身份连接到数据库!!!");
return con;
}
catch (ClassNotFoundException e) {
// 数据库驱动类异常处理
System.out.println("Sorry,can`t find the Driver!");
e.printStackTrace();
}
catch (SQLException e) {
// 数据库连接失败异常处理
e.printStackTrace();
}
catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
finally {
System.out.println("\t\t\t\t\t\t\t\t获取数据库数据完毕!!!");
}
return con;
}
}
3、调用这个类
package com.ins; import java.sql.*;
import javax.naming.*;
import javax.sql.*;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.ResultSetMetaData; public class run {
public static void main(String[] args) { test("select * from d_org");
} public static void test(String sql){
Connect _connect=new Connect();
Connection con=_connect.getconnect();
try
{
Statement statement = con.createStatement();
// 3.ResultSet类,用来存放获取的结果集!!
ResultSet rs = statement.executeQuery(sql);
ResultSetMetaData rsmd = rs.getMetaData();
int columnsNumber = rsmd.getColumnCount();
while (rs.next()) {
for (int i = 1; i <= columnsNumber; i++) {
if (i > 1) System.out.print(", ");
String columnValue = rs.getString(i);
System.out.print(rsmd.getColumnName(i) + " " + columnValue);
}
System.out.println("\n");
} }
catch (Exception e)
{
e.printStackTrace();
} } }
其他两个访问数据库查询和保存结果的类:
package com.ins; import java.sql.*;
import javax.naming.*;
import javax.sql.*;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.ResultSetMetaData; public class ExeQueryResult {
public String[][] getSelectResultWithStringArray(String sql)
{
Connect _connect=new Connect(); //连接数据库
Connection con=_connect.getconnect(); if(con==null)
return null; try
{
Statement statement = con.createStatement();
ResultSet rs = statement.executeQuery(sql); // 3.ResultSet类,用来存放获取的结果集!! if(rs==null){
System.out.println("查询结果为空!\n");
return null;
} ResultSetMetaData rsmd = rs.getMetaData();
int rowsNumber = 0;
int columnsNumber = rsmd.getColumnCount(); //列数目
rs.last();
rowsNumber=rs.getRow(); //行数目
rs.first(); Object o;
Object[][] ob = new Object[rowsNumber][columnsNumber];
int colType; for (int i = 0; i < rowsNumber; i++) {
for (int j = 0; j < columnsNumber; j++) {
o = rs.getObject(j + 1);
if(getIndexType(rs,j) == 0)
System.out.print("没有该类型!");
else {
colType = getIndexType(rs,j);
switch (colType) {
case java.sql.Types.DATE:
Date d = (Date) o;
if (d != null)
{
ob[i][j] = d.toString();
}
break;
case java.sql.Types.TIME:
Time t = (Time) o;
if (t != null)
{
ob[i][j] = t.toString();
}
break;
case java.sql.Types.TIMESTAMP: //时间戳
Timestamp ts = (Timestamp) o;
if (ts != null)
{
ob[i][j] = ts.toString();
}
break;
default:
ob[i][j] = o;
break;
}
} }
rs.next();
}
con.close(); String[][] s = new String[ob.length][ob[0].length];
for (int i = 0; i < ob.length; i++) {
for (int j = 0; j < ob[i].length; j++) {
if (ob[i][j] != null) { s[i][j] = ob[i][j].toString().trim(); //tirm()去掉两端多余字符
}
else {
s[i][j] = "";
}
}
} return s;
}
catch (Exception e)
{
e.printStackTrace();
return null;
}
} private int getIndexType(ResultSet set,int i) {
int type = 0;
try {
/*
getColumType()方法
方法说明:根据字段的索引值取得字段的类型,返回值的定义在java.sql.Type类
参数:column,字段的索引值,从1开始
返回值:字符串,SQL的数据类型定义在java.sql.Type类
异常产生:数据库发生任何的错误,则会产生一个SQLException对象
*/
type = set.getMetaData().getColumnType(i + 1);
}
catch (SQLException e) {
e.printStackTrace();
}
return type;
} } /*
int r=0;
for (int i = 1; i <= columnsNumber; i++) {
String s1=rsmd.getColumnLabel(i);
s[0][i]=s1;
} rs.first();
while (rs.next()) {
r++;
for(int i=1;i<=columnsNumber;i++){
String columnValue =new String(rs.getString(i));
s[r][i]=columnValue;
}
} */
package com.ins; import java.sql.*;
import java.util.*;
import javax.naming.*;
import javax.sql.*;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.ResultSetMetaData; public class ExeInsertUpdateDelete {
public final static int INSERT = 1; //插入
public final static int UPDATE = 2; //修改
public final static int DELETE = 3; //删除
public static String keyMark = "$"; //关键子段标识
public static String nonKeyMark ="_"; //一般字段标识 Connect _connect=new Connect();
Connection con=_connect.getconnect(); public boolean execSql(String tableName,int tableAction,Hashtable dbParam){
return false;
} public boolean execSql(String sqlStr){ try{
Statement stmt1 =con.createStatement(); // 创建用于执行静态sql语句的Statement对象
//String sql="insert into d_org(ORG_ID,ORG_NAME,ORG_ORDER,UP_ORG_ID) values (1,null,null,0)" ;
stmt1.executeUpdate(sqlStr);
return true;
}
catch (SQLException e){
e.printStackTrace();
return false;
}
// return false;
} public boolean execSql(String[] sql){ Statement statement=null;
try {
Class.forName("com.mysql.jdbc.Driver"); //加载驱动
statement =con.createStatement();
con.setAutoCommit(false); //相当于 set autocommit=0;
statement =con.createStatement();
for(int i=0;i<sql.length;i++) {
statement.addBatch(sql[i]);
}
statement.executeBatch(); //将上述SQL语句批量执行。
con.commit(); //executeBatch()语句若不出错,提交事务。
return true;
}
catch (Exception e) {
try {
//如果在创建连接对象过程中爆发异常,connection就会为null。若不加if语句,就会出现空指针异常。
if(con!=null) {
con.rollback(); //executeBatch()语句若出错,回滚,两个SQL语句执行不成功。
}
} catch (SQLException e1) {
e1.printStackTrace();
}
e.printStackTrace();
return false;
}
finally {
try {
if (statement!=null) {
statement.close();
}
}
catch (SQLException e) {
e.printStackTrace();
}
try {
if (con!=null) {
con.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
MyEclipse web项目连接数据库的更多相关文章
- MyEclipse Web项目部署失败:Deployment failure on Tomcat 7.x.Could not copy all resources to XXX.
在做第一个MyEclipse web项目时,总是部署失败: Deployment failure on Tomcat 7.x.Could not copy all resources to XXX.I ...
- MyEclipse web项目导入Eclipse,详细说明
最近导入一个MyEclipse的项目,具体是:spring4.1的web项目,同时遇到了一些问题,总结一下. 1.进入项目目录,找到.project文件,打开.增加一个<buildCommand ...
- Java.MyEclipse Web项目导入Eclipse
Java项目, 在MyEclipse中开发保存的目录结构和配置, 是不能直接在Eclipse中导入和运行的; 有时我们会碰到想把MyEclipse项目导入到Eclipse中开发的需求, 记录过程如下: ...
- Myeclipse - Web项目转换技巧--处理Java项目、SVN非Web项目问题
喜欢从业的专注,七分学习的态度. 概述 对于Java调试,使用Eclipse习惯性的使用Junit调试,使用Myeclipse习惯性的将项目转成Web项目在Tomcat或Weblogic中调试,在My ...
- myeclipse:web项目不能显示Web App Libraries
项目根路径下.classpath文件,加上 <classpathentry kind="con" path="org.eclipse.jst.j2ee.intern ...
- MyEclipse Web项目调试
1.发布项目 2.启动服务 服务有两种启动方式,Run Server和Debug Server Run Server是运行模式,Debug Server是调试模式 使用Debug Server模式启动 ...
- MyEclipse Web 项目导入 Eclipse 中需要改的文件
来自为知笔记(Wiz)
- servlet web项目连接数据库报错
报错信息类似这样: Wed May 27 14:15:54 CST 2020 WARN: Establishing SSL connection without server's identity v ...
- myeclipse中的web项目导入到eclipse中注意事项,项目部署到tomcat后无法访问jsp文件
打开eclipse,点击空白处,右键可以看到import>general>existing projects into workspace>next>选择你的myeclipse ...
随机推荐
- Springboot中如何自定义注解以及使用2例
不说废话,直接进入正题: java自定义注解主要有3步:1.编写@interface接口2.编写@interface对应的处理方法进行处理3.调用处理方法 示例一:判断奇偶:比如有一个字段no要判断奇 ...
- Java—包装类/System类/Math类/Arrays类/大数据运算/Collection接口/Iterator迭代器
基本类型包装类 8种基本类型对应的包装类如: 将字符串转成基本类型: 将基本数值转成字符串有3种方式: 基本类型直接与””相连接即可:34+" " 调用String的valueOf ...
- Java—匿名对象/内部类/访问修饰符/代码块
匿名对象 匿名对象是指创建对象时,只有创建对象的语句,却没有把对象地址值赋值给某个变量. //创建一个普通对象 Person p = new Person(); //创建一个匿名对象 new Pers ...
- 高级搜索树-红黑树(RBTree)解析
目录 红黑树的定义 节点与树的定义 旋转操作 插入操作 情况1:p的兄弟u为黑色 情况2: p的兄弟u为红色 插入操作性能分析 代码实现 删除操作 情况1:x的接替者succ为红色 情况2:x的接替者 ...
- Butterfly侧边栏引入一言
此教程涉及修改源码 背景 在修改每页显示7篇文章后,出现了这种情况. 这是完美主义(强迫症)的我所不能忍受的,有什么可以占据这里的呢?{% btn 'https://hitokoto.cn/',一言, ...
- Golang Gtk+3教程:开始
GTK+是一个控件工具包.每个通过GTK+创建的用户界面由一些控件组成. 控件是层级式的,window控件是主容器,通过在window中添加按钮.下拉菜单.输入字段等其他控件构成用户界面. 如果是复杂 ...
- 【SCOI2013】摩托车交易 - 最大生成树+树链剖分
题目描述 mzry1992 在打完吊针出院之后,买了辆新摩托车,开始了在周边城市的黄金运送生意.在mzry1992 生活的地方,城市之间是用双向高速公路连接的.另外,每条高速公路有一个载重上限,即在不 ...
- unity探索者之复制内容到剪贴板
版权声明:本文为原创文章,转载请声明http://www.cnblogs.com/unityExplorer/p/8417014.html unity中提供的TextEditor类,只能在window ...
- 第一篇博客 Python开发环境配置
本文主要介绍Windows7环境下安装并配置Anaconda+VSCode作为Python开发环境. 目录 Anaconda与包管理配 Anaconda安装 添加环境变量 Anaconda安装错误及解 ...
- Jmeter系列(55)- 详解 Throughput Controller 吞吐量控制器
如果你想从头学习Jmeter,可以看看这个系列的文章哦 https://www.cnblogs.com/poloyy/category/1746599.html 简单介绍 自行调整该控制器下的子项的执 ...