.xml配置文件的方式,测试jdbcTemplate的使用

父工程的pom文件,要安装的依赖:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.atguigu</groupId><artifactId>ssm-spring-part</artifactId><version>1.0-SNAPSHOT</version><modules><module>spring-Ioc-xml-01</module><module>spring-ioc-xml-practice-02</module><module>spring-ioc-annotation-03</module></modules><packaging>pom</packaging><!-- 声明项目属性,这些属性可以在POM文件的其他地方引用--><properties><!-- 源码编译版本 --><maven.compiler.source>17</maven.compiler.source><!-- 目标字节码版本 --><maven.compiler.target>17</maven.compiler.target><!-- 项目构建时的源代码编码方式 --><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding></properties><!-- 导入依赖,在此处导入,所有的子工程都有相应的依赖 --><dependencies><!-- spring context 依赖 --><!-- 当你引入 Spring Context 依赖之后,表示将Spring的基础依赖引入了  --><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>6.0.6</version></dependency><!-- junit5 测试 --><dependency><groupId>org.junit.jupiter</groupId><artifactId>junit-jupiter-api</artifactId><version>5.3.1</version></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.25</version></dependency><dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.2.8</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId><version>6.0.6</version></dependency></dependencies></project>
下面这个是子工程哦,因为父工程已经有依赖了,所以子工程不再导了

src/main/resources/jdbc.properties

atguitu.url=jdbc:mysql:///my_study
atguigu.driver=com.mysql.cj.jdbc.Driver
atguigu.username=root
atguigu.password=root

Student.java类

package com.atguigu.pojo;public class Student {private Integer id;private String name;private String pwd;private String plone;private String address;public Integer getId() { return id; }public String getPwd() { return pwd; }public void setPwd(String pwd) { this.pwd = pwd; }public void setId(Integer id) { this.id = id; }public String getName() { return name; }public void setName(String name) { this.name = name; }public String getPlone() { return plone; }public void setPlone(String plone) { this.plone = plone; }public String getAddress() { return address; }public void setAddress(String address) {this.address = address;}@Overridepublic String toString() {return "Student{" + "id=" + id + ", name='" + name + '\'' + ", phone=" + plone + ", address='" + address + '\'' + '}';}
}

src/main/resources/spring-01.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: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 https://www.springframework.org/schema/context/spring-context.xsd">读取外部配置文件,只能读取后缀名是“.properties”格式的别的位置就能使用配置文件的变量了,格式:value = ${key}可以添加多个配置文件,用逗号隔开即可:context:property-placeholder location="classpath:jdbc.properties,classpath:其他配置"<context:property-placeholder location="classpath:jdbc.properties" /><!-- spring-01.xml是配置文件的方式,测试jdbcTemplate的使用 --><bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"><!--<property name="url" value="jdbc:mysql:///my_study" /> --><property name="url" value="${atguitu.url}" /><!--<property name="driverClassName" value="com.mysql.cj.jdbc.Driver" /> --><property name="driverClassName" value="${atguigu.driver}" /><!--<property name="username" value="root" /> --><property name="username" value="${atguigu.username}" /><!--<property name="password" value="root" /> --><property name="password" value="${atguigu.password}" /></bean><bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"><property name="dataSource" ref="dataSource" /></bean></beans>

JdbcTemplateTest.java

public void testForXml() {创建Ioc容器ApplicationContext applicationContext = new ClassPathXmlApplicationContext("spring-01.xml");获取jdbcTemplate对象JdbcTemplate jdbcTemplate = applicationContext.getBean(JdbcTemplate.class);进行数据库的crud1、插入、删除、修改String sql = "insert into my_user (name, pwd, plone, address) values (?,?,?,?)";int rows = jdbcTemplate.update(sql, "三狗子", "8899", "158339994", "海南省");System.out.println("rows=" + rows); // rows=12、查询单条数据jdbcTemplate.queryForObject()介绍如下:参数1:sql语句参数2RowMapper,列名和属性名的映射接口参数3Object...param 可变参数 占位符的值返回值是 rowMapper指定的对象sql = "select * from my_user where id = ?";// 不使用拉姆达表达式Student student = jdbcTemplate.queryForObject(sql, new RowMapper<Student>() {@Overridepublic Student mapRow(ResultSet rs, int rowNum) throws SQLException {rs:结果集,rowNum:行数rs结果集中获取的列的值,赋值给实体类对象即可,怎样赋值呢?如下:Student student = new Student();student.setId(rs.getInt("id"));student.setName(rs.getString("name"));student.setPlone(rs.getString("plone"));student.setAddress(rs.getString("address"));return student;}}, 1);System.out.println("student= " + student); // student= Student{id=1, name='张三', phone=1583331, address='北京市'}// 使用拉姆达表达式Student student2 = jdbcTemplate.queryForObject(sql, (rs, rowNum) -> {Student stu = new Student();stu.setId(rs.getInt("id"));stu.setName(rs.getString("name"));stu.setPlone(rs.getString("plone"));stu.setAddress(rs.getString("address"));return stu;}, 2);System.out.println("student2= " + student2); // student2= Student{id=2, name='李四', phone=158695, address='上海市'}3、查询所有的数据sql = "select id, name, pwd, plone, address from my_user";List<Student> studentList = jdbcTemplate.query(sql, new BeanPropertyRowMapper<Student>(Student.class));System.out.println("studentList= " + studentList);}

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

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

相关文章

量身定制:选择能够解决企业问题的六西格玛培训机构

现在的培训机构太多了&#xff0c;都在打着六西格玛管理的旗号&#xff0c;甚至有很多培训机构连六西格玛管理都没有学习过&#xff0c;就敢号称自己是六西格玛管理专家。在这个鱼龙混杂的市场上&#xff0c;很多企业对于选择什么样的培训机构&#xff0c;以及如何选择一家靠谱…

Android EditText可编辑与不可编辑的切换

需求背景&#xff1a;EditText需要根据用户的选择在可编辑与不可编辑之间进行切换。 一、可编辑与不可编辑的切换 1、可编辑 mEt.setInputType(InputType.TYPE_CLASS_TEXT); 2、不可编辑 mEt.setInputType(InputType.TYPE_NULL); 二、长按[全选、复制、粘贴、剪切等]的显示与…

C和C++有哪些异同

C和C是两种非常相似但也有一些重要区别的编程语言。以下是它们之间的主要异同点&#xff1a; 相同点&#xff1a; 基本语法&#xff1a;C是C语言的超集&#xff0c;大部分C语言代码可以在C中直接编译运行。 基本数据类型&#xff1a;两者都具有相似的基本数据类型&#xff0c…

AOP实现接口加解密

接口加解密&#xff08;主要实现分为 请求参数解密&#xff0c;返回参数加密 两个操作&#xff09; 玩一下&#xff0c; 开搞&#xff0c;开搞&#xff01;&#xff01;&#xff01; 目录 实现思路引入maven核心代码自定义注解AOP切面测试方法测试结果 实现思路 首先加解密用的…

Vue3(domdiff)最长递归子序列求解简易版(超简单)

Vue3&#xff08;domdiff&#xff09;最长递归子序列求解简易版 ⚠️ 关键词&#xff08;每一个都需要理解&#xff09;js 代码实现写完感想欢迎关注 ⚠️ 关键词&#xff08;每一个都需要理解&#xff09; 动态规划&#xff08;O(N^2)&#xff09;&#xff08;不提倡&#xf…

python接入AI 实现微信自动回复

import numpy as np # 引入numpy库&#xff0c;目的是将读取的数据转换为列表 import pandas as pd # 引入pandas库&#xff0c;用来读取csv数据 from uiautomation import WindowControl # 引入uiautomation库中的WindowControl类&#xff0c;用来进行图像识别和模拟操作 i…

windows组播发不出去解决办法

由于开启了虚拟网卡&#xff0c;安装VMWare虚拟化软件&#xff0c;可能会通过虚拟网卡发送组播&#xff0c;需要禁用虚拟化网卡。

二分法题集1

1 二分查找 分析&#xff1a; 这是一道很简单的二分法题&#xff0c;定义两个指针和中间值middle&#xff0c;判断middle对应数组值与目标值的大小关系&#xff0c;从而对left和right进行修改。由于太过基础&#xff0c;代码简单基础就不多赘述。 目录 1 二分查找 分析&…

Android Framework 常见解决方案(28)system分区自定义方案

1 原理说明 一般在定制系统时&#xff0c;都会做预置apk和各类其他资源&#xff0c;很有可能超出系统默认设置的系统分区大小&#xff0c;也就会导致编译system时因超出默认设置的分区大小而失败。一般的做法是修改android framework时&#xff0c;修改对应项目的BOARD_SYSTEM…

干货 | 探索CUTTag:从样本到文库,实验步步为营!

CUT&Tag&#xff08;Cleavage Under Targets and Tagmentation&#xff09;是一种新型DNA-蛋白互作研究技术&#xff0c;主要用于研究转录因子或组蛋白修饰在全基因组上的结合或分布位点。相比于传统的ChIP-seq技术&#xff0c;CUT&Tag反应在细胞内进行&#xff0c;创新…

ccf 201703-1分蛋糕

// 分蛋糕 import java.util.Scanner;public class 分蛋糕 {public static void main(String[] args) {Scanner input new Scanner(System.in);int n input.nextInt(); // 蛋糕块数int k input.nextInt(); // 分发蛋糕的重量标准int[] arr new int[n];// 录入每块蛋糕的重量…

51单片机入门:LED点阵屏

LED点阵屏介绍 LED点阵屏由若干个独立的LED组成&#xff0c;LED以矩阵的形式排列&#xff0c;以灯珠亮灭来显示文字、图片、视频等。LED点阵屏广泛应用于各种场合&#xff0c;如&#xff1a;广告屏、公告牌等。 分类&#xff1a; 按颜色&#xff1a;单色、双色、全彩&#x…

nuxt3配置打包静态资源在某一路径下

export default defineNuxtConfig({app: {baseURL: "/account-project"} });

ruoyi-nbcio-plus基于vue3的flowable流程设计器组件的升级修改

更多ruoyi-nbcio功能请看演示系统 gitee源代码地址 前后端代码&#xff1a; https://gitee.com/nbacheng/ruoyi-nbcio 演示地址&#xff1a;RuoYi-Nbcio后台管理系统 http://122.227.135.243:9666/ 更多nbcio-boot功能请看演示系统 gitee源代码地址 后端代码&#xff1a…

银行ITSS体系下低代码运维体系实践分享

前言 自2021年中国人民银行发布《金融科技发展规划&#xff08;2022-2025年&#xff09;》以来&#xff0c;商业银行迈入数字化转型的高阶阶段。在此背景下&#xff0c;为了进一步提高金融科技的管理水平&#xff0c;商业银行需要改变传统金融运维模式&#xff0c;对已有运维体…

JUC:实现一个简易的数据库连接池(享元模式)

主要是学习享元模式。 享元模式&#xff08;Flyweight Pattern&#xff09;是一种结构型设计模式&#xff0c;旨在通过共享尽可能多的对象来最小化内存使用和提高性能。在该模式中&#xff0c;对象被分为两种状态&#xff1a;内部状态和外部状态。 内部状态&#xff08;Intr…

红黑树插入机制深度剖析与实践指南

红黑树插入机制深度剖析与实践指南 一、红黑树的基本概念二、插入操作的初步2.1 RB-INSERT-FIXUP过程2.2 循环的不变性2.2.1 情况1&#xff1a;叔节点是红色2.2.2情况2和情况3&#xff1a;叔节点是黑色 三、插入操作的复杂性分析四、伪代码4.1 RB-INSERT 过程4.2 RB-INSERT-FIX…

亚信安慧AntDB:以数据之名,书写创新篇章

随着大数据时代的到来&#xff0c;对数据库的需求愈发强烈。在这一背景下&#xff0c;国产数据库逐渐崭露头角&#xff0c;亚信安慧AntDB作为重要的代表产品之一正积极参与到激烈的市场竞争中。亚信安慧AntDB不仅追求技术的革新和突破&#xff0c;同时也致力于满足用户日益增长…

4月06日,每日信息差

第一、中国电建设计承建的西藏八宿县100兆瓦保障性并网风电项目2日举行开工仪式。项目海拔高达5300米&#xff0c;刷新了之前同样由中国电建设计承建的西藏措美哲古风电场5200米的世界海拔最高风电场纪录 第二、宫崎骏新片《你想活出怎样的人生》上映第4天&#xff0c;中国内地…

理解PostgreSQL中的postmaster.pid

在PG中&#xff0c;一个简要的体系结构图可以大致画成下边的样子&#xff1a; Server端基本上分成backend process和若干background process。这些process都是一个名为postmaster进程的子进程。而postmaster则是postgres进程的别名。 进程概况 [14:42:08-postgrescentos1:/pg…