1.ORM框架的映射

01.JDBC连接数据库以前的方式代码,并给对象赋值

@Test
/**
* 以前的方式jdbc
*/
public void TestJdbc(){
/**
* 连接数据库的四要素
*/
String driver="com.mysql.jdbc.Driver";
String url="jdbc:mysql://localhost:3306/spring";
String username="root";
String password="";
/**
* 创建jdbc需要的api
*/
Connection connection=null;
PreparedStatement pst=null;
ResultSet rs=null; try {
//01加载驱动
Class.forName(driver);
//02获取链接
connection= DriverManager.getConnection(url, username, password);
//03书写sql语句
String sql="select sid,sname,age from student where sid=?";
//04给参数赋值
pst=connection.prepareStatement(sql);
pst.setInt(,);
//05获取查询结果
rs=pst.executeQuery(); while(rs.next()){
Student student=new Student();
student.setSid(rs.getInt("sid"));
student.setAge(rs.getInt("age"));
student.setSname(rs.getString("sname"));
System.out.println(student);
} } catch (Exception e) {
e.printStackTrace();
}finally{
try {
rs.close();
pst.close();
connection.close();
} catch (SQLException e) {
e.printStackTrace();
}
} }

02.我们使用反射机制来 动态的给 Student对象赋值

 /**
* 我们使用反射机制来 动态的给 Student对象赋值
*/
public static void main(String[] args){
/**
* 连接数据库的四要素
*/
String driver="com.mysql.jdbc.Driver";
String url="jdbc:mysql://localhost:3306/spring";
String username="root";
String password=""; /**
* 创建jdbc需要的api
*/
Connection connection=null;
PreparedStatement pst=null;
ResultSet rs=null; //创建需要映射的实体类
Object student=null;
try {
student=Class.forName("cn.pb.bean.Student").newInstance();
} catch (Exception e) {
e.printStackTrace();
} try {
//01.加载驱动
Class.forName(driver);
//02.获取连接
connection=DriverManager.getConnection(url,username,password);
//03.书写sql语句
String sql="select sid,age,sname from student where sid=?";
//04.给参数赋值
pst=connection.prepareStatement(sql);
pst.setInt(,);
//05.返回结果
rs=pst.executeQuery(); while (rs.next()){
//获取元数据的结果集 元数据:描述数据的数据
ResultSetMetaData metaData = rs.getMetaData();
System.out.println("元数据"+metaData);
int columnCount = metaData.getColumnCount();
//遍历元数据集合
for (int i=;i<=columnCount;i++){
//获取数据库字段的名称
String columnName = metaData.getColumnName(i);
//获取数据库字段的类型 返回的类型都是大写
String columnTypeName = metaData.getColumnTypeName(i); /**
* 01.给我一个元数据的名称
* 02.我去实体类中找对应的setXxx()
*/
String method = getMethod(columnName);
//赋值的时候根据类型
if(columnTypeName.equals("INT")){
student.getClass().getMethod(method,int.class).invoke(student,rs.getInt(columnName));
}else if(columnTypeName.equals("VARCHAR")){
student.getClass().getMethod(method,String.class).invoke(student,rs.getString(columnName));
} } Student stu= (Student) student;
System.out.println(stu);
} } catch (Exception e) {
e.printStackTrace();
}finally {
try {
rs.close();
pst.close();
connection.close();
} catch (SQLException e) {
e.printStackTrace();
}
} } /**
* 01.用户给我一个字段名称(数据库中)
* 02.我们返回一个set+字段名 (首字母大写)
* @param name 字段名称
* @return 返回的set方法名称
*/
public static String getMethod(String name){//传过来sid 返回 setSid return "set"+name.substring(,).toUpperCase()+name.substring();
}

2.Spring的JDBC:

01.实体类代码:

package cn.pb.bean;

/**
* student的实体类
*/
public class Student { private int sid;
private int age;
private String sname; public Student(int sid, int age, String sname) {
this.sid = sid;
this.age = age;
this.sname = sname;
} public Student(int age, String sname) {
this.age = age;
this.sname = sname;
} public Student() { } public int getSid() {
return sid;
} public void setSid(int sid) {
this.sid = sid;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
} public String getSname() {
return sname;
} public void setSname(String sname) {
this.sname = sname;
} @Override
public String toString() {
return "Student{" +
"sid=" + sid +
", age=" + age +
", sname='" + sname + '\'' +
'}';
}
}

02.dao层代码:

001.dao层代码

package cn.pb.dao;

import cn.pb.bean.Student;

import java.util.List;

public interface StudentDao {
int addStudent(Student student);
int delStudent(Student student);
int updateStudent(Student student);
List<Student> findAllStudents();
}

002.daoImpl层代码

package cn.pb.dao.impl;

import cn.pb.bean.Student;
import cn.pb.dao.StudentDao;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.jdbc.core.support.JdbcDaoSupport; import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;
/**
* Spring 有一个类叫 JdbcDaoSupport ===>BaseDao
* JdbcDaoSupport有一个属性叫JdbcTemplate
* 在创建JdbcTemplate的时候 需要一个DataSource
*
* 我们只需要在配置文件中 配置数据源 即可!
*
*/
public class StudentDaoImpl extends JdbcDaoSupport implements StudentDao { public int addStudent(Student student) {
String sql="insert into student(sname,age) values(?,?)";
return getJdbcTemplate().update(sql,student.getSname(),student.getAge());
} public int delStudent(Student student) {
String sql="delete from student where sid=?";
return getJdbcTemplate().update(sql,student.getSid());
} public int updateStudent(Student student) {
String sql="update student set sname=?,age=? where sid=?";
return getJdbcTemplate().update(sql,student.getSname(),student.getAge(),student.getSid());
}
/**
* @return 行映射器 rowMapper
*/
public List<Student> findAllStudents() {
String sql="select * from student";
return getJdbcTemplate().query(sql, new StudentRowMapper() { });
}
}

行映射器代码:

package cn.pb.dao.impl;

import cn.pb.bean.Student;
import org.springframework.jdbc.core.RowMapper; import java.sql.ResultSet;
import java.sql.SQLException; public class StudentRowMapper implements RowMapper<Student> {
/**
*
* @param resultSet 之前叫 返回数据的结果集,是所有数据
* 现在 这个不是所有,是一行数据的结果集
*/
public Student mapRow(ResultSet resultSet, int i) throws SQLException {
Student student=new Student();
student.setSid(resultSet.getInt("sid"));
student.setSname(resultSet.getString("sname"));
student.setAge(resultSet.getInt("age"));
return student;
}
}

03.service层代码:

001.service层代码:

package cn.pb.service;

import cn.pb.bean.Student;

import java.util.List;

public interface StudentService {
int addStudent(Student student);
int delStudent(Student student);
int updateStudent(Student student);
List<Student> findAllStudents(); }

002.serviceImpl层代码

package cn.pb.service.impl;

import cn.pb.bean.Student;
import cn.pb.dao.StudentDao;
import cn.pb.service.StudentService; import java.util.List; public class StudentServiceImpl implements StudentService {
private StudentDao dao; public int addStudent(Student student) {
return dao.addStudent(student);
} public int delStudent(Student student) {
return dao.delStudent(student);
} public int updateStudent(Student student) {
return dao.updateStudent(student);
} public List<Student> findAllStudents() {
return dao.findAllStudents();
} public StudentDao getDao() {
return dao;
} public void setDao(StudentDao dao) {
this.dao = dao;
}
}

04.连接数据库的properties文件:jdbc.properties

jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.jdbcUrl=jdbc:mysql://localhost:3306/spring
jdbc.userName=root
jdbc.password=

05.applicationContext.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"
xmlns:c="http://www.springframework.org/schema/c"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd"> <!--01.加载jdbc.properties文件-->
<context:property-placeholder location="classpath:jdbc.properties"/> <!--02.配置数据源-->
<!--001.使用spring默认的数据源
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="${jdbc.driverClass}"/>
<property name="url" value="${jdbc.jdbcUrl}"/>
<property name="username" value="${jdbc.userName}"/>
<property name="password" value="${jdbc.password}"/>
</bean>-->
<!--002.使用c3p0数据源
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="${jdbc.driverClass}"/>
<property name="jdbcUrl" value="${jdbc.jdbcUrl}"/>
<property name="user" value="${jdbc.userName}"/>
<property name="password" value="${jdbc.password}"/>
</bean>-->
<!--003.使用dbcp数据源-->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="${jdbc.driverClass}"/>
<property name="url" value="${jdbc.jdbcUrl}"/>
<property name="username" value="${jdbc.userName}"/>
<property name="password" value="${jdbc.password}"/>
</bean>
<!--03.配置dao 在StudentDaoImpl里要使用数据源-->
<bean id="studentDaoImpl" class="cn.pb.dao.impl.StudentDaoImpl">
<property name="dataSource" ref="dataSource"/>
</bean> <!--04.配置service-->
<bean id="studentServiceImpl" class="cn.pb.service.impl.StudentServiceImpl">
<property name="dao" ref="studentDaoImpl"/>
</bean>
</beans>

06.测试代码:

package cn.pb;

import cn.pb.bean.Student;
import cn.pb.service.StudentService;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; import java.util.List; public class TestJdbc { public static void main(String[] args) {
ApplicationContext context=new
ClassPathXmlApplicationContext("applicationContext.xml");
StudentService service= (StudentService) context.getBean("studentServiceImpl");
//service.addStudent(new Student(25,"xixi"));
List<Student> list=service.findAllStudents();
System.out.println(list);
}
}

Spring笔记05(Spring JDBC三种数据源和ORM框架的映射)的更多相关文章

  1. 【转】Spring学习---Bean配置的三种方式(XML、注解、Java类)介绍与对比

    [原文]https://www.toutiao.com/i6594205115605844493/ Spring学习Bean配置的三种方式(XML.注解.Java类)介绍与对比 本文将详细介绍Spri ...

  2. spring对事务支持的三种形式

    spring对事务支持的三种形式: 1.通过spring配置文件进行切面配置 <bean id="***Manager" class="org.springfram ...

  3. Spring Boot应用启动的三种方式

    Spring Boot应用HelloWorld的三种启动方式: 项目的创建可以在http://start.spring.io/网站中进行项目的创建. 首先项目结构: 1.  通过main方法的形式启动 ...

  4. JSON三种数据解析方法(转)

    原 JSON三种数据解析方法 2018年01月15日 13:05:01 zhoujiang2012 阅读数:7896    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blo ...

  5. Excel应该这么玩——5、三种数据:Excel也是系统

        Excel最常用的功能就是记录数据,把数据按照行列记录下来.这部分数据是源数据,是业务活动中最原始的流水账,作为后续操作的依据.为了从源数据中得出一定的结论,需要对源数据进行分析得出报表数据. ...

  6. Hibernate中的三种数据状态

    Hibernate中的三种数据状态(临时.持久.游离) 1.临时态(瞬时态) 不存在于session中,也不存在于数据库中的数据,被称为临时态. 比如:刚刚使用new关键字创建出的对象. 2.持久态 ...

  7. Docker 数据管理-三种数据mount方式

    可以在Container可写层存储数据,但是有三个缺点: 当Container销毁时,数据不能持久保存. Container的可写层和Container所在的主机紧耦合,不容易将数据移动到其他地方. ...

  8. 浅谈Hibernate中的三种数据状态

    Hibernate中的三种数据状态:临时.持久.游离 1.临时态(瞬时态) 不存在于session中,也不存在于数据库中的数据,被称为临时态. 数据库中没有数据与之对应,超过作用域会被JVM垃圾回收器 ...

  9. Linux 双线策略路由的三种实现方式总结+端口映射

    Linux 双线策略路由的三种实现方式总结+端口映射 Linux 双线策略路由的三种实现方式总结+端口映射 网络环境 服务器(网关): eth0 为LAN口,IP为 LAN_IP = 192.168. ...

随机推荐

  1. ARM和STM32的区别及ARM公司架构的发展

    ARM和STM32的区别及ARM公司架构的发展 转:https://www.cnblogs.com/kwdeblog/p/5260348.html ARM是英国的芯片设计公司,其最成功的莫过于32位嵌 ...

  2. gitbook 的资源同步到 github中(方便维护和备份)

    进入SETTINGS -> Github -> Select a Repository. 到这一步为止,我们可以先去我们的github,创建一个仓库先,推荐同名.然后回来gitbook中, ...

  3. 解决mysql数据库乱码问题

    MySQL的SQL语言是用于访问数据库的最常用标准化语言.MySQL软件采用了双授权政策,它分为社区版和商业版,由于其体积小.速 度快.总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选 ...

  4. Unity3D研究院之拓展Scene视图

    Scene视图是编辑游戏模型的地方,其实它还可以进行编辑.如下图所示,我给Scene视图做了简单的编辑. Scene视图的拓展是基于对象的,意思就是你必须在Hierarchy视图中选择一个对象才行.H ...

  5. programming review (c++): (2)binary tree, BFS, DFS, recursive, non-recursive

    1.二叉树定义 // Definition for a binary tree node. struct TreeNode { int val; TreeNode *left; TreeNode *r ...

  6. python 基础 1.3 使用pycharm给python传递参数及pycharm调试模式

    一.通过pycharm 给python传递函数 1. 在pycharm终端中写入要获取的参数,进行获取 1>启动pycharm 中Terminal(终端) 窗口 点击pycharm左下角的图标, ...

  7. EasyNVR RTSP转HLS(m3u8+ts)流媒体服务器前端构建之:bootstrap-datepicker日历插件的实时动态展现

    EasyNVR中有对录像进行检索回放的功能,且先抛开录像的回放,为了更好的用户体验过.让用户方便快捷的找到对应通道对应日期的录像视频,是必须的功能. 基于上述的需求,为前端添加一个日历插件,在日历上展 ...

  8. 九度OJ 1170:找最小数 (最值)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:6451 解决:2843 题目描述: 第一行输入一个数n,1 <= n <= 1000,下面输入n行数据,每一行有两个数,分别是x ...

  9. 九度OJ 1077:最大序列和 (DP)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:5600 解决:1637 题目描述: 给出一个整数序列S,其中有N个数,定义其中一个非空连续子序列T中所有数的和为T的"序列和&qu ...

  10. 如果这种方式导致程序明显变慢或者引起其他问题,我们要重新思考来通过 goroutines 和 channels 来解决问题

    https://github.com/Unknwon/the-way-to-go_ZH_CN/blob/master/eBook/09.3.md 9.3 锁和 sync 包 在一些复杂的程序中,通常通 ...