Jfinal简单实现增删改查

最近学习了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 中,养成好习惯,有利于大型项目的开发与维护.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,907评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,987评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,298评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,586评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,633评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,488评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,275评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,176评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,619评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,819评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,932评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,655评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,265评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,871评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,994评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,095评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,884评论 2 354

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,128评论 25 707
  • 一. Java基础部分.................................................
    wy_sure阅读 3,811评论 0 11
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,631评论 18 399
  • ——评《无理之人》 年前看完伍迪·艾伦的新片《无理之人》,大感老头功力不减,一如既往地大段台词,一如既往地绕来绕去...
    苏横阅读 675评论 0 3
  • 生于苦难长于苦难看身边人的苦难读文豪大家的苦难,才更能了解苦难。活了这么久,谁没有个阳光灿烂的往事,谁没有个要死不...
    梦青川平阅读 124评论 1 0