`
Supanccy2013
  • 浏览: 214075 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Nutz4---一对一的增删改查

    博客分类:
  • Nutz
阅读更多
   nutz太过轻量,所有关联的对象,都不会一个方法就load出来,需要两个步骤,下面是实例。

一:数据库
1,创建person表
-- Create table
create table T_PERSON
(
  ID        NUMBER not null,
  NAME      NVARCHAR2(60),
  PASSWORD  NVARCHAR2(60),
  ADDRESSID NUMBER
)
tablespace SYSTEM
  pctfree 10
  pctused 40
  initrans 1
  maxtrans 255
  storage
  (
    initial 64K
    minextents 1
    maxextents unlimited
  );
-- Create/Recreate primary, unique and foreign key constraints 
alter table T_PERSON
  add constraint PK_PERSON primary key (ID)
  using index 
  tablespace USERS
  pctfree 10
  initrans 2
  maxtrans 255
  storage
  (
    initial 64K
    minextents 1
    maxextents unlimited
  );

2,创建address表
-- Create table
create table T_ADDRESS
(
  ID   NUMBER not null,
  NAME NVARCHAR2(60),
  MEMO NVARCHAR2(60)
)
tablespace SYSTEM
  pctfree 10
  pctused 40
  initrans 1
  maxtrans 255
  storage
  (
    initial 64K
    minextents 1
    maxextents unlimited
  );
-- Create/Recreate primary, unique and foreign key constraints 
alter table T_ADDRESS
  add constraint PK_ADDRESS primary key (ID)
  using index 
  tablespace USERS
  pctfree 10
  initrans 2
  maxtrans 255
  storage
  (
    initial 64K
    minextents 1
    maxextents unlimited
  );

3,创建序列
--创建序列(实现person,address主键自增的必要序列)
create sequence seq_nutz
increment by 1
start with 1
maxvalue 999999999;

4,创建触发器
--给person表创建触发器--实现主键自增
CREATE TRIGGER trigger_pk_person BEFORE
insert ON  T_PERSON FOR EACH ROW
begin
select seq_nutz.nextval into:New.id from dual;
end;

--给person表创建触发器--实现主键自增
CREATE TRIGGER trigger_pk_address BEFORE
insert ON  T_ADDRESS FOR EACH ROW
begin
select seq_nutz.nextval into:New.id from dual;
end;

2,数据库实体模型
Person实体
package com.supan.nuts.module;

import org.nutz.dao.entity.annotation.Column;
import org.nutz.dao.entity.annotation.Id;
import org.nutz.dao.entity.annotation.One;
import org.nutz.dao.entity.annotation.Table;

@Table("T_PERSON")
public class Person {
	
	@Id
	private Integer id;
	
	@Column("name")
	private String name;
	
	@Column("password")
	private String password;
	
	@Column("addressId")
	private Integer addressId;
	
	@One(target = Address.class,field = "addressId")
	private Address address;
         //省略getter setter...
}

Address实体
package com.supan.nuts.module;

import org.nutz.dao.entity.annotation.Column;
import org.nutz.dao.entity.annotation.Id;
import org.nutz.dao.entity.annotation.Table;

@Table("T_ADDRESS")
public class Address {
	
	@Id
	private Integer id;
	
	@Column("name")
	private String name;
	
	@Column("memo")
	private String memo;
         //省略getter,setter
}
三:页面
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<script type="text/javascript" src="js/jquery.js"></script>
<script type="text/javascript" src="js/json2.js"></script>
<script type="text/javascript">

    //添加person
    //在页面上构造后台需要的复杂的Person对象。
    function addPerson(){
        var person = {
                id:"1",
                name:"chenchaoyang",
                password:"woaini",
                address:{
                    id:1,
                    name:"广东省深圳市龙岗区",
                    memo:"有点远"
                }
        }
        $.ajax({
            type : 'POST',
            url : 'insertPerson.nut',
            data : JSON.stringify(person),
            success : function(){
                alert("chenchaoyang");
            }
        });
    }
    
    //获取Person对象
    function getPerson(personId){
        $.ajax({
            type : 'POST',
            url : 'getPerson.nut?personId=26',
            success : function(){
                alert("chenchaoyang");
            }
        });
    }
    
    //更新Person对象
    function updatePerson(personId){
        $.ajax({
            type : 'POST',
            url : 'updatePerson.nut?personId=26',
            success : function(){
                alert("chenchaoyang");
            }
        });
    }
    
    //更新Person对象
    function queryPerson(personId){
        $.ajax({
            type : 'POST',
            url : 'queryPerson.nut',
            success : function(){
                alert("chenchaoyang");
            }
        });
    }
    
</script>
</head>
<body>
<input type="button" value="添加Person" onclick="addPerson();">
<input type="button" value="获取Person" onclick="getPerson();">
<input type="button" value="更新Person" onclick="updatePerson();">
<input type="button" value="查询Person列表" onclick="queryPerson();">
</body>
</html>

四:Action
package com.supan.nuts.action;
import java.util.List;
import org.nutz.dao.impl.NutDao;
import org.nutz.dao.pager.Pager;
import org.nutz.ioc.loader.annotation.Inject;
import org.nutz.ioc.loader.annotation.IocBean;
import org.nutz.mvc.adaptor.JsonAdaptor;
import org.nutz.mvc.adaptor.PairAdaptor;
import org.nutz.mvc.annotation.AdaptBy;
import org.nutz.mvc.annotation.At;
import org.nutz.mvc.annotation.Ok;
import org.nutz.mvc.annotation.Param;
import com.supan.nuts.module.Person;

@IocBean
public class PersonAction {

	@Inject
	private NutDao dao;

	@At("/insertPerson")
	@Ok("json")
	@AdaptBy(type = JsonAdaptor.class)
	public String insertPerson(@Param("..") Person person) {
		// 注意下面一句话可以同时插入Person,Address表中各一条记录
		dao.insertWith(person, "address");
		return "success";
	}

	@At("/getPerson")
	@Ok("json")
	@AdaptBy(type = PairAdaptor.class)
	public String getPerson(@Param("personId") Integer personId) {
		// 仅仅获取Person对象,不包括含有的Address关联对象
		Person person = dao.fetch(Person.class, personId);
		// 获取Person对象,包括关联对象address
		Person person2 = dao.fetchLinks(person, "address");
		// 注意nutz并没有提供一个方法能一次获取Person及其关联对象address
		// 如果你想一句话获取Person及其关联对象address可以组合上面的两句
		Person person3 = dao.fetchLinks(dao.fetch(Person.class, personId),
				"address");
		return "success";
	}

	@At("/updatePerson")
	@Ok("json")
	@AdaptBy(type = PairAdaptor.class)
	public String updatePerson(@Param("personId") Integer personId) {
		// 先根据PersonId获取Person对象(注意包括其关联的address对象)
		Person person = dao.fetchLinks(dao.fetch(Person.class, personId),
				"address");
		person.setName("何胜男");
		person.setPassword("heshegnnan");
		// 更新Person关联的Address对象
		person.getAddress().setName("河南省");
		person.getAddress().setMemo("是个贫穷的地方");
		// 同时更新Person及其关联的Address对象
		dao.updateWith(person, "address");
		return "success";
	}

	/**
	 * 查询Person列表,注意nutz并不会关联查询其关联的address对象 2015年5月9日
	 */
	@At("/queryPerson")
	@Ok("json")
	@AdaptBy(type = PairAdaptor.class)
	public String queryPerson() {
		Pager pager = dao.createPager(1, 100000);
		// 仅仅查询Person列表
		List<Person> personList = dao.query(Person.class, null, pager);
		// 遍历Person列表,为每个person查询其关联的address
		for (Person person : personList) {
			dao.fetchLinks(person, "address");
		}
		return "success";
	}

	public NutDao getDao() {
		return dao;
	}

	public void setDao(NutDao dao) {
		this.dao = dao;
	}
}



分享到:
评论

相关推荐

    nutz-1.r.60.jar

    nutz-1.r.60.jar

    nutzDao增删改查Demo

    nutzDao增删改查Demo

    nutz-1.b.43-jdk5.jar

    nutz-1.b.43-jdk5.jar 资源包

    nutz-1.b.52.zip

    Nutz, 它是一组轻便小型的框架的集合。 -------------Nutz 可以做什么? Dao -- 针对 JDBC 的薄封装,事务模板,无缓存 Ioc -- JSON 风格的配置文件,声明时切片支持 Mvc -- 注解风格的配置,内置多文件上传功能 ...

    nutz-1.b.48-manual.pdf 文档

    java 框架 nutz-1.b.48-manual.pdf

    nutz-1.b.43-jdk6.jar

    nutz-1.b.43-jdk5.jar 资源包

    nutz-1.r.62.jar

    nutz-1.r.62.jar 的jar包 可以解决中文乱码,设置字符编码等等

    nutz-1.r.61-发布包

    nutz-1.r.61-发布包

    nutz-master.zip

    Nutz -- 不只是Web框架(Mvc/Ioc/Aop/Dao/Json) for ALL Java developer

    nutz 使用手册 nutz-1.a.33-manual.pdf

    nutz 使用手册 nutz 使用手册 nutz 使用手册 nutz 使用手册 nutz 使用手册 nutz 使用手册 nutz 使用手册 nutz 使用手册 nutz 使用手册 nutz 使用手册 nutz 使用手册

    nutz-1.b.49-manual.pdf

    nutz 框架nutz-1.b.49-manual.pdf,配置简单易懂

    Nutz-1.b.38

    同传统的 SSH 相比,它具备如下特点:轻 -- ...这就意味着:如果一个 Web 应用,你在 WEB-INF/lib 下只 需要放置一个 nutz.jar 就够了当然你要使用其它的连接池,数据库驱动,打印PDF支持等功能,还需要自行添置 jar 包

    nutz-1.b.49.r2.zip

    Nutz是对于Java程序员来说,除SSH之外的另一个选择。当然,它是开源的,并且是完全免费的。同时也是商业友好的(Licensed under the Apache License, Version 2.0)。

    nutz-1.r.62.zip

    nutz-1.r.62.zip 强大的Java框架,里面有许多好玩的方便的约定配置,有兴趣的可以下载再看看

    wendal-nutz-master.zip

    希望可以帮到大家,完成一个简单的NUTZ的学习。

    nutz-1.r.58

    nutz框架jar包

    nutz-jar包,20170512

    nutz-jar包,20170512

    nutz-1.r.61.r2.jar包

    nutz-1.r.61.r2-发布包_修正JDK6兼容性

    nutz-1.a.25_jdoc.zip

    nutz-1.a.25_jdoc.zip nutz-1.a.25_jdoc.zipnutz-1.a.25_jdoc.zip

    nutz-1.b.40-manual.pdf

    这就意味着:如果一个 Web 应用,你在 WEB-INF/lib 下只 需要放置一个 nutz.jar 就够了 当然你要使用其它的连接池,数据库驱动,打印PDF支持等功能,还需要自行添置 jar 包。 Nutz 为谁而设计?¶

Global site tag (gtag.js) - Google Analytics