抽取BaseService
到目前为止,我们已经写了三个模块的开发了。我们已经抽取过了BaseAction、BaseDao,我们这次来看看我们的Service接口。
/**
* created by ozc on 2017/5/23.
*/
public interface UserService {
void save(User user);
void update(User user);
void delete(Serializable id);
User findObjectById(Serializable id);
List findObjects() throws ServiceException;
void exportExcel(List userList, ServletOutputStream outputStream);
void importExcel(File userExcel, String userExcelFileName);
/**
* 根据帐号和用户id查询用户
*
* @param id 用户ID
* @param account 用户帐号
* @return 用户列表
*/
List findAccount(String id, String account);
void saveUserAndRole(User user, String[] userRoleIds);
List findRoleById(String id);
void deleteUserRoleById(String[] userRoleIds);
List findUserByAccountAndPassword(String account, String password);
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
/**
* created by ozc on 2017/5/23.
*/
public interface InfoService {
public void save (Info info);
public void update (Info info);
public void delete (Serializable id);
public Info findObjectById (Serializable id);
public List findObjects () ;
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
/**
* Created by ozc on 2017/5/26.
*/
public interface RoleService {
void save(Role role);
void update(Role role);
void delete(Serializable id);
Role findObjectById(Serializable id);
List findObjects() ;
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
我们可以发现,三个Service接口中都存在着增删改查的方法,这明显就是重复的代码。 因此,我们需要将他们进行抽取成一个BaseService。
抽取BaseService
在core模块中添加service包,抽取BaseService
package zhongfucheng.core.service;
import java.io.Serializable;
import java.util.List;
/**
* Created by ozc on 2017/6/7.
*/
interface BaseService {
void save(T entity);
void update(T entity);
void delete(Serializable id);
T findObjectById(Serializable id);
List findObjects();
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
我们的Sercive是调用dao层的对象来实现方法的,因为这个Service是代表整个项目的Service,于是应该使用BaseDao
package zhongfucheng.core.service.impl;
import zhongfucheng.core.dao.BaseDao;
import zhongfucheng.core.service.BaseService;
import java.io.Serializable;
import java.util.List;
public abstract class BaseServiceImpl implements BaseService {
private BaseDao baseDao;
@Override
public void save (T entity) {
baseDao.save(entity);
}
@Override
public void update (T entity) {
baseDao.update(entity);
}
@Override
public void delete (Serializable id) {
baseDao.delete(id);
}
@Override
public T findObjectById (Serializable id) {
return baseDao.findObjectById(id);
}
@Override
public List findObjects () {
return baseDao.findObjects();
}
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
以Info模块举例子
InfoService继承了BaseService接口,于是就有了增删改查的方法。同时把泛型T的类型确定下来。
public interface InfoService extends BaseService <Info > {
}
继承了InfoService,有了增删该查的方法,然而具体的操作是BaseServiceImpl中实现的。我们继承它,并给出泛型T对应的类型。
@Service
public class InfoServiceImpl extends BaseServiceImpl <Info > implements InfoService {
}
现在的问题是什么呢???我们在BaseServiceImpl中使用了BaseDao这个变量来对数据库进行操作。可是在BaseServiceImpl中是没有BaseDao这个变量的。
首先,要明确的是,我们不能在BaseServiceImpl中注入BaseDao,因为BaseServiceImpl本身就是一个抽象类。那我们怎么对BaseDao进行实例化呢???
我们可以这样做:
@Service
public class InfoServiceImpl extends BaseServiceImpl <Info > implements InfoService {
private InfoDao infoDao;
@Resource
public void setInfoDao(InfoDao infoDao) {
super .setBaseDao(infoDao);
this .infoDao = infoDao;
}
}
BaseServiceImpl为BaseDao设置set方法。
private BaseDao baseDao;
public void setBaseDao (BaseDao baseDao) {
this .baseDao = baseDao;
}
条件查询
我们来实现下面的功能:
传统方式
其实也是一个查询,只不过查询多了一个条件罢了。按照传统的方式我们可以这样做:
在BaseDao中声明一个方法,接收的是SQL和参数列表
List < T> findObjects(String sql, List < Object> objectList);
@Override
public List findObjects (String sql, List objectList) {
Query query = getSession().createQuery(sql);
if (objectList != null ) {
int i =0 ;
for (Object o : objectList) {
query.setParameter(i, o);
i++;
}
return query.list();
}
return query.list();
}
List < T> findObjects(String sql, List < Object> objectList);
BaseServiceImpl中使用baseDao来调用它
@Override
public List findObjects (String sql, List objectList) {
return baseDao.findObjects(sql, objectList);
}
我们还是用着listUI这个方法,因为它仅仅是参数可能不同。
如果用户使用的是条件查询,那么它应该有Info对象带过来。
如果不是条件查询,就没有Info对象
根据Info对象设置是否要设置参数来查询【在HQL语句中添加新字段】。所以这个方法通用。
public String listUI() {
String hql = "FROM Info i " ;
List < Object> objectList = new ArrayList<> ();
if (info != null ) {
if (StringUtils. isNotBlank(info. getTitle())) {
hql += "where i.title like ?" ;
objectList. add("%" + info. getTitle() + "%" );
}
}
infoList = infoServiceImpl. findObjects(hql,objectList);
ActionContext. getContext(). getContextMap(). put("infoTypeMap" , Info. INFO_TYPE_MAP);
return "listUI" ;
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
优化
看回我们Action中的代码,我们可以看出一些不够优雅的地方:
于是,我们想要用一个工具类来把上面的代码进行优化。
针对上面的问题,我们发现手写拼接SQL很容易出错。那我们可以在工具类里面拼接,使用的时候调用方法获取就行啦。查询的对象写死了,我们要可以处理任何的查询。 。
我们能够找到如下的规律:
FROM Info
WHERE title like ? and state = ?
order by createTime,state
条件查询(QueryHelper):
1 、查询条件语句hql:
from 子句:必定出现;而且只出现一次
where 子句:可选;但关键字where 出现一次;可添加多个查询条件
order by 子句:可选;但关键字order by 出现一次;可添加多个排序属性
2 、查询条件值集合:
出现时机:在添加查询条件的时候,?对应的查询条件值
package zhongfucheng.core.utils;
import java.util.ArrayList;
import java.util.List;
/**
* Created by ozc on 2017/6/7.
*/
public class QueryHelper {
private String fromClause = "" ;
private String whereClause = "" ;
private String orderbyClause = "" ;
private List objectList;
public static String ORDER_BY_ASC = "asc" ;
public static String ORDER_BY_DESC = "desc" ;
/**
* 构建FROM字句,并设置查询哪张表
* @param aClass 用户想要操作的类型
* @param alias 别名
*/
public QueryHelper (Class aClass, String alias) {
fromClause = " FROM " + aClass.getSimpleName() + " " + alias;
}
/**
* 构建WHERE字句
* @param condition
* @param objects
* @return
*/
public QueryHelper addCondition (String condition, Object... objects) {
if (whereClause.length() > 0 ) {
whereClause += " AND " + condition;
} else {
whereClause += " WHERE" + condition;
}
if (objects == null ) {
objectList = new ArrayList<>();
}
for (Object object : objects) {
objectList.add(object);
}
return this ;
}
/**
*
* @param property 要排序的属性
* @param order 是升序还是降序
* @return
*/
public QueryHelper orderBy (String property, String order) {
if (orderbyClause.length() > 0 ) {
orderbyClause += " , " + property +" " + order;
} else {
orderbyClause += " ORDER BY " + property+" " + order;
}
return this ;
}
/**
* 返回HQL语句
*/
public String returnHQL () {
return fromClause + whereClause + orderbyClause;
}
/**
* 得到参数列表
* @return
*/
public List getObjectList () {
return objectList;
}
}
public String listUI () {
QueryHelper queryHelper = new QueryHelper(Info.class, "i" );
if (info != null ) {
if (StringUtils.isNotBlank(info.getTitle())) {
queryHelper.addCondition(" i.title like ? " , "%" + info.getTitle() + "%" );
}
}
queryHelper.orderBy("i.createTime" , QueryHelper.ORDER_BY_DESC);
infoList = infoServiceImpl.findObjects(queryHelper);
ActionContext.getContext().getContextMap().put("infoTypeMap" , Info.INFO_TYPE_MAP);
return "listUI" ;
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
最后在dao、service层中添加一个queryHelper参数的方法就行了。
你可能感兴趣的:(纳税服务系统【抽取BaseService、条件查询】)
python模块mediapipe安装教程
2401_85863780
python 开发语言 mediapipe
安装MediaPipe通过.whl文件的方法与安装其他Python库相似。下面是详细的步骤,指导你如何通过.whl文件安装MediaPipe。1.确认Python和pip已经安装首先,确保你的系统上已经安装了Python和pip。你可以通过打开命令行(对于Windows用户,这可以是CMD或PowerShell;对于macOS和Linux用户,这可以是终端)并运行以下命令来检查:python--v
Spring Cloud 微服务实战:网关那些事儿
Leaton Lee
spring cloud spring
引言:网关在微服务架构中的重要地位在微服务架构中,网关(Gateway)扮演着“守门人”的角色。它不仅是前后端交互的唯一入口,还承担着路由、过滤、负载均衡、安全控制等多种职责。对于一个微服务系统来说,网关的设计和实现直接决定了系统的性能、安全性和可扩展性。我深知网关是大厂面试中的高频考点。无论是BAT还是其他一线互联网公司,面试官总会围绕网关的设计与实现提出一系列问题。例如:如何实现灰度发布?如何
高流量Web服务器Kubernetes架构优化
完颜振江
前端 服务器 kubernetes
一、基础设施层优化1.节点自动扩展策略#集群自动扩缩容配置(GKE示例)apiVersion:clusterautoscaler.kubernetes.io/v1beta2kind:AutoscalingPolicymetadata:name:web-cluster-policyspec:minNodeCount:5maxNodeCount:50scaleDown:utilizationThres
在 Ubuntu 20.04 为 Clash Verge AppImage 创建桌面图标教程
FHKHH
ubuntu linux 运维
在Ubuntu20.04为AppImage创建桌面图标教程一、准备工作确保你已经下载了xxxx.AppImage文件,并且知道它所在的具体路径。同时,你可以准备一个合适的图标文件(.png格式)用于代表该应用程序,如果没有合适的图标也不影响后续操作,后续可使用系统默认图标。二、确保AppImage文件可执行AppImage文件需要具备可执行权限才能正常运行。我们可以通过终端命令来赋予其可执行权限。
计算机网络面试题库
小孟Java攻城狮
计算机网络 面试 职场和发展 java
HTTP1.0和2.0有什么区别?头部:1.0不支持头部压缩,2.0支持头部压缩()HPACK压缩1.0每个连接都要独立的TCP,2.0引入了stream的概念,解决了队头阻塞二进制头部,2.0使用二进制头部,成为二进制帧,提高传输效率顺序请求响应模型,1.0客户端有主动权,2.0允许服务器向客户端发送资源,而不是客户端明确请求HTTP2.0和3.0有什么区别?2.0基于TCP协议3.0基于QUI
第六篇:数字逻辑的“矩阵革命”——域控制器中的组合电路设计
天天爱吃肉8218
学习笔记 矩阵 线性代数 汽车 笔记
副标题:用卡诺图破解车身域控制器的逻辑迷宫,揭秘华为DriveONE的“数字特工”▍开篇:黑客帝国世界观映射>"WelcometotheRealWorld."——Morpheus>在数字逻辑的世界里,组合电路就是构建Matrix的底层代码。当新能源汽车的域控制器需要同时处理车门锁、灯光控制、热管理信号时,就像Neo同时躲避多个特工的追击——只有最优化的逻辑设计,才能让系统在纳秒级响应中游刃有余。核
钉钉的缓存图片存放目录因操作系统(Windows、macOS、Android、iOS)和设备权限不同而有所差异。以下是各平台常见的路径及注意事项:一、Windows 系统默认路径复制C:\
不一样的故事126
钉钉 缓存 macos
钉钉的缓存图片存放目录因操作系统(Windows、macOS、Android、iOS)和设备权限不同而有所差异。以下是各平台常见的路径及注意事项:一、Windows系统默认路径复制C:\Users\[你的用户名]\AppData\Local\DingTalk\cache或:复制C:\Users\[你的用户名]\AppData\Roaming\DingTalk\main\data\media\ima
MySQL的主从复制和读写分离
吾妻雪乃
linux mysql 数据库
MySQL的主从复制和读写分离MySQL的主从复制和读写分离什么是MySQL的主从复制MySQL的主从复制的主要场景MySQL主从复制原理mysq支持的复制类型MySQL主从复制延迟MySQL读写分离原理目前较为常见的MySQL读写分离分为MySQL主从复制和读写分离实验部署案例拓扑图环境配置一、搭建MySQL主从复制1、Mysql主从服务器时间同步2、主服务器的mysql配置3、从服务器的mys
如果你在使用 Edge 浏览器访问 HTTP 服务时被自动重定向到 HTTPS,并因此无法正常访问,你可以尝试以下几种解决方案:清除浏览器缓存:打开 Edge 浏览器,点击右上角的三点图标,选择“
不一样的故事126
http edge https
如果你在使用Edge浏览器访问HTTP服务时被自动重定向到HTTPS,并因此无法正常访问,你可以尝试以下几种解决方案:清除浏览器缓存:打开Edge浏览器,点击右上角的三点图标,选择“设置”。在设置中,导航到“隐私、搜索和服务”,找到“清除浏览数据”。选择“缓存的图片和文件”以及“Cookies和其他站点数据”,然后点击“清除”。检查网址:确保你输入的URL是以http://开头,而不是https:
2020-10-09
weixin_45660257
笔记
java学习集合的目标1.会使用集合存储数据2.会遍历集合,把数据取出来3.掌握每种集合的特性集合框架的学习方法方式1.学习顶层:学习顶层接口,抽象类中共性的方法,所有的子类创建对象使用Collection接口定义的是所有的单列集合中共性的方法所有的单列集合都可以使用共性的方法没有带索引的方法继承:子类共性抽取形成父类(接口)List接口1.有序的集合(存储和取出元素顺序相同)2.允许存储重复的元
【clickhouse踩坑记录】ClickHouse查询性能优化(入门级)
一条咸鱼的记录
踩坑记录 数据库 big data
背景用了一年多的ClickHouse,但好像都没系统地去学一遍,趁着最近有点时间,相对全面地去看了一圈ClickHouse的内容。发现ClickHouse虽然性能查询本身快,但如果使用不恰当,性能会被降一个级别。下面主要简单介绍一下,ClickHouse的查询可以从哪些方面做优化。可重点关注标题加粗部分!!优化方法以下,主要从表级别、语法、查询这三方面简要介绍。表级别优化填充有空值的字段对于一些表
31.5 切换链式复制到主从复制
weixin_41275260
MySQL技术大全:开发 优化与运维实战
31.5切换链式复制到主从复制如果MySQL当前的复制模式为链式复制模式,可以将其转化为MySQL的主从复制模式。本节就简单介绍一下如何将MySQL的链式复制模式转化为主从复制模式。1.服务器规划首先需要进行服务器规划,本节中的服务器规划与31.3.1节中的服务器规划相同,不再赘述。2.切换复制模式(1)在binghe152服务器上,停止从库的运行,并查看主库的状态。mysql>STOPSLAVE
mysql链式_例:MYSQL链式复制:A=>B=>C
程归子
mysql链式
A:192.168.2.155主B:192.168.2.156从/主C:192.168.2.160从A主机:vi/etc/my.cnflog-bin=mysql-binserver-id=1binlog_do_db=tongbu(注:如不指定此参数,binlog记录所有库的操作,添加用户binlog也会改变,也会复制到从服务器)servicemysqldrestartmysql-uroot-p12
使用jQuery、Ajax、ASP和MySQL实现动态加载更多内容
来自日本的亮仔
本文还有配套的精品资源,点击获取简介:“加载更多”功能改善网页用户体验,适用于大量数据场景。本文将探讨如何通过结合jQuery监听滚动事件、使用Ajax技术与服务器交互、ASP后端处理请求、以及MySQL数据库查询,实现无需刷新页面即可动态加载内容的完整步骤。1.页面滚动事件监听与处理在当今的网络应用中,页面滚动事件是一种常见的用户交互方式,它直接影响到用户体验。监听和处理滚动事件,能够帮助开发者
例:MYSQL链式复制:A=>B=>C
weixin_34268579
数据库
A:192.168.2.155主B:192.168.2.156从/主C:192.168.2.160从A主机:vi/etc/my.cnflog-bin=mysql-binserver-id=1binlog_do_db=tongbu(注:如不指定此参数,binlog记录所有库的操作,添加用户binlog也会改变,也会复制到从服务器)servicemysqldrestartmysql-uroot-p12
Memcached服务器UDP反射放大攻击
weixin_30639719
memcached 网络 操作系统
1、前言2月28日,Memcache服务器被曝出存在UDP反射放大攻击漏洞。攻击者可利用这个漏洞来发起大规模的DDoS攻击,从而影响网络正常运行。漏洞的形成原因为Memcache服务器UDP协议支持的方式不安全、默认配置中将UDP端口暴露给外部链接。2、原理分析这个漏洞的攻击方式属于DRDOS(DistributedReflectionDenialofService)分布式反射拒绝服务攻击。DRD
mysql8.0 设置远程连接
乐观主义现代人
mysql linux 服务器
1.修改配置(这一步很多教程上没有写,这是最重要的一步)cd/etc/mysql/mysql.conf.dvimmysqld.cnf#找到#bind-address=127.0.0.1,注释掉,替换成下面的配置bind-address=0.0.0.02.重启mysql服务servicemysqlrestart创建用户,授权,刷新配置生效createuser'demo'@'%'identifiedb
数字化转型的深度思考与最佳实践
小稻草打打打
数字化 数据可视化 职场和发展
引言:数字化转型的时代背景在数字经济迅猛发展的今天,数字化转型已成为企业生存和发展的必由之路。根据IDC的报告,到2025年,全球数字经济规模将超过23万亿美元,占GDP的比重将超过50%。然而,数字化转型并非简单的技术升级,而是一场涉及战略、组织、文化和技术的系统性变革。本文将深入探讨数字化转型的核心逻辑、关键挑战以及最佳实践,为企业提供可落地的参考框架。一、数字化转型的本质与核心逻辑1.数字化
网络安全之反射放大型DDOS
tiezhuLee
笔记 scapy 安全 网络 经验分享
背景据CERNET2014年10月的月报统计,其38个主节点中有超过一半检测到来自国内次数超过2200次、总流量超过16TB的NTP反射放大攻击;2016年10月美国Dyn公司的DNS服务器遭受DNS反射放大攻击与SYN洪水攻击,导致美国大范围断网;2017年11月13日到2017年11月15日期间,ZoomEye网络空间探测引擎探测到一个活动频繁的攻击——CLDAPDDoS反射放大攻击,随后对D
SpringCould openFeign 配置动态路由实现本地调试
Resean0223
日常问题解决 实际项目问题汇总 java 开发语言
概述现在很多项目都基于微服务开发,而对于开发来说,最困扰的就是本地服务间的调试。在此之前在网上给出的方案都是直接在feign调用接口写死url,但这会出现团队成员不小心将调试的url提交到仓库中,无形的增加了产线事故的产生。本文将介绍一下我自身基于项目改造的可配置feign路由的方案。Openfeign的初始化在项目启动阶段,OpenFeign框架会发起一个主动的扫包流程,从指定的目录下扫描并加载
Elasticsearch+Fluentd+Kibana 日志收集系统的搭建
Resean0223
devops elasticsearch docker
本次安装部署是在docker环境中进行,没有安装docker的,先安装docker环境,具体也可以参考我另一篇文章:[https://blog.csdn.net/qq_31366767/article/details/120880458]一、ElasticSearch安装配置1、首先先创建好安装目录,然後在改目录下创建docker-compse.yml文件version:'2'networks:e
阿里云通用平衡增强型g6e服务器网络收发包能力PPS对照表详解
m0_60889071
阿里云 服务器
阿里云服务器通用平衡增强型g6e实例是阿里云新推出的第六代云服务器,最大网络收发包能力达到2400万PPS,g6e实例CPU内存比1:4适用于高网络包收发场景等应用场景,InstanceTypes分享阿里云g6e通用平衡增强型云服务器网络收发包PPS能力汇总:阿里云g6e实例网络收发包什么是网络收发包?网络收发包PPS即packetspersecond每秒发包数量,网络信息最终都是按照包为单位发送
ubuntu系统切换python版本的方法
lkasi
Ubuntu ubuntu linux 运维
1.查看所有的python版本终端输入ls/usr/bin/python*结果2.切换版本终端输入sudoupdate-alternatives--configpython结果输入对应的选择编号即可切换python版本
RDF 规范:理解与运用
lly202406
开发语言
RDF规范:理解与运用引言资源描述框架(ResourceDescriptionFramework,RDF)是一种用于描述网络资源的框架,它允许数据以结构化的形式存储和交换。RDF规范在语义网中扮演着至关重要的角色,它为数据提供了语义描述,使得数据能够在不同的系统和应用程序之间进行有效的交换和互操作。本文将详细介绍RDF规范的基本概念、组成元素、应用场景及其重要性。RDF基本概念什么是RDF?RDF
【课程设计】Java EE SSM 试卷管理系统
鱼弦
课程设计 java-ee java
JavaEESSM试卷管理系统简介试卷管理系统是一个用于教育机构、培训中心等单位的在线考试和评估工具。该系统帮助教师管理考试题目、生成试卷,并将试卷导出为Word文档。应用使用场景学校与教育机构:用于日常测验、期中和期末考试。企业培训:用于员工技能测试和评估。在线教育平台:用于提供学生练习题和模拟考试。原理解释架构系统基于JavaEE开发,采用了Spring、SpringMVC和MyBatis(S
AJAX 与 ASP:现代 Web 开发的关键技术
csbysj2020
开发语言
AJAX与ASP:现代Web开发的关键技术引言在当今的Web开发领域,AJAX(AsynchronousJavaScriptandXML)和ASP(ActiveServerPages)是两项至关重要的技术。AJAX允许网页在不重新加载整个页面的情况下,与服务器交换数据和更新部分网页内容。而ASP则是一种服务器端脚本环境,用于动态生成交互性网页。本文将深入探讨AJAX和ASP的技术细节、应用场景以及
本地生活服务平台(源码+文档+部署+讲解)
亥时科技
生活 源代码管理 数据库 java 开源
引言随着城市化进程的加速,本地生活服务的需求日益多样化和个性化。本地生活服务平台通过数字化手段,为社区居民提供了一个全面、便捷的服务体验,从而提升社区服务体验和生活质量。系统概述本地生活服务平台采用前后端分离的架构设计,服务端基于MySQL5.7+、JDK1.8+和Redis,前端则采用VUE2.6.14和element-ui2.15.6,并在NODE14.21.3(>=8.9)环境下运行,NPM
Java 项目集成 DeepSeek,亮点项目(包成功)
代码星辰阁(公众号同名)
springboot 编程 spring boot deepseek 人工智能 java
获取DeepSeekAPI并搭建简易问答Java应用的完整步骤:“代码星辰阁”公众号有完整代码获取DeepSeekAPIKey访问DeepSeek官网:打开DeepSeek开放平台,点击右上角的“开放平台”。注册或登录账号:新注册账号通常会赠送一定数量的免费tokens。创建APIKey:在左侧菜单中点击APIKeys。点击“创建APIKey”,为APIKey命名(如“test”),然后创建。系统
linux系统测试网络pps、带宽和延时(方案来源于阿里云)
乐观主义现代人
linux 网络 阿里云
此方案来源于阿里云pps测试步骤分别在测试机和辅助测试机上执行以下命令,下载Netperf。wgethttps://benchmark-packages.oss-cn-qingdao.aliyuncs.com/netperf-2.7.0.tar.gz分别在测试机和辅助测试机上执行以下命令,安装Netperf和sar监控工具。sudoyuminstall-ygccautoconfautomakeli
天童美语:观察你的生活
消息快传
生活
在孩子的认知里,世界宛如一片充满神秘色彩的未知之境,有着无尽的奥秘等待他们去探索。家长们,引导孩子用心观察世界,领略其中的美妙,这对孩子的成长进程有着极为关键的作用。贵阳天童教育相信:观察生活,感悟生活,会给孩子带来对世界的美好之处的深度体验。为什么我们建议孩子们去观察生活呢?从认知发展理论来讲,孩子通过观察自然万象,能有效激发他们内在的好奇心与求知欲。自然环境中的各类元素,无论是宏观的生态系统,
Enum 枚举
120153216
enum 枚举
原文地址:http://www.cnblogs.com/Kavlez/p/4268601.html Enumeration
于Java 1.5增加的enum type...enum type是由一组固定的常量组成的类型,比如四个季节、扑克花色。在出现enum type之前,通常用一组int常量表示枚举类型。比如这样:
public static final int APPLE_FUJI = 0
Java8简明教程
bijian1013
java jdk1.8
Java 8已于2014年3月18日正式发布了,新版本带来了诸多改进,包括Lambda表达式、Streams、日期时间API等等。本文就带你领略Java 8的全新特性。
一.允许在接口中有默认方法实现
Java 8 允许我们使用default关键字,为接口声明添
Oracle表维护 快速备份删除数据
cuisuqiang
oracle 索引 快速 备份 删除
我知道oracle表分区,不过那是数据库设计阶段的事情,目前是远水解不了近渴。
当前的数据库表,要求保留一个月数据,且表存在大量录入更新,不存在程序删除。
为了解决频繁查询和更新的瓶颈,我在oracle内根据需要创建了索引。但是随着数据量的增加,一个半月数据就要超千万,此时就算有索引,对高并发的查询和更新来说,让然有所拖累。
为了解决这个问题,我一般一个月会进行一次数据库维护,主要工作就是备
java多态内存分析
麦田的设计者
java 内存分析 多态原理 接口和抽象类
“ 时针如果可以回头,熟悉那张脸,重温嬉戏这乐园,墙壁的松脱涂鸦已经褪色才明白存在的价值归于记忆。街角小店尚存在吗?这大时代会不会牵挂,过去现在花开怎么会等待。
但有种意外不管痛不痛都有伤害,光阴远远离开,那笑声徘徊与脑海。但这一秒可笑不再可爱,当天心
Xshell实现Windows上传文件到Linux主机
被触发
windows
经常有这样的需求,我们在Windows下载的软件包,如何上传到远程Linux主机上?还有如何从Linux主机下载软件包到Windows下;之前我的做法现在看来好笨好繁琐,不过也达到了目的,笨人有本方法嘛;
我是怎么操作的:
1、打开一台本地Linux虚拟机,使用mount 挂载Windows的共享文件夹到Linux上,然后拷贝数据到Linux虚拟机里面;(经常第一步都不顺利,无法挂载Windo
类的加载ClassLoader
肆无忌惮_
ClassLoader
类加载器ClassLoader是用来将java的类加载到虚拟机中,类加载器负责读取class字节文件到内存中,并将它转为Class的对象(类对象),通过此实例的 newInstance()方法就可以创建出该类的一个对象。
其中重要的方法为findClass(String name)。
如何写一个自己的类加载器呢?
首先写一个便于测试的类Student
html5写的玫瑰花
知了ing
html5
<html>
<head>
<title>I Love You!</title>
<meta charset="utf-8" />
</head>
<body>
<canvas id="c"></canvas>
google的ConcurrentLinkedHashmap源代码解析
矮蛋蛋
LRU
原文地址:
http://janeky.iteye.com/blog/1534352
简述
ConcurrentLinkedHashMap 是google团队提供的一个容器。它有什么用呢?其实它本身是对
ConcurrentHashMap的封装,可以用来实现一个基于LRU策略的缓存。详细介绍可以参见
http://code.google.com/p/concurrentlinke
webservice获取访问服务的ip地址
alleni123
webservice
1. 首先注入javax.xml.ws.WebServiceContext,
@Resource
private WebServiceContext context;
2. 在方法中获取交换请求的对象。
javax.xml.ws.handler.MessageContext mc=context.getMessageContext();
com.sun.net.http
菜鸟的java基础提升之道——————>是否值得拥有
百合不是茶
1,c++,java是面向对象编程的语言,将万事万物都看成是对象;java做一件事情关注的是人物,java是c++继承过来的,java没有直接更改地址的权限但是可以通过引用来传值操作地址,java也没有c++中繁琐的操作,java以其优越的可移植型,平台的安全型,高效性赢得了广泛的认同,全世界越来越多的人去学习java,我也是其中的一员
java组成:
通过修改Linux服务自动启动指定应用程序
bijian1013
linux
Linux中修改系统服务的命令是chkconfig (check config),命令的详细解释如下: chkconfig
功能说明:检查,设置系统的各种服务。
语 法:chkconfig [ -- add][ -- del][ -- list][系统服务] 或 chkconfig [ -- level <</SPAN>
spring拦截器的一个简单实例
bijian1013
java spring 拦截器 Interceptor
Purview接口
package aop;
public interface Purview {
void checkLogin();
}
Purview接口的实现类PurviesImpl.java
package aop;
public class PurviewImpl implements Purview {
public void check
[Velocity二]自定义Velocity指令
bit1129
velocity
什么是Velocity指令
在Velocity中,#set,#if, #foreach, #elseif, #parse等,以#开头的称之为指令,Velocity内置的这些指令可以用来做赋值,条件判断,循环控制等脚本语言必备的逻辑控制等语句,Velocity的指令是可扩展的,即用户可以根据实际的需要自定义Velocity指令
自定义指令(Directive)的一般步骤
&nbs
【Hive十】Programming Hive学习笔记
bit1129
programming
第二章 Getting Started
1.Hive最大的局限性是什么?一是不支持行级别的增删改(insert, delete, update)二是查询性能非常差(基于Hadoop MapReduce),不适合延迟小的交互式任务三是不支持事务2. Hive MetaStore是干什么的?Hive persists table schemas and other system metadata.
nginx有选择性进行限制
ronin47
nginx 动静 限制
http {
limit_conn_zone $binary_remote_addr zone=addr:10m;
limit_req_zone $binary_remote_addr zone=one:10m rate=5r/s;...
server {...
location ~.*\.(gif|png|css|js|icon)$ {
java-4.-在二元树中找出和为某一值的所有路径 .
bylijinnan
java
/*
* 0.use a TwoWayLinkedList to store the path.when the node can't be path,you should/can delete it.
* 1.curSum==exceptedSum:if the lastNode is TreeNode,printPath();delete the node otherwise
Netty学习笔记
bylijinnan
java netty
本文是阅读以下两篇文章时:
http://seeallhearall.blogspot.com/2012/05/netty-tutorial-part-1-introduction-to.html
http://seeallhearall.blogspot.com/2012/06/netty-tutorial-part-15-on-channel.html
我的一些笔记
===
js获取项目路径
cngolon
js
//js获取项目根路径,如: http://localhost:8083/uimcardprj
function getRootPath(){
//获取当前网址,如: http://localhost:8083/uimcardprj/share/meun.jsp
var curWwwPath=window.document.locati
oracle 的性能优化
cuishikuan
oracle SQL Server
在网上搜索了一些Oracle性能优化的文章,为了更加深层次的巩固[边写边记],也为了可以随时查看,所以发表这篇文章。
1.ORACLE采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前,那些可以过滤掉最大数量记录的条件必须写在WHERE子句的末尾。(这点本人曾经做过实例验证过,的确如此哦!
Shell变量和数组使用详解
daizj
linux shell 变量 数组
Shell 变量
定义变量时,变量名不加美元符号($,PHP语言中变量需要),如:
your_name="w3cschool.cc"
注意,变量名和等号之间不能有空格,这可能和你熟悉的所有编程语言都不一样。同时,变量名的命名须遵循如下规则:
首个字符必须为字母(a-z,A-Z)。
中间不能有空格,可以使用下划线(_)。
不能使用标点符号。
不能使用ba
编程中的一些概念,KISS、DRY、MVC、OOP、REST
dcj3sjt126com
REST
KISS、DRY、MVC、OOP、REST (1)KISS是指Keep It Simple,Stupid(摘自wikipedia),指设计时要坚持简约原则,避免不必要的复杂化。 (2)DRY是指Don't Repeat Yourself(摘自wikipedia),特指在程序设计以及计算中避免重复代码,因为这样会降低灵活性、简洁性,并且可能导致代码之间的矛盾。 (3)OOP 即Object-Orie
[Android]设置Activity为全屏显示的两种方法
dcj3sjt126com
Activity
1. 方法1:AndroidManifest.xml 里,Activity的 android:theme 指定为" @android:style/Theme.NoTitleBar.Fullscreen" 示例: <application
solrcloud 部署方式比较
eksliang
solrCloud
solrcloud 的部署其实有两种方式可选,那么我们在实践开发中应该怎样选择呢? 第一种:当启动solr服务器时,内嵌的启动一个Zookeeper服务器,然后将这些内嵌的Zookeeper服务器组成一个集群。 第二种:将Zookeeper服务器独立的配置一个集群,然后将solr交给Zookeeper进行管理
谈谈第一种:每启动一个solr服务器就内嵌的启动一个Zoo
Java synchronized关键字详解
gqdy365
synchronized
转载自:http://www.cnblogs.com/mengdd/archive/2013/02/16/2913806.html
多线程的同步机制对资源进行加锁,使得在同一个时间,只有一个线程可以进行操作,同步用以解决多个线程同时访问时可能出现的问题。
同步机制可以使用synchronized关键字实现。
当synchronized关键字修饰一个方法的时候,该方法叫做同步方法。
当s
js实现登录时记住用户名
hw1287789687
记住我 记住密码 cookie 记住用户名 记住账号
在页面中如何获取cookie值呢?
如果是JSP的话,可以通过servlet的对象request 获取cookie,可以
参考:http://hw1287789687.iteye.com/blog/2050040
如果要求登录页面是html呢?html页面中如何获取cookie呢?
直接上代码了
页面:loginInput.html
代码:
<!DOCTYPE html PUB
开发者必备的 Chrome 扩展
justjavac
chrome
Firebug:不用多介绍了吧https://chrome.google.com/webstore/detail/bmagokdooijbeehmkpknfglimnifench
ChromeSnifferPlus:Chrome 探测器,可以探测正在使用的开源软件或者 js 类库https://chrome.google.com/webstore/detail/chrome-sniffer-pl
算法机试题
李亚飞
java 算法 机试题
在面试机试时,遇到一个算法题,当时没能写出来,最后是同学帮忙解决的。
这道题大致意思是:输入一个数,比如4,。这时会输出:
&n
正确配置Linux系统ulimit值
字符串
ulimit
在Linux下面部 署应用的时候,有时候会遇上Socket/File: Can’t open so many files的问题;这个值也会影响服务器的最大并发数,其实Linux是有文件句柄限制的,而且Linux默认不是很高,一般都是1024,生产服务器用 其实很容易就达到这个数量。下面说的是,如何通过正解配置来改正这个系统默认值。因为这个问题是我配置Nginx+php5时遇到了,所以我将这篇归纳进
hibernate调用返回游标的存储过程
Supanccy2013
java DAO oracle Hibernate jdbc
注:原创作品,转载请注明出处。
上篇博文介绍的是hibernate调用返回单值的存储过程,本片博文说的是hibernate调用返回游标的存储过程。
此此扁博文的存储过程的功能相当于是jdbc调用select 的作用。
1,创建oracle中的包,并在该包中创建的游标类型。
---创建oracle的程
Spring 4.2新特性-更简单的Application Event
wiselyman
application
1.1 Application Event
Spring 4.1的写法请参考10点睛Spring4.1-Application Event
请对比10点睛Spring4.1-Application Event
使用一个@EventListener取代了实现ApplicationListener接口,使耦合度降低;
1.2 示例
包依赖
<p
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699