美文网首页
Jfinal简单实现增删改查

Jfinal简单实现增删改查

作者: ccq_inori | 来源:发表于2017-10-07 19:02 被阅读0次

    最近学习了jfinal框架。就我感觉而言,我用起来的感觉真是很爽,以前在学习其他的框架的时候,实现增删改查的时候,你需要自己手动书写你的sql语句来与数据库进行数据交互,还要创建一个实例,然后实现它的set和get方法,而jfinal框架不需要那么麻烦,只需要把前端的参数传回后台,一个语句就能实现增删改查,实在是很方便,大大减少了代码量。
    废话不多说,现在就来实现增删改查
    前端页面只是简单的实现其功能,可能不太好看。。。。。

    1.创建一个项目,然后导入Jfinal的相关包 链接: https://pan.baidu.com/s/1sluj1Ad 密码: 3ivc
    2.创建一个MainConfig.java继承JFinalConfig
    package demo;
    
    import com.jfinal.config.Constants;
    import com.jfinal.config.Handlers;
    import com.jfinal.config.Interceptors;
    import com.jfinal.config.JFinalConfig;
    import com.jfinal.config.Plugins;
    import com.jfinal.config.Routes;
    import com.jfinal.core.JFinal;
    import com.jfinal.ext.handler.ContextPathHandler;
    import com.jfinal.kit.PropKit;
    import com.jfinal.plugin.activerecord.ActiveRecordPlugin;
    import com.jfinal.plugin.c3p0.C3p0Plugin;
    import com.jfinal.render.ViewType;
    import com.jfinal.template.Engine;
    
    
    
    public class DemoConfig extends JFinalConfig {
        /**
         * 此方法用来配置 JFinal 常量值
         */
        public void configConstant(Constants me) 
        {
            //设置视图类型
            me.setViewType(ViewType.JSP);
            //读取外部文件
            PropKit.use("config.properties");
        }
    
        /**
         * 此方法用来配置 JFinal 访问路由
         */
        public void configRoute(Routes me) {
            //更改路由
            me.add("/user", UserController.class);
        }
    
        /**
         * 此方法用来配置 JFinal 的 Plugin
         */
        public void configPlugin(Plugins me) {
            // TODO Auto-generated method stub
            //输入库连接池
            C3p0Plugin c3p0Plugin = new C3p0Plugin(PropKit.get("jdbcUrl"), PropKit.get("username"), PropKit.get("password"));
            //ORM Activerecord
            ActiveRecordPlugin arp = new ActiveRecordPlugin(c3p0Plugin);
            arp.setShowSql(true);
            arp.addMapping("user", User.class);
            me.add(c3p0Plugin);
            me.add(arp);
        }
    
        /**
         * 此方法用来配置 JFinal  的全局拦截器
         */
        public void configInterceptor(Interceptors me) 
        {
            // TODO Auto-generated method stub
        }
        /**
         * 此方法用来配置 JFinal 的 Handler
         */
        public void configHandler(Handlers me)
        {
    
        }
    
        public void configEngine(Engine me) 
        {
    
        }
        public static void main(String[] args) {
            JFinal.start("WebRoot", 80, "/", 5);
        }
    
        
    
    }
    
    
    3.创建一个实例user
    package demo;
    
    import com.jfinal.plugin.activerecord.Model;
    
    
    public class User extends Model<User> 
    {
        public static final User dao=new User();
    }
    
    4.创建一个UserController
    package demo;
    
    import java.util.List;
    
    import com.jfinal.core.Controller;
    
    public class UserController extends Controller 
    {
        /**
         * 直接访问user地址进入list.jsp
         */
        public void index(){
            //执行sql语句,得到数据库的数据
            List<User> users=User.dao.find("select * from user");
            //封装发到前端
            setAttr("users", users);
            System.out.println("得到数据"+users.size()+"个");
            //将数据在list页面中渲染出来
            render("list.jsp");
        }
        /**
         * 访问user/form 地址进入form.jsp
         */
        public void form(){
            //得到前端传过来的id
            Integer id=getParaToInt(0);
            if(id!=null&&id>0){
                setAttr("user", User.dao.findById(id));
            }
            render("form.jsp");
        }
        /**
         * 数据提交
         */
        public void submit(){
            //得到前端传来的user数值
            User user=getModel(User.class,"user");
            user.save();
            //返回到user界面
            redirect("/user");
        }
        public void update(){
            User user=getModel(User.class,"user");
            user.update();
            redirect("/user");
        }
        public void edit(){
            form();
        }
        public void del(){
            //得到前端传来的id,并执行sql语句
            User.dao.deleteById(getPara(0));
            redirect("/user");
        }
    }
    
    
    5.前端的页面list.jsp和form.jsp

    list.jsp

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
    <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> 
    <%
    String path = request.getContextPath();
    String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
    %>
    
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
      <head>
        <base href="${base_path}/" />
      </head>
      
    
        <div >
            <div>
                <div><a href="user/form">新增用户</a></div>
                <table border="2" width="50%" align="center">
                    <caption><h1>测试页面</h1></caption>            
                    <thead><th>ID</th><th>姓名</th><th>年龄</th><th>性别</th><th>备注</th><th>操作</th></thead>   
                    <tbody>     
                    <c:forEach items="${users}" var="user">
                    <tr><td>${user.id}</td><td>${user.name}</td><td>${user.age}</td><td>${user.sex}</td><td>${user.remark}</td><td><a href="user/edit/${user.id }">修改</a></td><td><a href="user/del/${user.id }">删除</a></td></tr>
                    </c:forEach>
                    </tbody>
                </table>
                
            </div>
        </div>
    </html>
    

    form.jsp页面

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
    <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
    <%
    String path = request.getContextPath();
    String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
    %>
    
     <header class="navbar navbar-static-top" id="top" role="banner">
    
    </header>
    <body>
        <form action="${user==null?'/user/submit':'/user/update'}" method="post">
        <input type="hidden" name="user.id" value="${user.id}">
        <label>姓名</label>
        <input type="text" name="user.name" value="${user.name}">
        <label>年龄</label>
        <input type="text" name="user.age" value="${user.age}">
        <div >
        <label>性别</label>
        <div>
        <input type="radio"  name="user.sex" <c:if test="${user.sex=='男'}">checked="checked"</c:if>value="男"> 男
        </div>
        <div>
        <input type="radio"   name="user.sex" <c:if test="${user.sex=='女'}">checked="checked"</c:if>value="女"> 女
        </div>
        </div>
        <label>备注</label>
        <textarea rows="10" cols="20" name="user.remark">${user.remark}</textarea>
        <button type="submit">提交</button>
        </form>
    </body>
    
    
    7.config.properties文件,填写相关的数据库驱动,表名,用户名和密码
    driver=com.mysql.jdbc.Driver
    jdbcUrl = jdbc:mysql://localhost:3306/test
    username = root
    password =root
    
    搜狗截图17年10月07日1853_2.png
    成功实现功能!!
    搜狗截图17年10月07日1856_3.png

    增删改查这里就完成了。我这里没有做数据的判断,所以觉得代码量有些少了。值的一提的是, 所有 sql 与业务逻辑写在 Service 中,不要放在 Model 中,更不要放在 Controller 中,养成好习惯,有利于大型项目的开发与维护.

    相关文章

      网友评论

          本文标题:Jfinal简单实现增删改查

          本文链接:https://www.haomeiwen.com/subject/vgtsyxtx.html