JDBC+MYSQL初始学习
JDBC+MYSQL初始学习
一、学习准备
Eclipse 开发工具 + mysql数据库+navicat 数据库连接工具
Mysql的数据库连接驱动jar包 + testing测试集成+maven工具集成
Jar的获取方法:
1、直接下载需要的jar,导入项目中使用。
2、在maven工程中加入依赖:本文使用的maven依赖:
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.38</version>
</dependency>
<dependency>
<groupId>org.testng</groupId>
<artifactId>testng</artifactId>
<version>6.0</version>
</dependency>
二、JDBC简单实用步骤:
Jdbc连接数据库操作,主要分为三个步骤:本文以mysql为例操作说明:
2.1加载驱动程序
Class.forName("com.mysql.jdbc.Driver");
2.2获取数据库连接
conn = DriverManager.getConnection(URL, USER, PASSWORD);
2.3对数据库的表结构进行CURD操作
三、JDBC增、删、改、查
3.1 通过navicat 连接本地mysql 创建user表结构:

3.2 建立相关的类来实现jdbc的crud的操作
3.1.1 模型类User
User类用于和数据库user表映射,方便CURD的实时操作。
/**
*
*/
package com.lilin.maven.service.jdbc; /**
* @author lilin
*
*/
public class User { private Integer id; /**
* 用户名称
*/
private String name; /**
* 用户密码
*/
private String password; public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
} public Integer getId() {
return id;
} public void setId(Integer id) {
this.id = id;
} public String toString() {
return "user 的名称是" + name + " user的密码是:" + password;
} }
3.1.2 工具类JdbcUtil
工具类主要定义了数据库连接的相关属性:URL 、USER、PASSWORD
工具类在静态块中获取了数据库的连接,存放于私有CONN中,同时对外提供了访问连接的公共方法:getConnection
/**
*
*/
package com.lilin.maven.service.jdbc; import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException; /**
* @author lilin
*
*/
public class JdbcUtil {
public static final String URL = "jdbc:mysql://127.0.0.1:3306/test"; public static final String USER = "root"; public static final String PASSWORD = "1"; private static Connection conn = null; /**
* 静态块 获取数据库的连接
*/
static {
try {
// 1.加载驱动程序
Class.forName("com.mysql.jdbc.Driver");
// 2.获取数据库连接
conn = DriverManager.getConnection(URL, USER, PASSWORD);
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
} /**
* 提供获取连接的调用方法
*
* @return
*/
public static Connection getConnection() {
return conn;
}
}
3.1.3 逻辑层类UserService
UserService类,主要是通过调用工具类,获取数据库连接,然后使用连接,配合好编写的sql语句,来对数据库中的user表来进行CURD操作,包含了一系列的常用的处理。
/**
*
*/
package com.lilin.maven.service.jdbc; import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List; /**
* @author lilin
*
*/
public class UserService { private Connection connection = JdbcUtil.getConnection(); /**
* 新增用户信息
*
* @param user
* @throws Exception
*/
public void addUser(User user) throws Exception {
String sql = " insert into user(NAME,PASS_WORD)values(?,?)";
// 预编译sql语句 在excute的时候真正执行
PreparedStatement ptmt = connection.prepareStatement(sql);
// 传递参数 补充完整的sql
ptmt.setString(1, user.getName());
ptmt.setString(2, user.getPassword());
ptmt.execute();
} /**
* 删除用户信息
*
* @param user
* @throws Exception
*/
public void deleteUser(Integer id) throws Exception {
String sql = " delete from user where ID=?";
// 预编译sql语句 在excute的时候真正执行
PreparedStatement ptmt = connection.prepareStatement(sql);
// 传递参数 补充完整的sql
ptmt.setInt(1, id);
ptmt.execute();
} /**
* 更新用户信息
*
* @param user
* @throws Exception
*/
public void updateUser(User user) throws Exception {
String sql = " update user set NAME=? ,PASS_WORD=? where ID=?";
// 预编译sql语句 在excute的时候真正执行
PreparedStatement ptmt = connection.prepareStatement(sql);
// 传递参数 补充完整的sql
ptmt.setInt(3, user.getId());
ptmt.setString(1, user.getName());
ptmt.setString(2, user.getPassword());
ptmt.execute();
} /**
* 查询单个用户信息
*
* @param user
* @throws Exception
*/
public User getUserByName(String name) throws Exception {
String sql = " select * from user where NAME=?";
// 预编译sql语句 在excute的时候真正执行
PreparedStatement ptmt = connection.prepareStatement(sql);
// 传递参数 补充完整的sql
ptmt.setString(1, name);
ResultSet resultSet = ptmt.executeQuery();
User user = null;
while (resultSet.next()) {
user = new User();
user.setId(resultSet.getInt("ID"));
user.setName(resultSet.getString("NAME"));
user.setPassword(resultSet.getString("PASS_WORD"));
}
return user;
} /**
* 查询所有的用户信息
*
* @return
* @throws Exception
*/
public List<User> getUsers() throws Exception {
// 3.操作数据库 实现增删改查
Statement statement = connection.createStatement();
ResultSet resultSet = statement.executeQuery("select * from user");
List<User> list = new ArrayList<User>();
User user = null;
while (resultSet.next()) {
user = new User();
String name = resultSet.getString("NAME");
String passWord = resultSet.getString("PASS_WORD");
user.setName(name);
user.setPassword(passWord);
list.add(user);
}
return list;
} }
3.1.4 testNG测试类 jdbctest
JdbcTest中,实现了多个测试方法,userserice中的CURD的方法,全部有对应的测试function:通过运行测试方法,以及配合使用navicat实时查询数据库的user表的数据的实时变化,以便于验证JDBC对于mysql的数据库操作的正确性。
/**
*
*/
package com.lilin.maven.service.jdbc; import java.util.List;
import java.util.Scanner; import org.testng.annotations.Test; /**
* @author lilin
*
*/
public class JdbcTest { private UserService userService = new UserService(); @Test
public void testGetUsers() throws Exception {
List<User> users = userService.getUsers();
for (User user : users) {
System.out.println(user);
}
} @Test
public void testAddUser() throws Exception {
User user = new User();
user.setName("李林");
user.setPassword("12345");
userService.addUser(user);
} @Test
public void testUpdateUser() throws Exception {
User user = new User();
user.setId(1);
user.setName("bb");
user.setPassword("12345");
userService.updateUser(user);
} @Test
public void testDeleteUser() throws Exception {
userService.deleteUser(4);
} @Test
public void testgetUserByName() throws Exception {
User user = userService.getUserByName("bb");
System.out.println(user);
} }
JDBC+MYSQL初始学习的更多相关文章
- MySQL数据库学习笔记(十)----JDBC事务处理、封装JDBC工具类
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- MySQL数据库学习笔记(九)----JDBC的ResultSet接口(查询操作)、PreparedStatement接口重构增删改查(含SQL注入的解释)
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- MySQL数据库学习笔记(八)----JDBC入门及简单增删改数据库的操作
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- JDBC MYSQL 学习笔记(一) JDBC 基本使用
1.JDBC简单介绍 SUN公司为了简化.统一对数据库的操作,定义了一套Java操作数据库的规范.称之为JDBC. JDBC全称为:Java Data Base Connectivity(java数据 ...
- MySQL数据库学习笔记(十一)----DAO设计模式实现数据库的增删改查(进一步封装JDBC工具类)
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- jdbc的入门学习
一.JDBC相关概念介绍 1.1.数据库驱动 这里的驱动的概念和平时听到的那种驱动的概念是一样的,比如平时购买的声卡,网卡直接插到计算机上面是不能用的,必须要安装相应的驱动程序之后才能够使用声卡和网卡 ...
- JDBC主要API学习总结
JDBC主要API学习 一.JDBC主要API简介 JDBC API 是一系列的接口,它使得应用程序能够进行数据库联接,执行SQL语句,并且得到返回结果. 二.Driver 接口 Java.sql.D ...
- JSP+Struts2+JDBC+Mysql实现的校园宿舍管理系统
项目简介 项目来源于:https://gitee.com/passenger134/javaweb-sushe 本系统基于JSP+Struts2+JDBC+Mysql的校园宿舍管理系统.该系统没有使用 ...
- JSP+Structs+JDBC+mysql实现的诚欣电子商城
项目简介 项目来源于:https://github.com/SuperiorNature/Java-Enterprise-electronic-mall 本系统是基于JSP+Structs+JDBC+ ...
随机推荐
- 关于MySQL Server影响ASP.NET网站使用的问题:未能加载文件或程序集MySql.Web.v20
最近开发的ASP.NET MVC 4网站,之前头头说如果遇到装过MySQL的机器就绕着走,还觉得奇怪 嘛,该来的迟早都会来 于是撞上了一台 启动网站再访问,总是出错,提示“未能加载文件或程序集”,名字 ...
- package、folder和source folder的区别
在用myeclipse工具开发java的过程中,新建目录时发现会有package,folder和source folder等不同类型的选项, 因此在网上搜集了一些资料:如下 以下文章转自:https: ...
- loadrunner报错总结
1.报错 没有缓存空间可用 TCP超时释放时间?是解决刚才那个报错的? 解决方法如下 修改TcpTimedWaitDelay值为1和MaxUserPort值为65534.最后,重启! 完美 ...
- 【剑指Offer】41、和为S的连续正数序列
题目描述: 小明很喜欢数学,有一天他在做数学作业时,要求计算出9~16的和,他马上就写出了正确答案是100.但是他并不满足于此,他在想究竟有多少种连续的正数序列的和为100(至少包括两个数). ...
- 10.01QBXT集训
a[问题描述]你是能看到第一题的 friends呢.—— hja何大爷对字符串十分有研究,于是天出题虐杀 zhx.何大爷今天为 何大爷今天为 字符串定义了新的权值计算方法.一个由小写母组成,被定义为其 ...
- Centos 7源码编译搭建Nginx
一.Nginx入门介绍 1. Nginx(engine x):[ˈendʒɪnks] 2. Nginx 是 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,第一个公开版 ...
- 【[Offer收割]编程练习赛15 C】过河问题
[题目链接]:http://hihocoder.com/problemset/problem/1516 [题意] [题解] 状态压缩DP+bfs 这个过河问题能用bfs来搞.涨知识了; 首先; 16个 ...
- JavaSE 学习笔记之继承(五)
继 承(面向对象特征之一) 好处: 1:提高了代码的复用性. 2:让类与类之间产生了关系,提供了另一个特征多态的前提. 父类的由来:其实是由多个类不断向上抽取共性内容而来的. java中对于继承,ja ...
- 使用PSI-probe监控tomcat7
http://www.lambdaprobe.org/ http://blog.csdn.net/tanglei6636/article/details/70169153 http://blog.cs ...
- IDEA入门级使用教程
原文链接:https://blog.csdn.net/qq_31655965/article/details/52788374 最智能的IDE IDEA相对于eclipse来说最大的优点就是它比ecl ...