省市区三级级联,含有数据库.单一外键模式.

2024-06-08 16:38

本文主要是介绍省市区三级级联,含有数据库.单一外键模式.,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.最重要的是js部分.其他的数据库使用Oralce10g,MyEclipse8.6,tomcat6.x可.
2. 本身整个文件 16M>10M无法全部上传,所以学会抽出对自己有用的部分
MarketAction.java

package com.action;

import java.util.Date;
import java.util.List;
import java.util.Map;
import com.entity.Market;
import com.biz.MarketBiz;
import com.entity.Province;
import com.biz.ProvinceBiz;
import java.util.ArrayList;
import java.io.UnsupportedEncodingException;

import net.sf.json.JSONArray;
import net.sf.json.JsonConfig;

/**
* ********************************************************
* @ClassName: MarketAction
* @Description: 市级表
* @author 生成Action类
* @date 2014-08-28 下午 09:32:26
*******************************************************
*/
public class MarketAction {

private MarketBiz marketbiz;

private Market market = new Market();

private List<Market> marketlist = new ArrayList<Market>();

private List<Province> provincelist = new ArrayList<Province>();

private JSONArray jsons;

private Integer id;

/**
*
*添加表<Market>信息
*
**/
public String addMarket(){
Integer results = marketbiz.addMarket(market);
if (results > 0 ) {
return "successs";
}else {
return "error";
}
}

/**
*
*查询表<Market>所有信息
*
**/
public String getAllMarket(){
marketlist = marketbiz.getAllMarket();
if (marketlist.size() > 0 ) {
return "success";
}else {
return "error";
}
}

/**
*
*根据@id查询表<Market>信息
*
**/
public String getMarket_id(){
market.setProvince_id(id);
marketlist = marketbiz.getMarket_id(market);
if (marketlist.size() > 0 ) {
JsonConfig config = new JsonConfig();
config.setExcludes(new String[]{"county"});
jsons = JSONArray.fromObject(marketlist,config);
return "edit";
}else {
return "error";
}
}

/**
*
*根据@id修改表<Market>信息
*
**/
public String updaMarket_id(){
try {

marketbiz.updaMarket_id(market);
} catch (Exception e) {
// TODO: handle exception
return "error";
}
return "successs";
}

/**
*
*根据@id删除表<Market>信息
*
**/
public String deleMarket(){
try {
marketbiz.deleMarket(market);
} catch (Exception e) {
// TODO: handle exception
return "error";
}
return "successs";
}

/**
*
*查询关联表<Province>信息
*
**/
public String reAllProvince(){
provincelist = marketbiz.reAllProvince();
if (provincelist.size() > 0 ) {
return "relist";
}else {
return "error";
}
}

public Market getMarket() {
return market;
}
public void setMarket(Market market) {
this.market = market;
}
public List<Province> getProvincelist() {
return provincelist;
}
public void setProvincelist(List<Province> provincelist) {
this.provincelist = provincelist;
}
public List<Market> getMarketlist() {
return marketlist;
}
public void setMarketlist(List<Market> marketlist) {
this.marketlist = marketlist;
}
public void setMarketbiz(MarketBiz marketbiz) {
this.marketbiz = marketbiz;
}

public JSONArray getJsons() {
return jsons;
}

public void setJsons(JSONArray jsons) {
this.jsons = jsons;
}

public Integer getId() {
return id;
}

public void setId(Integer id) {
this.id = id;
}

}



jilian.js

function changes(obj,selectid,url){ //当前对象,选中的id,url路径.
var id = "#"+selectid;
if($(obj).val() != 0){
$.ajax({type:"post",url:url,dataType:"json",
data:{"id":$(obj).val()},//简写:TUDD.
success:function(data){
$(id).html("");
$.each(data,function(i,item){
if(selectid == "shi"){
$(id).append("<option value="+item.market_id+">"+item.market_name+"</option>");
}
if(selectid == "xian"){
$(id).append("<option value="+item.county_id+">"+item.county_name+"</option>");
}
});
if(selectid == "shi"){ // 如果下一个是市,就加上请选择市.
$(id).attr("disabled",false);
$(id).append("<option value='0' selected='selected'>---请选择市/区---</option>");
$.each($("select"),function(i,item){
if(i >= $(id).index()){
i++;
$("select:eq("+i+")").attr("disabled",true);//改变select不可用
$("select:eq("+i+")").val(0);
}
})

}
if(selectid == "xian"){ //同上
$(id).attr("disabled",false);
$(id).append("<option value='0' selected='selected'>---请选择县/区---</option>");
}
}
});
}else if(selectid == "shi" || selectid == "xian"){ //如果当前选择项是 请选择,那么下个就也是请选择,
//且不可用-
$.each($("select"),function(i,item){
if(i >= $(id).index()){
$(item).attr("disabled",true);
$(item).val(0);
}
})
}
}

页面部分:list.jsp

<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%@ taglib uri="/struts-tags" prefix="s"%>
<%
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="<%=basePath%>">

<title>县级表总览</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->

</head>

<body>
<table align="center" border="1">
<caption style="color:red;"><a href="index.jsp">Url控制</a></caption>
<tr align="center">
<td>市级id(外键)</td>
<td>县级id</td>
<td>县级名称</td>
<td>操作</td>
</tr>
<s:iterator value="countylist" status="s" var="li">
<tr align="center" <s:if test="%{#s.index % 2 == 0}">style="background-color:red;"</s:if>>
<td><s:property value="%{#li.market_id.market_id}"/></td>
<td><s:property value="%{#li.county_id}"/></td>
<td><s:property value="%{#li.county_name}"/></td>
<td>
<a href="countyreAllMarket.action">添加</a>
<a href="countygetCounty_id.action?county.county_id=<s:property value="%{#li.county_id}"/>">修改</a>
<a href="javascript:confirmdel(<s:property value="%{#li.county_id}"/>)">删除</a>
</td>
</tr>
</s:iterator>
</table>

<script type="text/javascript" src="js/jquery.min.js"></script>
<script type="text/javascript">
function confirmdel(id){
if(confirm("确定要删除么")){
location.href="countydeleCounty.action?county.county_id="+id;
}
}
</script>
</body>
</html>

struts-contor.xml

<?xml version="1.0" encoding="GBK" ?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN" "http://struts.apache.org/dtds/struts-2.1.dtd">
<struts>
<constant name="struts.devMode" value="false"/>
<constant name="struts.i18n.encoding" value="GBK"></constant>
<constant name="struts.ui.theme" value="simple"></constant>
<constant name="struts.enable.DymicMethodInvocation" value="false"/>
<package name="default" namespace="/" extends="json-default">

<!-- 表<Market> <MarketAction> 配置 -->
<action name="market*" class="MarketAction" method="{1}">
<result name="relist">Market/save.jsp</result>
<result name="success">Market/list.jsp</result>
<result name="successs" type="redirectAction">marketgetAllMarket.action</result>
<result name="edit" type="json">
<param name="root">jsons</param>
</result>
<result name="error">Market/error.jsp</result>
</action>

<!-- 表<Province> <ProvinceAction> 配置 -->
<action name="province*" class="ProvinceAction" method="{1}">
<result name="success">MyJsp.jsp</result>
<result name="successs" type="redirectAction">provincegetAllProvince.action</result>
<result name="edit">Province/update.jsp</result>
<result name="error">Province/error.jsp</result>
</action>

<!-- 表<County> <CountyAction> 配置 -->
<action name="county*" class="CountyAction" method="{1}">
<result name="relist">County/save.jsp</result>
<result name="success">County/list.jsp</result>
<result name="successs" type="redirectAction">countygetAllCounty.action</result>
<result name="edit" type="json">
<param name="root">jsons</param>
</result>
<result name="error">County/error.jsp</result>
</action>

</package>
</struts>


[quote]Quote?[/quote]

这篇关于省市区三级级联,含有数据库.单一外键模式.的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1042729

相关文章

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

C#和Unity中的中介者模式使用方式

《C#和Unity中的中介者模式使用方式》中介者模式通过中介者封装对象交互,降低耦合度,集中控制逻辑,适用于复杂系统组件交互场景,C#中可用事件、委托或MediatR实现,提升可维护性与灵活性... 目录C#中的中介者模式详解一、中介者模式的基本概念1. 定义2. 组成要素3. 模式结构二、中介者模式的特点

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

MySQL 数据库表与查询操作实战案例

《MySQL数据库表与查询操作实战案例》本文将通过实际案例,详细介绍MySQL中数据库表的设计、数据插入以及常用的查询操作,帮助初学者快速上手,感兴趣的朋友跟随小编一起看看吧... 目录mysql 数据库表操作与查询实战案例项目一:产品相关数据库设计与创建一、数据库及表结构设计二、数据库与表的创建项目二:员

MybatisPlus中removeById删除数据库未变解决方案

《MybatisPlus中removeById删除数据库未变解决方案》MyBatisPlus中,removeById需实体类标注@TableId注解以识别数据库主键,若字段名不一致,应通过value属... 目录MyBATisPlus中removeBypythonId删除数据库未变removeById(Se

在 Spring Boot 中连接 MySQL 数据库的详细步骤

《在SpringBoot中连接MySQL数据库的详细步骤》本文介绍了SpringBoot连接MySQL数据库的流程,添加依赖、配置连接信息、创建实体类与仓库接口,通过自动配置实现数据库操作,... 目录一、添加依赖二、配置数据库连接三、创建实体类四、创建仓库接口五、创建服务类六、创建控制器七、运行应用程序八