当前位置:首页 > 学习笔记 > 正文内容

优化jdbc的代码 面向对象思想

廖万里2年前 (2022-09-09)学习笔记41132

封装父类  BaseDao

3.1 三个属性

//属性

protected Connection conn;

protected PreparedStatement pstm;

protected ResultSet rs;

3.2 四个方法

//方法

public void openDB(){

//1 开库

try {

Class.forName("com.mysql.jdbc.Driver");

 conn=DriverManager.

getConnection("jdbc:mysql://localhost:3306/my105","root","123456");

catch (Exception e) {

// TODO Auto-generated catch block

e.printStackTrace();

System.out.println("开错误");

}


}

public void closeDB(){


try {

if(rs!=null){

rs.close();

}

if(pstm!=null){

pstm.close();

}

if(conn!=null){

conn.close();

}


catch (Exception e) {

// TODO Auto-generated catch block

e.printStackTrace();

System.out.println("关错误");

}


}


//增删 改     INSERT INTO student( sname,age) VALUES(?,?)

//可变参数  object[]

public int myUpdate(String sql,

Object... os){

int n=0;

try {

//1 开库

openDB();

//2

pstm=conn.prepareStatement(sql);


if(os!=null){//sql有? 

for(int i=0;i<os.length;i++){

pstm.setObject(i+1, os[i]);

}

}

//3 执行

 n=pstm.executeUpdate();


catch (Exception e) {

// TODO: handle exception

e.printStackTrace();//一定有异常打印

}finally{

//4 必须关闭数据库

closeDB();

}


return n;

}



public ResultSet mySelect(String sql,Object... os){


try {

//1

openDB();

//2

pstm=conn.prepareStatement(sql);

if(os!=null){//sql有? 

for(int i=0;i<os.length;i++){

pstm.setObject(i+1, os[i]);

}

}

//3 

rs=pstm.executeQuery();


catch (Exception e) {

// TODO: handle exception

e.printStackTrace();

}finally{

//2

//closeDB();

}


return rs;


}

 4 实体类 

Jdbc  操作  

实体类   数据表相同的

类名=表名

类的属性和表的列要一模一样 名称 和类型一样 

类的所有属性private  .封装get/set   shift+alt+s  

 

 

作用

查询的时候,把查询的结果 封装到 实体类的集合中

 5 表的子类


本文链接:https://www.kkkliao.cn/?id=10 转载需授权!

分享到:

添加博主微信共同交流探讨信息差网赚项目: 19528888767 , 请猛戳这里→点我添加

版权声明:本文由廖万里的博客发布,如需转载请注明出处。

“优化jdbc的代码 面向对象思想 ” 的相关文章

万策云网络工作室旗下高性能服务器,保证用户数据安全

万策云网络工作室旗下高性能服务器,保证用户数据安全

万策云工作室旗下所有业务均使用1T高防高性能服务器,数据定时备份,多台服务器实时同步数据,保障用户数据安全!多台服务器定时备份,企业级安全,50m独享,大带宽抗cc文件实时同步备份,数据库定时备份。主服务器采用T级群防,150G单机防御的国内高性能服务器。秒解机器!真实可测客户数据丢了都可以找回来...

如何配置mybatis并且自动生成实体类pojo和mapper

如何配置mybatis并且自动生成实体类pojo和mapper

1如何配置mybatis1.1 复制jar 点击下载mybatis和mysql的jar包:mybatis和mysql的jar包 - 万策云盘编辑1.2 复制配置文件 resources配置文件下载: resources配置文件 - 万策云盘编辑1.3...

Spring框架提供的多种属性注入方式

Spring框架提供的多种属性注入方式

1 set注入注入的成员变量必须要封装  set方法注入bean<!--成员变量对象--><!--<bean id="u" class="com.bdqn.User"></bean&g...

python如何连接mysql数据库

python链接mysql数据库要用到pymysql模块中的connect ,connect函数是pymysql模块中 用于连接MySQL数据库的一个函数。 所以连接mysql之前需要先导入pymysql模块 location.href="ht...

使用Python制作电脑无限弹窗恶搞程序教程

使用Python制作电脑无限弹窗恶搞程序教程

 效果如下:编辑演示视频:python弹窗恶搞程序演示视频 教程:1,导入模块,下载模块的方法不过多说明了,可以看我其他的文章有说怎么下载第三方模块,或者Alt+Enter下载也可。# 弹窗恶搞import tkinter as tkimp...

如何在程序中实现多进程,多进程概述

如何在程序中实现多进程,多进程概述

 多进程:在一个程序中实现多任务处理,可以使用多线程和多进程两种方式。多进程创建:使用Process、类,每次实例化这个类的时候,就创建一个进程对象。编辑 多进程:一个程序运行中,产生了多个进程。N个正在运行的程序----至少N个程序1个程序------可能只有一个进程/也可能有...