第一步:准备好我们的源码
第二步:准备好MySQL(Linux,Windows,云端)
- 数据库的IP:
- 数据库的端口:
- 数据库的数据库名:
- 数据库的登录用户名
- 数据库的登录密码:
- 查看数据库的版本
第四步:准备好MySQL官网的jar包,包要与数据库版本一一对应
(SELECT @@VERSION;)//查看MySQL数据库版本
第五步:打开idea 建立以下包:
这里的Student是个对象类,
Dao包是数据访问层;
Service包是业务逻辑层;
Controlier是展示层;
JDBC包放的是工具类,用来连接数据库;
Lib包放的是MySQL官网的jar包;
第六步:将准备好的jar包拖到lib包内:
如下:
然后右键点击它
点击蓝色的Add as Library
然后点击OK
第七步:
在until下建立一个工具类,类名自定义即可:
输入以下内容:
private static String url = "jdbc:mysql://192.168.64.12*:3306/goods";
// 192.168.64.12*是IP ,3306是端口 IP和端口改成自己的
private static String dbName = "root"; // 数据库用户名
private static String dbPass = "123456"; // 数据库密码
public static Connection conn=null;
public static PreparedStatement pstmt=null;
public static ResultSet rs =null;
public static Connection getConn() throws Exception{
Class.forName("com.mysql.cj.jdbc.Driver");//加载驱动
return DriverManager.getConnection(url,dbName,dbPass);
//Class.forName("com.mysql.cj.jdbc.Driver");//加载驱动
//return DriverManager.getConnection(url,dbName,dbPass);
//这两句是固定的
}
public static void closeAll(Connection conn, PreparedStatement pstmt, ResultSet rs) throws Exception{//关流操作方法
if(conn!=null)
conn.close();
if(pstmt!=null){
pstmt.close();
}
if(rs!=null){
rs.close();
}
}
第八步:创建对象类,将其他代码用分类分包的思想写入
(这里不会写入的自己加班加点想办法完成,本文档不管,上课讲的时候干鸡毛去了?一点也不尊重老师)
第九步:
分类分包思路: 对象类------dao包(数据访问层(增删改查))-------- Service包(业务逻辑层 写业务的比如登录验证啥的)------- Controlier(展示层(通常该类里面写的是连接网页的代码))
注:本文档这里Controlier以Java代码的形式使用!
Dao包内有两个文件
首先StudentDao很明显从图片上来看就知道它是一个接口,(注意:先建立接口然后再建接口实现类)
public interface StudentDao {//写所需要的方法
int studentAdd(Student std) throws Exception;
void studentDel(ArrayList<Student> L) throws Exception;
void studentChange(ArrayList<Student> L) throws Exception;
void studentCheck() throws Exception;
}
然后StudentDaoimpl:
@Override
public void studentAdd() throws Exception {
List<Student> L=check();
Scanner sc=new Scanner(System.in);
String ID="";
Student x;
System.out.print("请输入学生学号:");
String id=sc.next();
for (int i = 0; i <L.size() ; i++) {
x = L.get(i);
ID = x.getId();
}
if(id.equals(ID)){
System.out.println("学号已被使用,请重新输入");}
else {
Student x1=new Student();
x1.setId(id);
System.out.print("请输入学生姓名:");
String name = sc.next();
x1.setName(name);
System.out.print("请输入学生年龄:");
int age = sc.nextInt();
x1.setAge(age);
System.out.print("请输入学生生日:");
String birth = sc.next();
x1.setBirth(birth);
String sql="INSERT INTO Std VALUES(?,?,?,?)";
String [] param={x1.getId(),x1.getName(),x1.getAge()+"",x1.getBirth()};
Stdtool.executeUpdataSQL(sql,param);
}
}
@Override
public void studentDel() throws Exception {
List<Student> L=check();
Scanner sc=new Scanner(System.in);
System.out.println("请输入要删除的学生学号:");
String ID=sc.next();
for (int i = 0; i <L.size() ; i++) {
Student x2=L.get(i);
String id=x2.getId();
if(ID.equals(id)){
String sql="delete from Std where id="+id+"";
//L.remove(i);
Stdtool.executeUpdataSQL1(sql);
System.out.println("删除成功!");
break;
}
else{
System.out.println("暂无信息!");
}
}
}
@Override
public void studentChange() throws Exception {
Scanner sc=new Scanner(System.in);
List<Student> L=check();
System.out.println("请输入要修改的学生学号");
String ID=sc.next();
for (int i = 0; i <L.size() ; i++) {
Student x3=L.get(i);
String id=x3.getId();
if(id.equals(ID)){
System.out.println("请输入新的姓名:");
String name=sc.next();
x3.setName(name);
System.out.println("请输入新的年龄:");
int age=sc.nextInt();
x3.setAge(age);
System.out.println("请输入新的生日:");
String birth=sc.next();
x3.setBirth(birth);
String sql = "update Std set name = '"+x3.getName()+"',age = '"+x3.getAge()+
"',birth = '"+x3.getBirth()+"'where id = '"+id+"'";
Stdtool.executeUpdataSQL1(sql);
System.out.println("修改成功!");
}
else{
System.out.println("暂无信息!");
}
}
}
@Override
public void studentCheck() throws Exception {//查询全部学生信息
String sql="SELECT * from Std";
Connection conn=Stdtool.getConn();
PreparedStatement pstmt = conn.prepareStatement(sql);
ResultSet rs=pstmt.executeQuery();
List<Student> list =new ArrayList<>();
while(rs.next()){
Student std=new Student();
std.setId(rs.getString(1));
std.setName(rs.getString(2));
std.setAge(rs.getInt(3));
std.setBirth(rs.getString(4));
list.add(std);
}
for(Student std:list){//遍历输出学生信息
System.out.println(std);
}
Stdtool.closeAll(conn,pstmt,rs);
}
public List<Student> check() throws Exception{//通用方法
String sql="SELECT * from Std";
Connection conn=Stdtool.getConn();
PreparedStatement pstmt = conn.prepareStatement(sql);
ResultSet rs=pstmt.executeQuery();
List<Student> list =new ArrayList<>();
while(rs.next()){
Student std=new Student();
std.setId(rs.getString(1));
std.setName(rs.getString(2));
std.setAge(rs.getInt(3));
std.setBirth(rs.getString(4));
list.add(std);
}
return list;
}
这里的dao包下的代码如上可以复制粘贴使用
按照自己的需求进行修改即可
如果有问题可以咨询我