多条件模糊查询,list作为查询条件

sql

    <select id="selectSellingOrder2" resultType="com.yf.platform.order.bean.orderEntity.SellingOrderPara">
        SELECT
        oob.order_id,
        date_format( oob.order_shipping_time, '%Y-%m-%d %H:%i:%s' ) AS orderShippingTime,
        oob.order_from,
        oob.pay_from,
        oob.order_receiver_name,
        oob.payment_other_number,
        oob.order_create_time,
        oob.order_payment_amount,
        oob.order_status,
        oob.order_refund_status,
        oob.order_return_status,
        oob.payment_number,
        oob.payment_name,
        oob.pay_code,
        oob.payment_time,
        oob.order_shipping_code,
        oob.order_refund_amount,
        oob.order_finished_time,
        oob.order_buyer_evaluation_status,
        oob.shop_id,
        oob.shop_name AS shopNameId,
        oob.buyer_user_id,
        oob.buyer_user_name,
        oob.order_receiver_address,
        oob.order_receiver_contact,
        oob.groupbuy_status,
        oob.order_message,
        oob.call_waiter_remark,
        oob.songda_time AS songdaTime,
        opv.review_status,
        b.trade_third_party_amount,
        b.trade_payment_recharge_card,
        b.trade_payment_amount,
        ( oob.order_goods_amount + oob.order_shipping_fee - oob.voucher_price ) AS orderAmount
        FROM
        odb_order_base oob
        LEFT JOIN java_pay.pdb_pay_consume_trade b ON b.order_id = oob.order_id
        LEFT JOIN odb_payment_vocher opv ON oob.order_id = opv.order_id
        <where>
            <if test="param.orderId != null and param.orderId != '' ">
                and oob.oob.order_id = #{param.orderId}
            </if>
            <if test="param.buyerUserName != null and param.buyerUserName != ''">
                and oob.buyer_user_name= #{param.buyerUserName}
            </if>
            <if test="param.shopName != null and param.shopName != '' ">
                and oob.shop_name LIKE CONCAT('%',#{param.shopName},'%')
            </if>
            <if test="param.finishTime != null and param.finishTime != '' ">
                and oob.order_create_time <![CDATA[<]]> #{param.finishTime}
            </if>
            <if test="param.airTime != null and param.airTime != '' ">
                and oob.order_create_time <![CDATA[>=]]> #{param.airTime}
            </if>
            <if test="param.shopNameIdList != null and param.shopNameIdList.size>0 ">
                and
                <foreach collection="param.shopNameIdList" open="("  separator="or"  close=")"  item="shopNameId">
                    oob.shop_name  LIKE  CONCAT('%',trim(#{shopNameId}),'%')
                </foreach>
            </if>
        </where>
        order by order_create_time desc limit #{param.cp},#{param.pageSize}
    </select>
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
一.功能简介 1. 实现一个图书管理系统。图书信息存放到一个数据库中。图书包含信息:图书号、图书名、作者、价格、备注字段。 2. 系统实现如下的基本管理功能: (1)用户分为两类:系统管理员,一般用户。 (2)提供用户注册和用户登录验证功能;其中登录用户的信息有:登录用户名,登录密码等。 (3)管理员可以实现对注册用户的管理(删除),并实现对图书的创建、查询、修改和删除等有关的操作。 (4)一般用户,只能查询图书,并进行借书、还书操作,每个用户最多借阅8本,即当目前借书已经是8本,则不能再借书了,只有还书后,才可以再借阅。 二.涉及技术 Struts2框架、MySQL数据库、C3P0数据池、Jsp、HTML、CSS、JavaScript等技术。 三.设计思路 1. 基于Struts2框架进行编程设计,连接MySQL数据库实现数据的增删查改,应用Jsp、HTML、CSS、JavaScript对访问页面进行编写和美化。 2. 分别创建book表和user表,用以存放图书信息和用户数据。其中user表中,设有flag以区分管理员和普通用户。 3. 分别创建Book类和User类,与数据表相对应。每本书和每个用户都有唯一的id与之对应。 4. 创建C3P0属性文件和数据库连接工具类。 5. 设计数据库操作类:UserDao类和BookDao类。UserDao用于实现所有对user表的操作,BookDao用于实现所有对book表的操作。 6. 创建分别对应UserDao类和BookDao类的Action:UserAction和BookAction。采用基于注解的方式进行Action配置。 7. 用户账号分为管理员账号和普通用户账号,注册时加以区分,登录时即可自动判断进入对应的操作主页面。 8. 管理员可实现对用户的查询显示,模糊查询,删除,批量删除,全选和取消全选等功能;可实现对图书的查询显示,模糊查询,添加,删除,批量删除,全选和取消全选等功能。 9. 普通用户可实现借书和还书功能,借书功能通过对book表的查询,将未借出的图书按照id顺序排列显示,点击表格后方的“借阅”按钮,进行确认借阅,将book表中本书的borrowperson列的值改为本用户账号。对于借阅成功的图书可以在“当前借阅”中进行查看。还书功能通过在“当前借阅”中点击“还书”按钮,进行确认还书,将book表中本书的borrowperson列的值改为“空”,本书信息将可以在“借书”界面查看。 四.存在的问题 1. 原本希望能为每一个用户创建一个对应的以其账号命名的数据表,用以存放用户所借图书信息,但创建表的SQL语句无法在java代码中执行,所以只好在book表中添加一列borrowperson,用来存放借阅本书的用户账号,这样查询用户当前借阅记录时,以“where borrowperson=‘account’”为条件对book表进行查询即可。但是每个用户要当前查询借阅记录时都需要对整个book表进行遍历,效率太低。 2. 模糊查询时,因同时需要进行where筛选,SQL语句无法执行,只好分开查询,先进行模糊查询查询结果存放到list表中,再通过遍历list表进行判断是否符合where的条件,若符合,则存入另一个list表中。这种方法虽然实现了查询,但效率太低,代码过于繁重。 五.改进预想 这些本不应该是预想,原本希望在本次作业中实现的,但时间不够充分,只能作为下一步的改建预想。 1. 希望实现登录时验证码验证登录; 2. 希望实现查询时,查询结果分页浏览; 3. 进一步优化Action之间的传值方法; 4. 页面进一步优化、美化; 5. 实现用户借书还书时间记录,和借阅时长限制。
在 Spring Boot 中,可以通过 Spring Data JPA 框架来实现多条件模糊查询。如果你的前端使用的是 Vue.js,可以通过 Axios 来发送 HTTP 请求,并将查询条件作为参数传递给后端。 以下是一个简单的示例: 1. 定义一个 Java 类作为查询条件的封装: ```java public class UserQuery { private String name; private String email; // getters 和 setters 省略 } ``` 2. 在 Spring Boot 中定义一个 UserRepository 接口,并继承 JpaRepository 接口: ```java public interface UserRepository extends JpaRepository<User, Long> { List<User> findByNameContainingAndEmailContaining(String name, String email); } ``` 3. 在 Controller 中接收前端发送的查询条件,并调用 UserRepository 中定义的方法进行查询: ```java @RestController @RequestMapping("/users") public class UserController { @Autowired private UserRepository userRepository; @GetMapping("") public List<User> getUsers(@RequestParam("name") String name, @RequestParam("email") String email) { List<User> users = userRepository.findByNameContainingAndEmailContaining(name, email); return users; } } ``` 4. 在 Vue.js 中使用 Axios 发送 HTTP 请求: ```javascript axios.get('/users', { params: { name: 'John', email: '[email protected]' } }) .then(function (response) { console.log(response.data); }) .catch(function (error) { console.log(error); }); ``` 在以上示例中,我们通过 UserRepository 中的 findByNameContainingAndEmailContaining 方法实现了多条件模糊查询。在 Controller 中,我们使用 @RequestParam 注解接收前端发送的查询条件。在 Vue.js 中,我们使用 Axios 发送 HTTP 请求,并将查询条件作为参数传递给后端。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值