日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java代码连接jdbc_纯JDBC代码连接实例 + 完整代码

發布時間:2024/6/1 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java代码连接jdbc_纯JDBC代码连接实例 + 完整代码 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

JDBC連接數據庫實例

1、 數據庫表

1.1、創建表

CREATE TABLE `users`(

`uid` INT NOT NULL AUTO_INCREMENT COMMENT '用戶id',

`uname` VARCHAR(20) NOT NULL COMMENT '用戶名',

`upass` VARCHAR(20) NOT NULL COMMENT '用戶密碼',

PRIMARY KEY (`uid`)

)ENGINE = INNODB DEFAULT CHARSET = utf8;

1.2、插入數據

INSERT INTO `users` (`uname`,`upass`) VALUES

('zhangwuji','123456'),

('zhaomin','123456'),

('zhouzhiruo','123456'),

('xiaozhao','123456');

1.3、查看表

?

2、 java部分

2.1根據數據庫表中的字段創建pojo對象

package com.cugb.pojo;

import lombok.ToString;

/**

* @author huangjian

* @data 2020/7/6 11:11

*/

public class Users {

//用戶id

private int uid;

//用戶名

private String uname;

//密碼

private String upass;

public Users() {

}

public Users(int uid, String uname, String upass) {

this.uid = uid;

this.uname = uname;

this.upass = upass;

}

public int getUid() {

return uid;

}

public void setUid(int uid) {

this.uid = uid;

}

public String getUname() {

return uname;

}

public void setUname(String uname) {

this.uname = uname;

}

public String getUpass() {

return upass;

}

public void setUpass(String upass) {

this.upass = upass;

}

@Override

public String toString() {

return "uid:" + uid + "\t" + "uname:" + uname+ "\t" +"upass:" + upass;

}

}

2.2、創建連接jdbc的工具類

package com.cugb.utils;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.SQLException;

import com.mysql.jdbc.Driver;

public class DBUTils {

private static String url = "jdbc:mysql://localhost:3306/mybatis?characterEncoding=UTF8";

private static String user = "root";

private static String pass = "123456";

static {

try {

new Driver();

} catch (SQLException e) {

e.printStackTrace();

}

}

//連接數據庫

public static Connection getConnection() {

Connection conn = null;

try {

conn = DriverManager.getConnection(url,user,pass);

} catch (Exception e) {

e.printStackTrace();

}

return conn;

}

//查詢

public static Object[] Query(String sql) {

Connection conn = getConnection();

PreparedStatement pst =null;

ResultSet rs = null;

try {

pst = conn.prepareStatement(sql);

rs = pst.executeQuery();

} catch (SQLException e) {

e.printStackTrace();

}

Object[] obj = new Object[]{rs,pst,conn};

return obj;

}

//增刪改

public static boolean DML(String sql, Object[] object) {

Connection conn = getConnection();

PreparedStatement pst = null;

Boolean b = false;

try {

pst = conn.prepareStatement(sql);

for(int i=0; i

pst.setObject(i+1, object[i]);

}

b = pst.executeUpdate()==1;

} catch (SQLException e) {

e.printStackTrace();

}

close(conn,pst,null);

return b;

}

//關閉資源

public static void close(Connection conn,PreparedStatement pst,ResultSet rs){

try{

if(rs != null && !rs.isClosed()) {

rs.close();

}

if(pst != null && !pst.isClosed()){

pst.close();

}

if(conn != null && !conn.isClosed()){

conn.close();

}

}catch(Exception e){

e.printStackTrace();

}

}

}

2.3、dao層創建接口,并添加增、刪、改、查等方法

import com.cugb.pojo.Users;

import java.util.ArrayList;

public interface UsersDao {

//查詢用戶

public ArrayList queryUsers(String sql);

//添加用戶

public boolean addUser(Users user);

//修改用戶

public boolean changeUser(String sql,Object[] obj);

}

dao層創建接口實現類,并重寫接口的方法

package com.cugb.dao;

import com.cugb.pojo.Users;

import com.cugb.utils.DBUTils;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.util.ArrayList;

/**

* @author huangjian

* @data 2020/7/6 11:37

*/

public class UsersDaoImpl implements UsersDao {

//查詢用戶

public ArrayList queryUsers(String sql){

Object[] obj = DBUTils.Query(sql);

ResultSet rs = (ResultSet)obj[0];

ArrayList list = new ArrayList();

try {

while(rs.next()){

int uid = rs.getInt(1);

String uname = rs.getString(2);

String upass = rs.getString(3);

Users user = new Users(uid,uname,upass);

list.add(user);

}

} catch (SQLException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

PreparedStatement pst = (PreparedStatement)obj[1];

Connection conn = (Connection)obj[2];

DBUTils.close(conn, pst, rs);

return list;

}

//添加用戶

public boolean addUser(Users user) {

String sql = "insert into Users (uname,upass values (?,?)";

Object[] obj = new Object[]{user.getUname(),user.getUpass()};

boolean flag = DBUTils.DML(sql, obj);

return flag;

};

//修改用戶

public boolean changeUser(String sql,Object[] obj) {

boolean flag = DBUTils.DML(sql, obj);

return flag;

}

}

2.4、測試類查詢功能

package com.cugb.test;

import com.cugb.dao.UsersDaoImpl;

import com.cugb.pojo.Users;

import java.util.ArrayList;

/**

* @author huangjian

* @data 2020/7/6 11:49

*/

public class UsersTest {

public static void main(String[] args) {

UsersDaoImpl usersDao = new UsersDaoImpl();

String sql = "select * from users";

ArrayList list = usersDao.queryUsers(sql);

for (Users users : list) {

System.out.println(users);

}

}

}

3、結果

uid:1uname:zhangwujiupass:123456

uid:2uname:zhaominupass:123456

uid:3uname:zhouzhiruoupass:123456

uid:4uname:xiaozhaoupass:123456

總結

以上是生活随笔為你收集整理的java代码连接jdbc_纯JDBC代码连接实例 + 完整代码的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。