当前位置: 首页 > wzjs >正文

上海做兼职哪个网站要怎么做网络营销

上海做兼职哪个网站,要怎么做网络营销,wordpress密钥,网站开发logo文章目录 一. 模糊查询1. Mysql的写法2. JDBC的实现 二. 动态条件查询1. 创建生成动态条件查询sql的方法2. 完整的动态条件查询类以及测试类 三. 分页查询1. 什么是分页查询?2. 分页查询的分类3. MySQL的实现4. JDBC实现4.1. 创建page页4.2. 分页的实现 本章来讲一下…

文章目录

  • 一. 模糊查询
    • 1. Mysql的写法
    • 2. JDBC的实现
  • 二. 动态条件查询
    • 1. 创建生成动态条件查询sql的方法
    • 2. 完整的动态条件查询类以及测试类
  • 三. 分页查询
    • 1. 什么是分页查询?
    • 2. 分页查询的分类
    • 3. MySQL的实现
    • 4. JDBC实现
      • 4.1. 创建page页
      • 4.2. 分页的实现

本章来讲一下,JDBC的模糊查询、动态查询以及分页查询的三种查询方式
旨在帮助大家更好的理解和掌握这三种查询方式,希望能够帮助到大家

一. 模糊查询

1. Mysql的写法

这里先回忆一下sql中模糊查询的写法

  1. like: 模糊查询关键字
  2. %: 模糊查询通配符
  3. _: 模糊查询占位符

例如查询学生姓名首字母为A的同学
select * from students where studentName like ‘A%’;

2. JDBC的实现

那么接下来就使用JDBC来实现模糊查询

  1. 获取数据库连接
conn = JdbcUtils.getConnection();
  1. 创建PreparedStatement对象
ps = conn.prepareStatement("select * from users where username like ?");
  1. 参数绑定
ps.setString(1,username);
  1. 执行sql语句并且保存到集合中
rs = ps.executeQuery();
while(rs.next()){Users user = new Users();user.setUserid(rs.getInt("userid"));user.setUsername(rs.getString("username"));user.setUserage(rs.getInt("userage"));list.add(user);}
  1. 释放资源
JdbcUtils.closeResource(rs, ps, connection);

完整代码

public class FuzzyQueryTest {/*** 根据用户名称模糊查找用户信息*/public List<Users> fuzzyQuery(String username){// 用于保存查询的数据List<Users> list= new ArrayList<>();Connection conn =null;PreparedStatement ps = null;ResultSet rs = null;try{ // 获取数据库连接conn = JdbcUtils.getConnection();// 创建PreparedStatement对象ps = conn.prepareStatement("select * from users where username like ?");// 参数绑定ps.setString(1,username);// 执行sql语句rs = ps.executeQuery();while(rs.next()){Users user = new Users();user.setUserid(rs.getInt("userid"));user.setUsername(rs.getString("username"));user.setUserage(rs.getInt("userage"));list.add(user);}}catch(Exception e){e.printStackTrace();}finally{JdbcUtils.closeResource(rs,ps,conn);}// 返回数据集合 return list;}// 测试代码public static void main(String[] args) {FuzzyQueryTest ft = new FuzzyQueryTest();// 相当于查询// select * from users where username like %Y%// 并且保存数据集合List<Users> users = ft.fuzzyQuery("%Y%");for(Users user1 : users){System.out.println(user1.getUserid()+" "+user1.getUsername()+" "+user1.getUserage());}}
}

这里的测试代码实现的是,在users表中查询名字有Y这个字母的所有数据
原表数据为:
在这里插入图片描述
运行后得到结果为
在这里插入图片描述

二. 动态条件查询

动态条件查询就是根据用户给定的条件,来执行对应的查询
例如:要对用户的姓名和年龄对应的数据
这就提升了灵活性,弹性

先复习一下SQL,也就是先使用SQL语句来写一下查询方法
问题:在users表中,查询名字为LuoYi,年龄为18岁的用户信息
那么SQL语句应该是
select * from users where username = ‘LuoYi’ and userage = 18
这样就可以实现查询对应条件的数据了
接下来使用JDBC来实现

1. 创建生成动态条件查询sql的方法

这是在动态条件查询类中创建的一个方法

private String generateSql(Users users){// 初始化SQL语句,使用1=1确保后续条件可以直接用and连接 	  StringBuffer sb = new StringBuffer("select * from users where 1=1 ");// 如果有userid要修改的值// 那么就将这个userid添加到这个查询条件中  if(users.getUserid() > 0){sb.append(" and userid = ").append(users.getUserid());}// 这个也是,如果username有要修改的值// 那么就对应的添加修改条件  if(users.getUsername() !=null &&users.getUsername().length() > 0){// 因为这里的username是字符串,所以要添加单引号  sb.append(" and username = '").append(users.getUsername()).append("'");}// 同理  if(users.getUserage() > 0){sb.append(" and userage = ").append(users.getUserage());}// 最后再将其转换成字符串  return sb.toString();}

2. 完整的动态条件查询类以及测试类

public class DynamicConditionQueryTest {/*** 动态条件查询Users*/public List<Users> queryUsers(Users users){List<Users> list= new ArrayList<>();Connection conn =null;PreparedStatement ps = null;ResultSet rs = null;try{//获取数据库连接conn = JdbcUtils.getConnection();//拼接查询SQL语句String sql = this.generateSql(users);System.out.println(sql);//创建PreparedStatement对象ps = conn.prepareStatement(sql);//执行sql语句rs = ps.executeQuery();while(rs.next()){Users user = new Users();user.setUserid(rs.getInt("userid"));user.setUsername(rs.getString("username"));user.setUserage(rs.getInt("userage"));list.add(user);}}catch(Exception e){e.printStackTrace();}finally{JdbcUtils.closeResource(rs,ps,conn);}return list;}/*** 生成动态条件查询sql*/private String generateSql(Users users){// 初始化SQL语句,使用1=1确保后续条件可以直接用and连接 	  StringBuffer sb = new StringBuffer("select * from users where 1=1 ");// 如果有userid要修改的值// 那么就将这个userid添加到这个查询条件中  if(users.getUserid() > 0){sb.append(" and userid = ").append(users.getUserid());}// 这个也是,如果username有要修改的值// 那么就对应的添加修改条件  if(users.getUsername() !=null &&users.getUsername().length() > 0){// 因为这里的username是字符串,所以要添加单引号  sb.append(" and username = '").append(users.getUsername()).append("'");}// 同理  if(users.getUserage() > 0){sb.append(" and userage = ").append(users.getUserage());}// 最后再将其转换成字符串  return sb.toString();}// 测试类
public static void main(String[] args) {DynamicConditionQueryTest dt = new DynamicConditionQueryTest();Users users = new Users();// 存放的值就是要修改的条件users.setUsername("LuoYi");users.setUserage(18);List<Users> list = dt.queryUsers(users);for(Users user1 : list){System.out.println(user1.getUserid()+" "+user1.getUsername()+" "+user1.getUserage());}}
}

三. 分页查询

1. 什么是分页查询?

当要显示的数据过多时,就会导致内存溢出
那么分页查询就是来避免内存溢出的,降低内存消耗
也就是,我想要一页显示多少,就显示多少

2. 分页查询的分类

  1. 物理分页:
    a. 在数据库执行查询时(实现分页查询),查询需要的数据—依赖数据库的SQL语句
    b. 在SQL查询时,从数据库只检索分页需要的数据
    c. 通常不同的数据库有着不同的物理分页语句
    d. MySql物理分页采用limit关键字
  2. 逻辑分页:
    在sql查询时,先从数据库检索出所有数据的结果集,在程序内,通过逻辑语句获得分页需要的数据
    简单来说,逻辑分页,就是在java程序中,通过循环语句来实现一页显示多少数据

3. MySQL的实现

先复习一下MySQL中的分页查询使用SQL如何实现

select * from tableName limit m,n

其中
m 代表从哪开始(以0为起始)
n 代表需要获取多少行的数据项

例如我们想从users表中先获取前两条数据SQL为:
select * from users limit 0, 2;
那么如果要获取下一页显示2页数据,怎么来实现呢
select * from users limit 2, 2
以此类推,就能够看出规律,n是不变的,然后就看m
m 的公式为: (当前页 - 1) × 每页大小

4. JDBC实现

4.1. 创建page页

这个是分页的实体类

public class Page<T> {// 当前页private int currentPage;// 每页显示的条数private int pageSize;// 总条数private int totalCount;// 总页数private int totalPage;// 结果集private List<T> result;public int getCurrentPage() {return currentPage;}public void setCurrentPage(int currentPage) {this.currentPage = currentPage;}public int getPageSize() {return pageSize;}public void setPageSize(int pageSize) {this.pageSize = pageSize;}public int getTotalCount() {return totalCount;}public void setTotalCount(int totalCount) {this.totalCount = totalCount;}public int getTotalPage() {return totalPage;}public void setTotalPage(int totalPage) {this.totalPage = totalPage;}public List<T> getResult() {return result;}public void setResult(List<T> result) {this.result = result;}
}

4.2. 分页的实现

public class PageTest {/*** 分页查询Users*/public Page<Users> selectPage(Page page){Connection conn = null;PreparedStatement ps = null;ResultSet rs = null;List<Users> list = new ArrayList<>();try{// 获取连接对象conn = JdbcUtils.getConnection();// 创建PrepareStatement对象ps = conn.prepareStatement("select * from users limit ?,?");// 绑定m参数  m的值 = ( 当前页 - 1 ) * 每页显示的条数ps.setInt(1,(page.getCurrentPage()-1)*page.getPageSize());// 绑定n参数 n的值为每页显示的条数ps.setInt(2,page.getPageSize());// 执行查询rs = ps.executeQuery();// 处理结果集while(rs.next()){// 完成ORM映射Users users = new Users();users.setUserid(rs.getInt("userid"));users.setUsername(rs.getString("username"));users.setUserage(rs.getInt("userage"));list.add(users);}// 将结果集存放到Page对象中。page.setResult(list);// 查询总条数ps = conn.prepareStatement("select count(*) from users");// 执行查询rs = ps.executeQuery();while(rs.next()){// 总条数int count = rs.getInt(1);// 保存总条数page.setTotalCount(count);// 换算总页数 = 总条数 / 每页显示的条数 向上取整int totalPage = (int)Math.ceil(1.0*count/page.getPageSize());// 保存总页数page.setTotalPage(totalPage);}}catch(Exception e){e.printStackTrace();}finally{JdbcUtils.closeResource(rs,ps,conn);}return page;}// 测试类public static void main(String[] args) {PageTest pt = new PageTest();Page page = new Page();page.setCurrentPage(2);page.setPageSize(2);Page page1 = pt.selectPage(page);System.out.println("总条数:"+page1.getTotalCount());System.out.println("总页数:"+page1.getTotalPage());System.out.println("当前页:"+page1.getCurrentPage());System.out.println("每页显示的条数:"+page1.getPageSize());List<Users> list = page1.getResult();for(Users user:list){System.out.println(user.getUserid()+ " "+user.getUsername()+" "+user.getUserage());}}
}

原数据为
在这里插入图片描述
输出结果
在这里插入图片描述
现在讲完了,三种查询方式,希望能够帮助到大家
感谢~😊

http://www.dtcms.com/wzjs/593120.html

相关文章:

  • 做骑兵电影网站赚钱彩票源码论坛
  • 百度做的网站一般在什么后台网站切片 做程序
  • 惠州网站建设是什么制作网页多少钱
  • 农家乐网站模板关键词优化是怎样收费的
  • 网站建设所需费用郑州建站软件
  • 西安制作网站的电话网页设计ui设计培训
  • 500网站建设室内设计师常用网站
  • 无锡网站开发定制开发网站建设的7种流程
  • sns社交网站有哪些html代码app
  • 深圳网站建设推选上榜网络网站建设验收方式
  • 怎么关注网站 在手机上protected wordpress login
  • 邗江区建设局网站广州建设网站是什么样的
  • 网站建设流程方案教育网站制作定制
  • 网站不兼容怎么办wordpress主题的网站
  • 用织梦做的网站是模板的吗sem搜索引擎营销是什么
  • 购买手表的网站游戏程序开发
  • 大团网站建设网站内容建设的布局和结构
  • 网站备案号的链接房地产开发资质
  • 沈阳网站优化asp网站抓取
  • 软件推广网站建设商务网站过程
  • 免费可以绑定域名网站空间深色系网站
  • 手机网站免费wordpress move插件
  • vps建两个网站要两个程序池吗亚马逊备案网站建设
  • 微信app下载找回微信搜索引擎优化培训班
  • 建设主流媒体网站站长之家源码下载
  • 做网站运营工资是不是很低电商网站首页设计
  • 深圳罗湖网站制作廊坊关键词快速排名
  • 济南网站制作 泉诺天津网站建设有哪些
  • vs215开发python网站开发国外服务器租用价格
  • 鲜花网站建设策划书清溪镇做网站