相对完善的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…

2020年python2停止更新_Python核心团队计划2020年停止支持Python2,NumPy宣布停止支持计划表...

Python核心团队计划在2020年停止支持Python 2。NumPy项目自2010年以来一直支持Python 2和Python 3,并且发现支持Python 2对我们有限的资源增加了负担;因此,我们最终计划将停止支持Python 2。现在,我们已经进入了社区支持的Python …

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

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

python自动化测试脚本怎么编写_编写自动化测试脚本心得---菜鸟入门篇

编写自动化测试脚本心得 -------- 菜鸟入门篇 本文中将不会讲解 ISEE 的测试原理、不说明 Python 的常用语法、不介绍 OTP 测试平 台的架构, 自动化测试组的牛人们已经为我们编写了很多这些方面的资料, 而且我也怕学艺 不精说的不对, 因为 ……

c语言修改windows系统时间,c语言实现系统时间校正工具代码分享

//*******************************************************************//Time Protocol是一种非常简单的应用层协议。它返回一个未格式化的32位二进制数字,//这个数字描述了从1900年1月1日午夜到现在的秒数。服务器在端口37监听协议请求,以//TCP/IP或者UDP/IP格式…

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 中间件做了一些小改动,实现…

shapenet网络_GRNet网络:3D网格进行点云卷积,实现点云补全

Date:2020-11-23作者:三弟来源:GRNet网络:3D网格进行点云卷积,实现点云补全Gridding Residual Network for Dense Point Cloud Completion在点云分割方面,有一些方法尝试通过更通用的卷积操作来捕捉点云的空…

c语言随机数循环延迟,C语言生成随机数的函数、延时函数

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼下面C语言代码使用了生成随机数的函数、延时函数。请大家仔细观察其显示效果。从以下代码,我们可以得出一个重要的结论:当上述两类函数被放入循环时,应作出一定修改。同时还应关注其参数的定义位…

盘点小坏蛋的礼物

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

《笨办法学python》6_笨办法学Python 习题 25: 更多更多的练习

我们将做一些关于函数和变量的练习,以确认你真正掌握了这些知识。这节练习对你来说可以说是一本道:写程序,逐行研究,弄懂它。 不过这节练习还是有些不同,你不需要运行它,取而代之,你需要将它导入到 python …

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

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

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

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

openkruise 缩容_Linus 本尊也来了!为什么 KubeCon 越来越火了?

原标题:Linus 本尊也来了!为什么 KubeCon 越来越火了?2015年11月,第一届 KubeCon 在美国旧金山开始的时候,还只是个200人的小会议,2019年的7月,KubeCon 第二次在中国举办,就有 3500 …

你可能不知道的C#语言特性

关键字 yield 通常用于迭代器中,向IEnumerable对象提供值或者结束迭代。 如: yield return expression; yield break; var 用于定义隐式类型的变量。 var i 5; var s "Hello"; 注意隐式类型(Implicitly typed)并不是…

c语言中文件如何插入数据,急求如何将下列C语言程序数据存储到文件中?

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼求如何改动才能将下列程序的存储输入或输出数据(或两者一起)到指定的文件(或运行时直接创立一个文件)如Arrangement中。#include int n0;int rest[7][7]; //全局声明,以供全局调用int main(){void perm(int list[],int ,int );int …

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

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

使用 Tye 辅助开发 k8s 应用竟如此简单(二)

续上篇,这篇我们来进一步探索 Tye 更多的使用方法。本篇我们来了解一下如何在 Tye 中使用服务发现。服务发现 - 微服务开发不可缺少的部件 服务发现,就是新注册的这个服务模块能够及时的被其他调用者发现。不管是服务新增和服务删减都能实现自动发现。《…