通过JDBC方式连接数据库

1.准备工作
    在系统上安装mysql以及java开发环境,IDE等。
    检查:1.eclipse可以编译运行程序
          2.MySQL用户名密码正确
          3.查询表存在,查询语句可以执行
        
2.下载MySQL的驱动包,mysql-connector-java-5.1.47-bin.jar,新建java项目之后需要把驱动包加入项目。
3.编写代码
        
        try {  
        
              Class.forName("com.mysql.jdbc.Driver");  //加载MYSQL JDBC驱动程序 
              System.out.println("Success loading Mysql Driver!");  //ja
             }catch (Exception e) {  
              System.out.print("Error loading Mysql Driver!");  
              e.printStackTrace();  
         }  
         try{  
              Connection connect = DriverManager.getConnection(  
               "jdbc:mysql://localhost:3306/test","root","root");  
                //连接URL为 jdbc:mysql//服务器地址/数据库名 ,后面的2个参数分别是登陆用户名和密码  
               
              System.out.println("Success connect Mysql server!");  
              Statement stmt = connect.createStatement();  
              ResultSet rs = stmt.executeQuery("select * from info");  
                            //user 为你表的名称  
              while (rs.next()) {  
                      System.out.println(rs.getString("id"));  
                      System.out.println(rs.getString("name"));  
                 }  
             }catch(Exception e) {  
              System.out.print("get data error!");  
              e.printStackTrace();  
          }  
    //通过JDBC实现查询,需要把sql语句写在程序中。而且,处理查询的结果也要手工处理
    

二、使用JDBC TEMPLATE的相关操作。
    
    spring提供的操作JDBC的工具类。
    依赖于,连接池DATASource,(数据源)。
    使用准备:在mysql中建立数据库,建立表,添加数据。
    创建项目、导入jar包:日志,spring核心4个包,jdbc包、事务的包以及他们的依赖c3p0连接池,dbcp连接池和依赖。mysql的包。
    建立一个和表对应的类,user对应info表。作为javabean
    
    
    具体使用方法。
    - 使用API(了解) 使用API和JDBC很相似。
        建立一个TestAPI,主函数
        1.创建数据源,连接池
        BasicDataSource dataSource = new ****;
        dataSource.setDriverClassName();
        dataSource.setUrl();
        dataSource.setUsername();
        dataSource.setPassword();
        
        2.创建模板
        JdbcTemplate jdbcTemplate = new **
        jdbcTemplate.setDataSource(dataSource);
        
        3.通过API来操作
        jdbcTemplate的成员函数来进行增删改查。
        jdbcTemplate.update("","","")//语句中可以使用?来代替,后面给出数据。
        //只要看到了NEW,SET,就可以交给Spring来实现DAO
        
    - 配置DBCP
        通过Spring去注入模板
        建立一个userDAO类,中间包含jdbcTemplate.通过set方法设置值
        建立一个mainA类,编写beans.xml文件。配置DAO<bean id = “” class = “” >,还需要在xml中创建模板。模板中还需要注入一个数据源。
        通过spring工厂来生成这个类。
        不熟悉使用从上向下写,熟悉从下向上写,先写xml,再写main函数。(需要前面的注入知识)
        
        UserDAO的内容:
        package com.test.b_dbcp;
        import org.springframework.jdbc.core.JdbcTemplate;
        import org.springframework.jdbc.core.metadata.OracleCallMetaDataProvider;
        public class UserDao {
            public JdbcTemplate jdbcTemplate;

            public JdbcTemplate getJdbcTemplate() {
                return jdbcTemplate;
            }

            public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
                this.jdbcTemplate = jdbcTemplate;
            }

            //获取了模板,使用模板的api进行操作。
            public void updateDate()
            {
                this.jdbcTemplate.update("update info set name = 'cxc' where id = 12");
            }
        }

        BEANS.XML的内容:
        <?xml version="1.0" encoding="UTF-8"?>
        <beans xmlns="http://www.springframework.org/schema/beans"
            xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
            xmlns:p="http://www.springframework.org/schema/p"
            xsi:schemaLocation="http://www.springframework.org/schema/beans
                http://www.springframework.org/schema/beans/spring-beans.xsd">
           
           //配置数据源的工厂
           <bean id = "dataSourceid" class="org.apache.commons.dbcp2.BasicDataSource">
            <property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
            <property name="url" value="jdbc:mysql://localhost:3306/test"></property>
            <property name="username" value="root"></property>
            <property name="password" value="root"></property>
           </bean>
           
           //配置JDBCTemplate的工厂
           <bean id = "jdbcTemplateid" class="org.springframework.jdbc.core.JdbcTemplate">
            <property name="dataSource" ref="dataSourceid"></property>
           </bean> 
            
            //配置UserDao的工厂
            <bean id="userDaoid" class="com.test.b_dbcp.UserDao">
            <property name="jdbcTemplate" ref="jdbcTemplateid"></property>
            </bean>
        </beans>
        
    - 配置C3P0
        和DBCP十分相似。只是数据源是通过C3P0的方式来配置    
        ComboPooledDataSource,相关的设置(set方法)可能不一样。
        jdbcTemplate相关的配置是一样的。
        
        xml文件:
        <?xml version="1.0" encoding="UTF-8"?>

        <beans xmlns="http://www.springframework.org/schema/beans"
            xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
            xmlns:p="http://www.springframework.org/schema/p"
            xsi:schemaLocation="http://www.springframework.org/schema/beans
                http://www.springframework.org/schema/beans/spring-beans.xsd">
          
           <bean id = "dataSourceid" class="com.mchange.v2.c3p0.ComboPooledDataSource">
            <property name="driverClass" value="com.mysql.jdbc.Driver"></property>
            <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/test"></property>
            <property name="user" value="root"></property>
            <property name="password" value="root"></property>
           </bean>
                
           <bean id = "jdbcTemplateid" class="org.springframework.jdbc.core.JdbcTemplate">
            <property name="dataSource" ref="dataSourceid"></property>
           </bean> 
            
            <bean id="userDaoid" class="com.test.c_c3p0.UserDao">
            <property name="jdbcTemplate" ref="jdbcTemplateid"></property>
            </bean>
        </beans>
        
        了解一个jdbcTemplate的API,查询。
        query(),返回一个,全部。常用:查询语句,封装对象。ctrl+shift+t查看帮助文档。
        在使用query()函数时,需要了解一个接口RowMapper;
        JdbcTemplate用于在每个行的基础上,映射结果集ResultSet的行的接口。该接口的实现,将每行数据映射到实例对象。但不必担心异常处理。调用JdbcTemplate将捕获并处理SQLExceptions。 
        通常用于JdbcTemplate的查询方法或存储过程的输出参数。 RowMapper对象通常是无状态的,因此可重用;它们是在一个地方实现行映射逻辑的理想选择。或者,考虑从jdbc.object包子类化MappingSqlQuery:而不是使用单独的JdbcTemplate和RowMapper对象,您可以构建该样式的可执行查询对象(包含行映射逻辑)
        需要建立一个新的的类去继承RowMapper,设置对应的关系。
        UserMapping如下
        public class UserMapping implements RowMapper<User> {
        @Override
        public User mapRow(ResultSet rs, int rowNum) throws SQLException {
            // TODO Auto-generated method stub
            
            //建立一个user
            User user = new User();
            
            //通过rs进行关系对应
            user.setId(rs.getInt("id"));
            user.setName(rs.getString("name"));
            
            //输出结果
            return user;
        }
    }

        
    - 配置JDBCDaoSupport(使用比较多),在C3P0的基础上
    在userDao中需要写一个javaTemplate.可以让子类继承JdbcDaoSupport。
    可以通过getJdbcTemplate来代替jabcTemplate.
    
    //可以在xml中简化装配,不需要在dao中设置jdbcTemplate,只要直接把dataSource引入数据库中就可以了。
    //Dao需要继承JdbcDaoSupport。
    UserDao的写法
    public class UserDao extends JdbcDaoSupport {
        
        //获取了模板,使用模板的api进行操作。
            public void updateDate()
            {
                this.getJdbcTemplate().update("update info set name = 'qyq' where id = 12");
            }
            
            public void searchDate()
            {
                String sql = "select * from info;";
                List<User> ret_list = this.getJdbcTemplate().query(sql,new UserMapping());
                
                for(User user: ret_list)
                {
                    System.out.println(user.toString());
                }
            }
    }
    
    xml文件的写法
    <bean id = "dataSourceid" class="com.mchange.v2.c3p0.ComboPooledDataSource">
       <property name="driverClass" value="com.mysql.jdbc.Driver"></property>
       <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/test"></property>
       <property name="user" value="root"></property>
       <property name="password" value="root"></property>
   </bean>
    
    <bean id="userDaoid" class="com.test.d_jdbcDaoSupport.UserDao">
    <property name="dataSource" ref="dataSourceid"></property>
    </bean>
    
    在xml文件中,可以删除jdbcTemplate。而不需要设置。直接对dao来引入数据源。
    如果继承了这个类,就可以直接引入数据源。
    
    - 配置properties。在之前的基础中。
    开发过程中,会把数据源的相关信息写到propertise的文件中jbdcInfo.propertise.
    在xml中加载配置文件
    使用context:property-placeholder location=""
    之后就可以通过key来获取文件中的内容。
    //因为电脑无法输入美元符号,这个就不进行测试了。
    
    
    所有需要的jar包
    mysql的驱动:mysql-connector-java-5.1.47-bin.jar 
    
    Spring的核心:
    spring-beans-4.1.8.RELEASE.jar
    spring-context-4.1.8.RELEASE.jar
    spring-core-4.1.8.RELEASE.jar
    spring-expression-4.1.8.RELEASE.jar
    org.apache.commons.logging_1.1.1.jar
    
    Spring JdbcTemplate相关:
    spring-jdbc-4.1.8.RELEASE.jar
    spring-tx-4.1.8.RELEASE.jar
    
    数据源相关:
    commons-dbcp2-2.5.0.jar
    commons-pool2-2.6.0.jar
    c3p0-0.9.5.2.jar
    

    
三、使用MyBatis链接数据库
1.在JDBC的基础上下载mybatis的jar包
2.导入jar包
3.查看帮助文档,编写文件xml 

 

posted on 2018-10-11 21:28  风流倜傥的小花生  阅读(182)  评论(0编辑  收藏  举报