【jdbc】连接数据库从浅入深
一.回想
还记得以前自学的时候,刚接触到数据库,讲解的连接数据库的最基本的理论知识和方法,现在温习一下基础知识并总结如下!
1.JDBC连接数据库的基本流程
加载JDBC驱动程序 —> 提供JDBC连接的URL,ROOT,PASSWORD —> 连接数据库 —> 获取Statement相关类 —> 完成增删改 —> 关闭JDBC的相关对象
2.详细
①JDBC的驱动程序的加载
网上有说到JDBC加载驱动程序有4种方法,但是不太明白。这里用java的反射来完成驱动程序的加载。但是前提是需要相应的jar包才能成功加载
maven配置jar包:
- <!-- mysql驱动 -->
- <dependency>
- <groupId>mysql</groupId>
- <artifactId>mysql-connector-java</artifactId>
- <version>5.1.9</version>
- <scope>runtime</scope>
- </dependency>
mysql的驱动:com.mysql.jdbc.Driver
oracle的驱动:oracle.jdbc.driver.OracleDriver
for example:
- Class.forName(com.mysql.jdbc.Driver);//初始化jdbc驱动,并加载相应的驱动到jvm中
②连接数据库
这里使用的是java SE API 提供的DriverManager类来获得连接的Connection接口
mysql的url:jdbc:mysql://localhost:3306/test(数据库名)
oracle的url:jdbc:oracle:thin:@localhost:1521:test(数据库名)
for example:
- String url = "jdbc:mysql://localhost:3306/test";
- String user = "root";
- String passwd = "root";
- Connection connection = DriverManager.getConnection(url,user,passwd);
可以配置properties文件通过流获取
for example:
jdbc.properties文件内容(键值对的形式):
url:jdbc:mysql://localhost:3306/test
user:root
passwd:root
获取:
- InputStream in = this.getClass().getResourceASStream("/jdbc.properties");
- Properties p = new Properties();
- p.load(in);
- String url = p.getProperty("url");
- String user = p.getProperty("user");
- String passwd = p.getProperty("passwd");
③获取Statement相关类进行增删改
Interface Statement(只能用于执行静态代码+拼接):
方法:boolean execute(String sql);
int executeUpdate(String sql);//可执行增删改
ResultSet executeQuery(String sql);//执行查询功能
- Statement statement = connection.createStatement();
//boolean flag = statement.executeUpdate("update table1 set name = 'xl' where id = 1");//增删改用executeUpdate方法- ResultSet resultSet = statement.executeQuery("select * from table1");//查询使用executeQuery方法 返回ResultSet
- while(resultSet.next()){
- System.out.print(resultSet.getObject(1)+"---"+resultSet.getObject(2));
//System.out.print(resultSet.getString(1)++"---"+resultSet.getDate(2));- }
Interface PreparedStatement(可以执行动态代码):
方法:boolean execute();
int executeUpdate();//可执行增删改
ResultSet executeQuery();//执行查询功能
- String sql = "update test set name = ? where id = ?";
- PreparedStatement ps = connection.prepareStatement(sql);
- ps.setString(1,"ssx");
- ps.setInt(2,1);
- ps.execute();
另外,可由ResultSet 获得接口ResultSetMetadate(使用getMetaDate()方法)
方法:String getCatalogName(int column) 获取表名
int getColumnCount() :获取结果集的列数
String getColumnLabel(int column) :获取相应列的列名
3.封装jdbc
可以参看这里:写的很好
二.通过JNDI配置数据库信息(Spring)
JNDI:
- JNDI(Java Naming and Directory Interface) java命名和目录服务接口
- 降低程序和程序之间的耦合性
- 降低设备和设备的耦合性
- Tomcat服务器实现了JNDI服务,启动Tomcat服务器,等同于启动JNDI服务器
- JNDI是SUN制定的一套规范,这套规范可以和JDBC进行类比,JDBC也是一套规范,我们面向JDBC接口调用就可以获取数据库中的数据。同样,我们面向JNDI接口调用,可以获取“资源”,这个资源不是在底层数据库中。
- JNDI提供了一种服务,这个服务可以将“名称”和“资源”进行绑定,然后程序员通过面向JNDI接口调用方法lookup可以查找到相关的资源。
1.在tomcat目录下的conf/context.xml中配置如下:
- <Resource name="jdbc/microDB" auth="Container"
- type="javax.sql.DataSource"
- driverClassName="com.mysql.jdbc.Driver"
- url="jdbc:mysql://127.0.0.1:3306/micro_dev?characterEncoding=UTF-8"
- username="root"
- password="root"
- maxActive="50"
- maxIdle="30"
- maxWait="10000"/>
2.在spring的配置文件中配置如下(applicationContext.xml):
- <bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
- <property name="jndiName">
- <value>java:comp/env/jdbc/microDB</value>
- </property>
- </bean>
3.在项目的根目录下的web.xml中配置如下:
- <resource-ref>
- <description>DHCP数据库连接池</description>
- <res-ref-name>jdbc/microDB</res-ref-name>
- <res-type>javax.sql.DataSource</res-type>
- <res-auth>Container</res-auth>
- </resource-ref>
4.编写测试连接
- public class PropertyConnDateBase {
- public static void test(){
- Connection conn = null;
- Context context = null;
- try {
- context = new InitialContext();
- DataSource ds = (DataSource)context.lookup("java:comp/env/jdbc/microDB");
- conn = ds.getConnection();
- System.out.println(conn);
- }catch (Exception e){
- e.printStackTrace();
- }finally {
- }
- }
- }
5.在jsp页面中测试
- <%PropertyConnDateBase.test();%>
6.在后台可以看到打印成功;
**:不能通过在main方法中获取到jndi的连接来测试,这个jndi可能必须要在服务器开启的情况下才能获取到上下文context,main属于一个静态的方法,会报错没有初始化的context。
【jdbc】连接数据库从浅入深的更多相关文章
- Mybatis源码解析,一步一步从浅入深(一):创建准备工程
Spring SpringMVC Mybatis(简称ssm)是一个很流行的java web框架,而Mybatis作为ORM 持久层框架,因其灵活简单,深受青睐.而且现在的招聘职位中都要求应试者熟悉M ...
- Mybatis源码解析,一步一步从浅入深(三):实例化xml配置解析器(XMLConfigBuilder)
在上一篇文章:Mybatis源码解析,一步一步从浅入深(二):按步骤解析源码 ,中我们看到 代码:XMLConfigBuilder parser = new XMLConfigBuilder(read ...
- Mybatis源码解析,一步一步从浅入深(四):将configuration.xml的解析到Configuration对象实例
在Mybatis源码解析,一步一步从浅入深(二):按步骤解析源码中我们看到了XMLConfigBuilder(xml配置解析器)的实例化.而且这个实例化过程在文章:Mybatis源码解析,一步一步从浅 ...
- Mybatis源码解析,一步一步从浅入深(七):执行查询
一,前言 我们在文章:Mybatis源码解析,一步一步从浅入深(二):按步骤解析源码的最后一步说到执行查询的关键代码: result = sqlSession.selectOne(command.ge ...
- 浅入深出之Java集合框架(上)
Java中的集合框架(上) 由于Java中的集合框架的内容比较多,在这里分为三个部分介绍Java的集合框架,内容是从浅到深,如果已经有java基础的小伙伴可以直接跳到<浅入深出之Java集合框架 ...
- 浅入深出之Java集合框架(中)
Java中的集合框架(中) 由于Java中的集合框架的内容比较多,在这里分为三个部分介绍Java的集合框架,内容是从浅到深,如果已经有java基础的小伙伴可以直接跳到<浅入深出之Java集合框架 ...
- 浅入深出之Java集合框架(下)
Java中的集合框架(下) 由于Java中的集合框架的内容比较多,在这里分为三个部分介绍Java的集合框架,内容是从浅到深,哈哈这篇其实也还是基础,惊不惊喜意不意外 ̄▽ ̄ 写文真的好累,懒得写了.. ...
- 浅入深出Vue:环境搭建
浅入深出Vue:环境搭建 工欲善其事必先利其器,该搭建我们的环境了. 安装NPM 所有工具的下载地址都可以在导航篇中找到,这里我们下载的是最新版本的NodeJS Windows安装程序 下载下来后,直 ...
- 浅入深出Vue:工具准备之PostMan安装配置及Mock服务配置
浅入深出Vue之工具准备(二):PostMan安装配置 由于家中有事,文章没顾得上.在此说声抱歉,这是工具准备的最后一章. 接下来就是开始环境搭建了~尽情期待 工欲善其事必先利其器,让我们先做好准备工 ...
随机推荐
- matplotlib -- 基础知识
matplotlib 组织图表的方式 最上层是一个 Figure 实例,包含了所有可见的和其他一些不可见的内容.该 Figure 实例包含了一个 Axes 实例的成员属性 Figure.axes,同时 ...
- ELK日志系统使用说明
数据探索 Elasticsearch具有强大的数据检索和分析同能,支持模糊.全文.过滤.管道等数据查询.对于日志型数据处理很有优势. 下图为KIbana的主页图,将逐步说明每一部分的功能: 依照图中的 ...
- Beta冲刺吐槽&&获小黄衫心得
引 个人感觉本次Beta冲刺最大的槽点还是--反向延长 "冲刺周期" 做的不一样很容易,做的更好才是非常困难的 遗留的问题 经历了Alpha冲刺,组内大多数同学也大都对实践感到些许 ...
- String Match
Finding length of longest common substring /*Finding length of longest common substring using DP * * ...
- Oracle中将Clob字段转换成字符串
1. 利用dbms_lob.substr()方法可将对应字段转换成字符串如下 select dbms_lob.substr(content) from NEWS 该方法有个缺点,当content字段长 ...
- String类笔记
首先要知道,String类的核心是一个数组 我们所写的字符串序列都会放到这个char数组中,且前面有final修饰,所以只能赋值一次. 所以String创建的是不可变字符串序列,不可修改.如果要对其进 ...
- python之路(四)-set集合
set集合 set是一个无序且不重复的元素集合优点:访问速度快,解决重复问题 l1 = [1,2,34,5,6,7,4,3,3,] s2 = set(l1) #可以以列表元祖等作为参数传进来,set集 ...
- C# WebAPI系列(2)
上篇中简单介绍了一下WebApi,本章主要介绍一下Controller相关的知识. 在实际应用中,Controller是WebAPI的链接服务器和客户端的窗口.Controller的好坏影响整个系统的 ...
- LeetCode刷题:第四题 寻找两个有序数组的中位数
题目描述: 给定两个大小为 m 和 n 的有序数组 nums1 和 nums2. 请你找出这两个有序数组的中位数,并且要求算法的时间复杂度为 O(log(m + n)). 你可以假设 nums1 和 ...
- cvpr2018(转发一篇头条)
CVPR 2018:腾讯图像去模糊.自动人像操纵最新研究 新智元 2018-05-29 14:13:04 新智元报道 来源:腾讯优图 编辑:江磊.克雷格 [新智元导读]即将在6月美国盐湖城举行的计算机 ...