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

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

廖万里3年前 (2022-09-09)学习笔记41216

封装父类  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 转载需授权!

分享到:

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


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

如何使用kaliLinux攻击“恶意网站“实验

如何使用kaliLinux攻击“恶意网站“实验

此内容仅为参考或学习,请勿用于其他非法用途用nmap扫描IP地址为8.142.***.***服务器的漏洞nmap --script vuln 8.142.***.***漏洞已经扫描出来了,出现"vulnerable"说明有漏洞下面"ids:...

MyBatis-写分页的几种方法,怎么写分页最简单

MyBatis-写分页的几种方法,怎么写分页最简单

1、就是直接使用我们的SQL语句进行分页,也就是在Mapper里面加上分页的语句就好了。比如MySQL添加一个limit 2,4。这种方式弊端很大,比如我们不用MySQL了,所有的代码都要修改。2、MyBatis中的分页的插件PageHelper,3、自己手写分页框架。这种用的比较少,不是说写不出来...

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

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

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

CloudDriver一款将各种网盘云盘挂在到电脑本地变成本地磁盘的工具 教程

CloudDriver一款将各种网盘云盘挂在到电脑本地变成本地磁盘的工具 教程

平时我们的电脑可能由于大量的文件资料之类的导致存储空间可能不够,所以我们可以选择将网盘我们的本地磁盘用来存放东西。CloudDrive 是一款可以将 115、阿里云盘、天翼云盘、沃家云盘、WebDAV 挂载到电脑中,成为本地硬盘的工具,支持 Windows 与 Dock...

一款安卓/鸿蒙设备也能够轻松连接homepod的插件,跨平台音乐推流工具airmusic分享

一款安卓/鸿蒙设备也能够轻松连接homepod的插件,跨平台音乐推流工具airmusic分享

编辑点评:支持多种音频传输的方案,最为重要的就是支持AirPlay设备支持多种上音频传输方式的一款神器,AirMusic安卓免费版,是个解锁了高级功能的版本,软件需要root权限,可以将音频内容以满足自己需求的方式来推送到你所需要的音响当中,让你的安卓设备也能够轻松的享受到各种不同的音响的内容。操作...

openwrt推荐固件 iStoreOS软路由科学上网插件passwall、SSR、OpenClash、和去广告等插件分享

openwrt推荐固件 iStoreOS软路由科学上网插件passwall、SSR、OpenClash、和去广告等插件分享

如何安装,下载后,iStore手动安装,选择文件安装即可。软件下载地址https://github.com/AUK9527/Are-u-ok直接访问github就可以下载。如果你不能访问github 那你要先解决这个问题,然后再去路由器里面安装插件。插件名功能下载PassWallPassWall 科...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。