package com.mvc.util;
import com.alibaba.druid.pool.DruidDataSourceFactory;
import javax.sql.DataSource;
import java.io.IOException;
import java.io.InputStream;
import java.sql.*;
import java.util.*;
public class JDBCUtil {
/*public static String DRIVER;
public static String URL;
public static String USER;
public static String PASSWORD;*/
/**
* 加载驱动
*/
public static DataSource dataSource = null;
static{
/*try {
//创建一个输入流
InputStream stream = JDBCUtil.class.getClassLoader().getResourceAsStream("druid.properties");
//创建一个Properties 对象
Properties p = new Properties();
p.load(stream);
DRIVER = (String)p.get("driver");
URL = (String)p.get("url");
USER = (String)p.get("user");
PASSWORD = (String)p.get("password");
Class.forName(DRIVER);
} catch (ClassNotFoundException | IOException e) {
e.printStackTrace();
}*/
try {
//创建一个输入流
InputStream stream = JDBCUtil.class.getClassLoader().getResourceAsStream("druid.properties");
//创建一个Properties 对象
Properties p = new Properties();
p.load(stream);
dataSource = DruidDataSourceFactory.createDataSource(p);
} catch (IOException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 创建连接
* 返回值类型是 Connection
* 方法名 getConn
* 无参
* @return
*/
public static Connection getConn(){
try {
return dataSource.getConnection();
} catch (SQLException e) {
e.printStackTrace();
}
return null;
}
/**
* 设置 sql语句参数
* 返回值类型 void
* 方法名setShuZu
* 参数列表 PreparedStatement ps, Object... object
* @param ps
* @param objects
*/
public static void setShuZu(PreparedStatement ps,Object... objects){
if (objects.length >0){
for (int i = 0; i < objects.length; i++) {
try {
ps.setObject(i+1,objects[i]);
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
/**
* 关闭连接
* 返回值类型 void
* 方法名 closeAll
* 参数列表 ResultSet resultSet,PreparedStatement ps,Connection conn
*/
public static void closeAll(ResultSet resultSet,PreparedStatement ps,Connection conn){
try {
if (resultSet != null){
resultSet.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
try {
if (ps != null){
ps.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
try {
if (conn != null){
conn.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
/**
* List<List>类型 查询</>
* 返回值类型 List<List></>
* 方法名queryList
*参数列表 String sql,Object... object
*/
public static List<List> queryList(String sql,Object... objects){
//获取连接
Connection conn = getConn();
PreparedStatement ps = null;
ResultSet resultSet = null;
ArrayList<List> lists = null;
try {
//sql预编译
ps = conn.prepareStatement(sql);
//调用setShuZu()方法为sql语句设置参数
setShuZu(ps,objects);
//执行sql语句
resultSet = ps.executeQuery();
//创建一个List<List>类型的集合 存放每次循环获得的一整条是数据
lists = new ArrayList<>();
//遍历 执行语句之后得到的ResultSet 集合
//因为里面不知道有几条数据 所以遍历要用while
while (resultSet.next()){
//创建一个ArrayList 集合 存放通过遍历列数获得的一条数据
List<Object> list = new ArrayList<>();
for (int i = 0; i < resultSet.getMetaData().getColumnCount(); i++) {
list.add(resultSet.getObject(i+1));
}
lists.add(list);
}
} catch (SQLException e) {
e.printStackTrace();
}finally {
closeAll(resultSet,ps,conn);
}
return lists;
}
/**
* List<Map<String,Object></>></>
* 返回值类型 List<Map<String,Object>
* 方法名 queryMap
* 参数列表 String sql,Object... object
*/
public static List<Map<String,Object>> queryMap(String sql, Object... objects){
//获取连接
Connection conn = getConn();
PreparedStatement ps = null;
ResultSet resultSet = null;
ArrayList<Map<String,Object>> lists = null;
try {
//sql预编译
ps = conn.prepareStatement(sql);
//调用setShuZu()方法为sql语句设置参数
setShuZu(ps,objects);
//执行sql语句
resultSet = ps.executeQuery();
//创建一个List<List>类型的集合 存放每次循环获得的一整条是数据
lists = new ArrayList<>();
//遍历 执行语句之后得到的ResultSet 集合
//因为里面不知道有几条数据 所以遍历要用while
while (resultSet.next()){
//创建一个HashMap<String, Object> 集合 存放通过遍历列数获得的一条数据
Map<String, Object> map = new HashMap<>();
for (int i = 0; i < resultSet.getMetaData().getColumnCount(); i++) {
map.put(resultSet.getMetaData().getColumnName(i+1),resultSet.getObject(i+1));
}
lists.add(map);
}
} catch (SQLException e) {
e.printStackTrace();
}finally {
closeAll(resultSet,ps,conn);
}
return lists;
}
/**
* 封装通用的增删改
* 返回值类型 int
* 方法名updates
* 参数列表 String sql,Object... object
*/
public static int update(String sql, Object... objects){
//获取连接
Connection conn = getConn();
PreparedStatement ps = null;
try {
//sql预编译
ps = conn.prepareStatement(sql);
//调用setShuZu()方法为sql语句设置参数
setShuZu(ps,objects);
//执行sql语句
int i = ps.executeUpdate();
return i;
} catch (SQLException e) {
e.printStackTrace();
}finally {
closeAll(null,ps,conn);
}
return -1;
}
/**
* 封装返回主键的方法
* 返回值类型 int
* 方法名 getPrimaryKey
* 参数列表 String sql,Object... object
*/
public static int getPrimaryKey(String sql, Object... objects){
//获取连接
Connection conn = getConn();
PreparedStatement ps = null;
ResultSet keys = null;
try {
//sql预编译
ps = conn.prepareStatement(sql,Statement.RETURN_GENERATED_KEYS);
//调用setShuZu()方法为sql语句设置参数
setShuZu(ps,objects);
//执行sql语句
ps.executeUpdate();
//获取主键
keys = ps.getGeneratedKeys();
if (keys.next()){
int i = keys.getInt(1);
return i;
}
} catch (SQLException e) {
e.printStackTrace();
}finally {
closeAll(keys,ps,conn);
}
return -1;
}
}
没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
收起资源包目录
mvc-master.zip (134个子文件)
layui.css 73KB
layer.css 14KB
layui.mobile.css 10KB
laydate.css 7KB
code.css 1KB
iconfont.eot 46KB
59.gif 10KB
22.gif 10KB
24.gif 8KB
13.gif 7KB
16.gif 7KB
39.gif 6KB
64.gif 6KB
63.gif 6KB
50.gif 6KB
loading-0.gif 6KB
4.gif 6KB
1.gif 5KB
42.gif 5KB
71.gif 5KB
21.gif 5KB
20.gif 5KB
29.gif 5KB
70.gif 4KB
5.gif 4KB
17.gif 4KB
27.gif 4KB
9.gif 4KB
44.gif 4KB
11.gif 4KB
8.gif 4KB
3.gif 4KB
23.gif 4KB
34.gif 4KB
41.gif 4KB
38.gif 4KB
65.gif 3KB
32.gif 3KB
45.gif 3KB
7.gif 3KB
12.gif 3KB
26.gif 3KB
60.gif 3KB
2.gif 3KB
40.gif 3KB
25.gif 3KB
19.gif 3KB
66.gif 3KB
18.gif 3KB
46.gif 3KB
10.gif 3KB
28.gif 3KB
51.gif 3KB
57.gif 3KB
67.gif 3KB
0.gif 3KB
48.gif 3KB
43.gif 3KB
30.gif 2KB
61.gif 2KB
33.gif 2KB
69.gif 2KB
14.gif 2KB
47.gif 2KB
36.gif 2KB
49.gif 2KB
58.gif 2KB
6.gif 2KB
54.gif 2KB
53.gif 2KB
56.gif 2KB
62.gif 2KB
31.gif 2KB
55.gif 2KB
35.gif 2KB
15.gif 2KB
loading-2.gif 2KB
37.gif 1KB
68.gif 1KB
52.gif 777B
loading-1.gif 701B
druid-1.1.9.jar 2.59MB
lombok.jar 1.83MB
mysql-connector-java-5.1.26-bin.jar 836KB
commons-collections-3.2.2.jar 575KB
jstl-1.2.jar 405KB
fastjson-1.2.9.jar 384KB
standard.jar 384KB
commons-beanutils-1.9.3.jar 240KB
servlet-api.jar 238KB
commons-logging-1.1.1.jar 59KB
JDBCUtil.java 8KB
UserServlet.java 5KB
UsDaoImpl.java 3KB
UserFilter.java 1KB
User.java 1KB
CharsetFilter.java 922B
IUsDao.java 911B
layui.all.js 272KB
jquery.js 95KB
共 134 条
- 1
- 2
资源评论
哆啦哆啦S梦
- 粉丝: 166
- 资源: 517
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- Toon Boom Storyboard Pro 是一款专业的故事板制作软件,专为动画制作和影视前期制作而设计
- Serif Affinity Designer 是一款专业的矢量图形设计软件,旨在提供强大的创意工具和无与伦比的性能
- dbeaver exe安装脚本
- 基于Python+OpenCV人脸识别考勤管理系统+源代码(高分毕业设计).zip
- Photoshop 900个矢量和Photoshop画笔
- 华为项目管理十大模板管理表格
- Scratch资源~打宝箱小游戏
- 使用 MATLAB 绘制傅里叶级数图案
- HarmonyOS个人项目(第一周)
- FSCapture 非常好用的录频,滚动截图输入图片、pdf软件
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功