数据库名:taobaodb



配置文件:

JdbcTemplate主要提供以下五类方法:

  • execute方法:可以用于执行任何SQL语句,一般用于执行DDL语句;

  • update方法及batchUpdate方法:update方法用于执行新增、修改、删除等语句;batchUpdate方法用于执行批处理相关语句;

  • query方法及queryForXXX方法:用于执行查询相关语句;

  • call方法:用于执行存储过程、函数相关语句。

1.单条数据查询(可用于登录判断用户名、密码)

a.获取jsp表单得到的表单信息;

User user = new User();
Map<String, String[]> map = request.getParameterMap();

b.将表单信息注入到User类的对象中;

try {
BeanUtils.populate(u1,map);
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}

c.按user的用户名、密码查询数据库,得到一个对象u2,如果u2不是null,那么u2和user的信息是一致的,也就是表单填的信息正确

public User findUser(User user) {
User u=null;
try{
u=jt.queryForObject("select userName,userPwd from userinfo where userName=? and userPwd=?",
new BeanPropertyRowMapper<User>(User.class),user.getUsername(),user.getUserpwd());
}catch (Exception e){
} return u;
}

如果返回的u为null说明数据库中没有查询到符合条件的信息

单元测试代码:

import javax.sql.DataSource;
import java.io.IOException;
import java.util.Properties; public class MySql {
@Test
public void addData(){
Properties p=new Properties();//配置文件对象
/*加载配置文件
MySql.class当前类的class文件,getClassLoader类的加载器,getResourceAsStream获取资源流*/
try {
p.load(MySql.class.getClassLoader().getResourceAsStream("druid.properties"));
//创建连接池
DataSource ds = DruidDataSourceFactory.createDataSource(p);
JdbcTemplate jt=new JdbcTemplate(ds);
User user=new User();
user.setUserName("Tom");
user.setUserPwd("666666");
//查询(单条)
try{ //如果数据库中没有查询到此条数据会报错,try catch一下
User u2 =
jt.queryForObject(
"select userName,userPwd from userinfo where userName=? and userPwd=?",
new BeanPropertyRowMapper<User>(User.class),
user.getUserName(),user.getUserPwd());
System.out.println(u2);}catch (Exception e){ } } catch (IOException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
} }
}

运行结果

C:\java\JDK\bin\java.exe
八月 10, 2019 10:36:41 上午 com.alibaba.druid.support.logging.JakartaCommonsLoggingImpl info
信息: {dataSource-1} inited
User{userName='Tom', userPwd='666666'} Process finished with exit code 0

2.count sum

String sql="select count(*) from user";
int count= jdbcTemplate.queryForObject(sql, Integer.class);
System.out.println(count);

3.多条数据查询

try{ //如果数据库中没有查询到此条数据会报错,try catch一下
RowMapper<User> rowMapper=new BeanPropertyRowMapper<User>(User.class);
String sql="select userName,userPwd from userinfo";
List<User> users=jt.query(sql,rowMapper);
for (User u:users) {
System.out.println(u);
}
}catch (Exception e){ }

运行结果:

八月 10, 2019 10:59:10 上午 com.alibaba.druid.support.logging.JakartaCommonsLoggingImpl info
信息: {dataSource-1} inited
User{userName='Tom', userPwd='666666'}
User{userName='Alice', userPwd='666***'}
User{userName='Alan', userPwd='*6666#'}
User{userName='Ikun', userPwd='888888'}
User{userName='Bob', userPwd='123456'}
User{userName='Olive', userPwd='222223'}
User{userName='Oreo', userPwd='233233'} Process finished with exit code 0

3.插入数据(可用于注册)

A.插入单条数据

try{
String sql="insert into userinfo (userName,userPwd,typeId,userStatus) values (?,?,?,?)";
int count= jt.update(sql, new Object[]{"孙悟空","87654321",3,"齐天大圣正常"});
System.out.println("成功插入数据,影响行数:"+count);
}catch (Exception e){ }

运行结果

八月 10, 2019 11:10:58 上午 com.alibaba.druid.support.logging.JakartaCommonsLoggingImpl info
信息: {dataSource-1} inited
成功插入数据,影响行数:1 Process finished with exit code 0



B.批量插入

String sql="insert into userinfo (userName,userPwd,typeId,userStatus) values (?,?,?,?)";

List<Object[]> batchArgs=new ArrayList<Object[]>();
batchArgs.add( new Object[]{"孙行者","1111111",3,"正常"});
batchArgs.add( new Object[]{"者行孙","8222221",3,"大圣正常"}); jt.batchUpdate(sql, batchArgs);

4.删除数据

//删除userId为8,9的数据
String sql="delete from userinfo where userId=? or userId=?";
jt.update(sql,9,8);

5.修改(更新)数据

String sql="update userinfo set userStatus=? where userName=?";
jt.update(sql,"者行孙异常","者行孙");

String sql="update userinfo set userStatus=? where userName=?";
jt.update(sql,new Object[]{"Objec方式修改","者行孙"});

【Spring】JdbcTemplate的使用,查询,增、删、改的更多相关文章

  1. 好用的SQL TVP~~独家赠送[增-删-改-查]的例子

    以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化.  本系列主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础] ...

  2. iOS FMDB的使用(增,删,改,查,sqlite存取图片)

    iOS FMDB的使用(增,删,改,查,sqlite存取图片) 在上一篇博客我对sqlite的基本使用进行了详细介绍... 但是在实际开发中原生使用的频率是很少的... 这篇博客我将会较全面的介绍FM ...

  3. iOS sqlite3 的基本使用(增 删 改 查)

    iOS sqlite3 的基本使用(增 删 改 查) 这篇博客不会讲述太多sql语言,目的重在实现sqlite3的一些基本操作. 例:增 删 改 查 如果想了解更多的sql语言可以利用强大的互联网. ...

  4. ADO.NET 增 删 改 查

    ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访 ...

  5. MVC EF 增 删 改 查

    using System;using System.Collections.Generic;using System.Linq;using System.Web;//using System.Data ...

  6. 第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据

    第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据 ADO.NET 为什么要学习? 我们要搭建一个平台(Web/Winform ...

  7. Spring JdbcTemplate框架搭建及其增删改查使用指南

    Spring JdbcTemplate框架搭建及其增删改查使用指南 前言: 本文指在介绍spring框架中的JdbcTemplate类的使用方法,涉及基本的Spring反转控制的使用方法和JDBC的基 ...

  8. C# ADO.NET (sql语句连接方式)(增,删,改)

    using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.We ...

  9. django ajax增 删 改 查

    具于django ajax实现增 删 改 查功能 代码示例: 代码: urls.py from django.conf.urls import url from django.contrib impo ...

  10. StringBuilder修改字符串内容,增,删,改,插

    package seday01;/** * 字符串不变对象特性只针对字符串重用,并没有考虑修改操作的性能.因此String不适合频繁修改内容. * 若有频繁修改操作,使用StringBuilder来完 ...

随机推荐

  1. 【FPGA篇章一】FPGA工作原理:详细介绍FPGA实现编程逻辑的机理

    欢迎大家关注我的微信公众账号,支持程序媛写出更多优秀的文章 FPGA(Field Programmable Gate Array),即现场可编程逻辑门阵列,它是作为专用集成电路(ASIC)领域中一种半 ...

  2. Spring IOC使用详解

    SpringIOC使用详解 一.IOC简介 IOC(Inversion of Control):控制反转,即对象创建的问题.通俗地讲就是把创建对象的代码交给了Spring的配置文件来进行的.这样做的优 ...

  3. [hdu5101]计数问题

    http://acm.hdu.edu.cn/showproblem.php?pid=5101 题目大意:给n个集合,求从两个不同集合里面各取一个数使得它们的和大于给定数的方案数. ans=从所有数里面 ...

  4. Mysql常用sql语句(21)- regexp 正则表达式查询

    测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 正则的强大不言而喻,Mysql中也提供了 reg ...

  5. dedecms织梦建站后怎么防止被黑,加强安全漏洞措施?

    dedecms织梦建站后怎么防止被黑,加强安全漏洞措施? 很多人反映dedecms织梦网站被黑的情况,因为织梦相对来说漏洞还是挺多的,特别是新建设的站点,有些目录.文件该删的删,权限及安全都要设置,以 ...

  6. Vue中跨域问题解决方案1

    我们需要配置代理.代理可以解决的原因:因为客户端请求服务端的数据是存在跨域问题的,而服务器和服务器之间可以相互请求数据,是没有跨域的概念(如果服务器没有设置禁止跨域的权限问题),也就是说,我们可以配置 ...

  7. Atcoder Beginner Contest 167

    赛场实况: 训练反思: A题签到不说了,B题第一眼没看清楚数据范围,写了一堆然后仔细一看1e12果断不能暴力..立马换了一个写法,连交2发wa(细节啊细节!!),C题看了半天英语没看懂说了什么,拿翻译 ...

  8. python--集合和文件基本操作

    集合 # 集合天生就能去重,集合也是无序的  集合也是{ }  但是空集合定义特殊s=set()  #空集合s2 = set('1234445566778')print(s2) s3 = {'1',' ...

  9. 基于 abp vNext 和 .NET Core 开发博客项目 - 统一规范API,包装返回模型

    上一篇文章(https://www.cnblogs.com/meowv/p/12916613.html)使用自定义仓储完成了简单的增删改查案例,有心的同学可以看出,我们的返回参数一塌糊涂,显得很不友好 ...

  10. iterm 分屏切换快捷键与配色设置

    (1)快捷键设置 ⌘ + d: 垂直分屏, ⌘ + shift + d: 水平分屏. ⌘ + ]和⌘ + [在最近使用的分屏直接切换. ⌘ + opt + 方向键切换到指定位置的分屏. ⌘ + 数字: ...