相对完善的Java通过JDBC操纵mysql的例子

工具类:

 

ContractedBlock.gifExpandedBlockStart.gifCode
 1import java.sql.Connection;
 2import java.sql.DriverManager;
 3import java.sql.ResultSet;
 4import java.sql.SQLException;
 5import java.sql.Statement;
 6
 7
 8ExpandedBlockStart.gifContractedBlock.gifpublic final class JDBCUtils {
 9
10ExpandedSubBlockStart.gifContractedSubBlock.gif    private JDBCUtils(){}
11    
12    private static String url="jdbc:mysql://localhost:3306/forum";
13    private static String user="root";
14    private static String password="root";
15    
16ExpandedSubBlockStart.gifContractedSubBlock.gif    static{
17ExpandedSubBlockStart.gifContractedSubBlock.gif        try {
18            Class.forName("com.mysql.jdbc.Driver");
19ExpandedSubBlockStart.gifContractedSubBlock.gif        }
 catch (ClassNotFoundException e) {
20            throw new ExceptionInInitializerError(e);
21        }

22    }

23    
24    public static Connection getConnection() throws SQLException
25ExpandedSubBlockStart.gifContractedSubBlock.gif    {
26        return DriverManager.getConnection(url, user, password);        
27    }

28    
29    public static void free(ResultSet rs,Statement st,Connection conn)
30ExpandedSubBlockStart.gifContractedSubBlock.gif    {
31ExpandedSubBlockStart.gifContractedSubBlock.gif        try{
32            
33            if(rs!=null)
34                rs.close();
35ExpandedSubBlockStart.gifContractedSubBlock.gif        }
catch(SQLException e){
36            e.printStackTrace();
37ExpandedSubBlockStart.gifContractedSubBlock.gif        }
finally{
38            
39ExpandedSubBlockStart.gifContractedSubBlock.gif                        try{
40                            if(st!=null)
41                                st.close();
42ExpandedSubBlockStart.gifContractedSubBlock.gif                        }
catch(SQLException e){
43                            e.printStackTrace();
44ExpandedSubBlockStart.gifContractedSubBlock.gif                        }
finally{
45                            
46ExpandedSubBlockStart.gifContractedSubBlock.gif                                        try{
47                                            if(conn!=null)
48                                                conn.close();
49ExpandedSubBlockStart.gifContractedSubBlock.gif                                        }
catch(SQLException e){
50                                            e.printStackTrace();
51                                        }
        
52                        }

53        }

54    }

55}

56

使用的例子:

 

ContractedBlock.gifExpandedBlockStart.gifCode
 1ExpandedBlockStart.gifContractedBlock.gifpublic static void main(String[] args) {
 2        // TODO Auto-generated method stub
 3ExpandedSubBlockStart.gifContractedSubBlock.gif        try {
 4            JDBCUtilsTest();
 5ExpandedSubBlockStart.gifContractedSubBlock.gif        }
 catch (Exception e) {
 6            // TODO Auto-generated catch block
 7            e.printStackTrace();
 8        }

 9
10    }

11    
12    
13    public static void JDBCUtilsTest() throws Exception
14ExpandedBlockStart.gifContractedBlock.gif    {
15        Connection conn=null;
16        Statement st=null;
17        ResultSet rs=null;
18        
19ExpandedSubBlockStart.gifContractedSubBlock.gif        try{
20            conn=JDBCUtils.getConnection();
21            st=conn.createStatement();
22            rs=st.executeQuery("select * from user");
23            while(rs.next())
24ExpandedSubBlockStart.gifContractedSubBlock.gif            {
25                System.out.println(rs.getObject(1)+"\t"+rs.getObject(2));
26            }

27ExpandedSubBlockStart.gifContractedSubBlock.gif        }
finally{
28            JDBCUtils.free(rs, st, conn);
29        }
    
30        
31    }

转载于:https://www.cnblogs.com/sousou/archive/2009/01/20/1379102.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/305009.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何在 ASP.Net Core 中使用 File Providers

ASP.Net Core 为了便于获取文件和文件夹信息,监视文件变更, 在文件系统中提供了一个抽象层:File Providers, 这篇文章将会讨论如何使用 File Providers 。File Provider 抽象层 file prodivers 实现了 IFileProvider 接口&#xf…

对5种主流编程语言的吐槽

不可否认,想要成为一名优秀的程序员确实是需要掌握多种编程语言。通过这几年的自虐式学习,小编也慢慢的掌握了这些编程语言。接下来要为大家,介绍五款让人又爱又恨的编程语言! 1.C 语言 C 语言给人的感觉,就是一位神秘…

WM中的OutLook开发和操作

昨天闲来无视,学习了一下WM的基本开发。看WM有约的那套教程心里痒痒,于是下载了SDK,看看DEMO,在Sample中的示例进行加工。小有一点心得。其实总的来说难度也不是很大,以前没有做过FORM的程序,都是WEB上面的…

苹果手机运行python_iPhone是卖的最好的手机?用Python照样把他玩弄鼓掌之间!

关于 iOS 的技术解读有很多,但是却鲜有设备可视化同步的介绍文章。本文一起了解下这个酷炫的 iOS 黑科技。我们的任务很简单——如上图所示,实时获取设备的当前方向。 UIDevice.current.orientation 首先,需要调用 beginGeneratingDeviceOrie…

这几个动图告诉你科学的神奇,看完瞬间觉得智商都提高了

生活中简单平常的事物和现象背后,往往有着奇妙的原理,赶快跟着一起来看看涨点知识吧! 夹心雪糕的制作原理 ▼ 难怪雪糕大小,厚度都一模一样 原来都是从一个模子里出来的 ▼ 煎饼可以统一翻面 再也不用担心烤焦了 ▼ 冰淇淋蛋筒的制…

自定义 ocelot 中间件输出自定义错误信息

自定义 ocelot 中间件输出自定义错误信息Introocelot 中默认的 Response 中间件在出错的时候只会设置 StatusCode 没有具体的信息,想要展示自己定义的错误信息的时候就需要做一些自定义了,对 ocelot 中的 Response 中间件做了一些小改动,实现…

盘点小坏蛋的礼物

我们家小坏蛋一天天长大了,妈妈从觉得很辛苦过渡到习惯了很辛苦,苦中作乐的妈妈终于抽出空来写博客啦! 为什么叫他小坏蛋呢?因为他吃饭不乖。没满月的时候蛮乖的,每顿奶都吃的很香,咕咚咕咚的喝下去&#x…

为什么对gRPC做负载均衡会很棘手?

在过去的几年中,随着微服务的增长,gRPC在这些较小的服务之间的相互通信中获得了很大的普及,在后台,gRPC使用http/2在同一连接和双工流中复用许多请求。使用具有结构化数据的快速,轻便的二进制协议作为服务之间的通信介质确实很有吸…

给新手程序猿的16个必备小妙招

写在前面: 这个文章核心并不是程序优化的具体技巧,而是拿到一个问题如何思考和利用工具的通用方法。比如即使我们不知道 profiler 这个东西,通过搜索"代码 每一行 时间"也可以很快知道有这样的工具叫做 profiler,并且学…

python字符串设置字体_python怎么更改字符串后几位

python更改字符串后几位的方法:可以利用replace()函数来实现。replace()函数可以把字符串中的旧字符串替换成新字符串,并返回替换后的新字符串。具体使用方法如:【str.replace("is", "was")】。可以利用replace()函数来修…

程序猿的双十一最佳攻略

讲个恐怖故事 一年一度虐汪“光棍节”又来了 小天拍拍(不存在的)胸脯告诉大家 这个节日 我陪你们 买买买! 限时特惠专场 1 welcome 7天教你学会数学建模及Matlab编程 数学建模涉及的内容比较广泛,比如碎纸片问题中所涉及的图像识…

关于Word中审阅的一个问题!

前两天,在帮一个杂志撰稿的过程中,有一个关于Word审阅的问题。(以下内容以Word2007为例) 本身,审阅的应用不算困难。 我们可以为文章添加“批注”,或是你的上级对文章进行修改,他们可以开启“审…

ASP.NET Core - 在ActionFilter中使用依赖注入

上次ActionFilter引发的一个EF异常,本质上是对Core版本的ActionFilter的知识掌握不够牢固造成的,所以花了点时间仔细阅读了微软的官方文档。发现除了IActionFilter、IAsyncActionFilter的问题,还有一个就是依赖注入在ActionFilter上的使用也是需要注意的…

魏尔斯特拉斯函数与分形图形的动画演示

一般人会直觉上认为连续的函数必然是近乎可导的。即使不可导,所谓不可导的点也必然只占整体的一小部分。根据魏尔斯特拉斯在他的论文中所描述,早期的许多数学家,包括高斯,都曾经假定连续函数不可导的部分是有限或可数的。这可能是…

大脚战场插件怎么关闭_PM工具栏插件:HonmToolBar

视频演示:问:HonmToolBar是一款什么样的插件?答:HonmToolBar是一款高度自由化的插件,用户可以自己增加宏文件按钮或者宏命令按钮。该插件类似工具栏,有水平和垂直两个工具栏。插件悬浮在PM图形窗口左上角&a…

android 导航 美国,变美了 Android N或用全新虚拟导航按键

原标题:变美了 Android N或用全新虚拟导航按键变美了 Android N或用全新虚拟导航按键【IT168 资讯】虽然距离谷歌Android N系统的发布已经有一段时间了,不过该系统目前仍旧属于内测阶段,短时间内仍难以迅速推广。另外也正是由于Android N正式…

python特性和属性_Python面向对象-类的特性及公私有属性 | 【韩涛博客】

构造函数 __init__ self.name name #属性,成员变量,字段 def sayhi() #方法,动态属性 公有属性 在类中直接定义的属性,大家都可以用 私有属性 __两个下划线定义,外部不可以访问,内部可以访问 class Role(o…

[Abp 源码分析]自动审计记录

点击上方蓝字关注我们0.简介Abp 框架为我们自带了审计日志功能,审计日志可以方便地查看每次请求接口所耗的时间,能够帮助我们快速定位到某些性能有问题的接口。除此之外,审计日志信息还包含有每次调用接口时客户端请求的参数信息,…

我的老公是枚码农

前两天看到一篇写程序员的爆文,虽然略显夸张,但也着实有趣。忽然想到身边人也是一枚码农,浑身上下也是浓厚的码农气息,遂也胡乱写了几笔,博君一笑,为了方便起见,就称其为“码农哥”。 1 码农哥还…

harmonyos con,鸿蒙HarmonyOS系统中的JS开发框架

HarmonyOS开源至今已经一个多月,源码托管在国内知名开源平台码云上,https://gitee.com/openharmony 。我最感兴趣的就是JS 框架 ace_lite_jsfwk,从名字中可以看出来这是一个非常轻量级的框架,官方介绍说是“轻量级 JS 核心开发框架…