- SQL函数 LISTAGG/string_agg/group_concat
风和雪的爱情
sql数据库
LISTAGG/string_agg/group_concatoracle函数listagg使用oracle函数listagg使用作用可以实现将多列记录聚合为一列记录,实现数据的压缩语法结构listagg(measure_expr,delimiter)withingroup(orderbyorder_by_clause);解释:measure_expr可以是基于任何列的表达式delimiter分隔
- SQL Server 如何合并组内字符串
Sxb_Cry5tal
就是在SQLSERVER实现类似MYSQL中group_concat函数的功能,把分组中的字串拼接起来。SQLServer2017可以用STRING_AGG函数实现,比如SELECTG,STRING_AGG(S,',')FROMTGROUPBYG(按表T的G字段分组,组内S字段拼接起来);但2016版没有STRING_AGG函数,就会麻烦很多:SELECTp2.G,SS=JSON_VALUE(RE
- 【PgSQL】聚合函数string_agg
思惘
后端
在工作中,遇到了这样的需求,需要根据某一个字段A分组查询,统计数量,同时还要查询另一个字段B,但是呢这个字段B在分组后的记录中存在不同的值。最开始不知道有聚合函数可以实现这一功能,在代码中进行了处理。后来,经老同事的提醒,得知了string_agg这个函数,便稍微查询整理了一下。我们先新建一张表,插入一点数据,方便演示CREATETABLEpublic.user_info_test("name"v
- 金仓数据库将一个字段的数据或者多个字段的值拼接
linux_lsh
数据库数据库
将一个字段的值拼接string_agg(字段a,'分隔符')将多个字段的值连接concat_ws('分隔符',字段a,字段b)将多个字段的值拼接成一条string_agg(concat_ws('分隔符',字段a,字段b))as新名字测试:test=#select*frombb;ID----(0rows)test=#insertintobbvalues(1),(2),(3);INSERT03test
- postgresql group by之后对string字段进行拼接
会飞的尼古拉斯
postgresqlpostgresql1024程序员节
数据如下想要的效果sql如下SELECTcompany_id,string_agg(employee,','ORDERBYemployee)FROMmytableGROUPBYcompany_id;PostgreSQLSTRING_AGG()函数是一个聚合函数,用于连接字符串列表并在它们之间放置分隔符。该函数不会在字符串的末尾添加分隔符。
- postgresql 多行转成一个json对象
一个人也很酷
数据库postgresqljson数据库
数据格式record_idquestion_nameanswer_content1学校211大学1学院信息工程学院1年级大三1班级21用户身份学生SQLselectconcat('{',string_agg(strjson,','),'}')::jsonbasstrjsonfrom(SELECTconcat('"',question_name,'":','"',REPLACE(question_v
- Postgresql常用命令函数
光明31007625
postgresql数据库
1、string_agg()函数1.1用法:string_agg(expression,delimiter),参数类型(text,text)or(bytea,bytea),返回类型和参数类型一致,第一个参数是字段名,第二个参数是样式,比如,或者#分隔。1.2实战:SELECT*FROMaddressselectprovince,string_agg(city,',')fromaddressgrou
- 数据库——表结构相关SQL
前方一片光明
数据库#PgSQLsql数据库
一、GP或PostgreSQL1.获取表结构SELECTa.schemanameschema_name,a.tablenametable_name,string_agg(b.column_name,',')AScolumnsFROM(SELECTschemaname,tablenameFROMpg_tablesWHEREschemaname='public'andtablenamelike'tes
- mysql string agg_【转】SQL Server一个字段串拆分成多行显示或者多行数据合并成一个字符串(STRING_AGG、STRING_SPLIT)...
斗鱼游戏直播
mysqlstringagg
目录概述STRING_AGG(合并):多行数据合并成一个字符串,以逗号隔开。STRING_SPLIT(拆分):一个字符串,拆分成多行。一、多行数据合并成一个字符串1、通过FORxmlpath('')合并字符串记录根据name字段,合并codedeclare@table1table(idint,codevarchar(10),namevarchar(20));insertinto@table1(id
- SQL 中的For Xml Path详解
kingwebo'sZone
sqlxml数据库
今天就给大家介绍一下FORXMLPATH,它就是用来处理低版本数据库中数据合并的,是一个比较古老的功能了,新版本中也依然还能使用,对SQL中的ForXmlPath相关知识感兴趣的朋友一起看看吧最近出的每日一题里面,有一道是关于合并同类型数据为一行的题,使用SQLServer2017版本及以上的直接使用STRING_AGG()函数即可,但是2016版本以下是没有这个功能的,那该如何求解?今天就给大家
- PG 苏相
请叫我翟先生
SELECTs.*,string_agg(a."ProjID",',')asprojectsFROM"ProjSet"sLEFTJOIN"ProjSetRelation"aONa."ProjSetID"=s."ProjSetCode"wheres."Delete"='false'#conditions#string_agg把结果集用逗号分隔并转换成字符串pg中的字段和表需要用双引号pg的truef
- Oracle的wm_concat函数对应postgresql的什么函数?
liuhuapeng0304
sqlpostgresqloracle
//oracle的函数wm_concat(name)//pg的函数string_agg(name,',')
- mysql sql合并字符串函数_SQL Server 如何合并组内字符串
weixin_39777163
mysqlsql合并字符串函数
就是在SQLSERVER实现类似MYSQL中group_concat函数的功能,把分组中的字串拼接起来。SQLServer2017可以用STRING_AGG函数实现,比如SELECTG,STRING_AGG(S,',')FROMTGROUPBYG(按表T的G字段分组,组内S字段拼接起来);但2016版没有STRING_AGG函数,就会麻烦很多:SELECTp2.G,SS=JSON_VALUE(RE
- Postgresql聚合函数string_agg() 用法
明算科
SQL数据库etl
string_agg()函数是PostgreSQL中的一个聚合函数,用于将一个列中的值连接成一个字符串。这在需要将多个行的某个字段组合成一个字符串时非常有用。函数的基本语法如下:string_agg(column_name,separator) column_name:要聚合的列名。separator:可选参数,用于连接各个值的分隔符。如果未指定或为空,则使用默认分隔符(逗号加空格)。示例:假设我
- SQL 中的 For Xml Path解析
Linux小百科
sqlxml数据库
今天就给大家介绍一下FORXMLPATH,它就是用来处理低版本数据库中数据合并的,是一个比较古老的功能了,新版本中也依然还能使用。最近出的每日一题里面,有一道是关于合并同类型数据为一行的题,使用SQLServer2017版本及以上的直接使用STRING_AGG()函数即可,但是2016版本以下是没有这个功能的,那该如何求解?今天就给大家介绍一下FORXMLPATH,它就是用来处理低版本数据库中数据
- PostgreSQL 编程参考(不断更新中...)
GadflyBSD
一、行转列SELECTstring_agg(id::varchar,'-')AS"INT数据行转String列",string_agg(mobile,'-')AS"VARCHAR数据行转String列",array_agg(id)AS"INT数据转数组",pg_typeof(array_agg(id))AS"INT数据转数组后的类型",array_agg(mobile)AS"VARCHAR数据转数
- postgres 常用sql
jadefan
字符串拼接1.一行数据中的多字段值根据连接符拼接concat_ws(':',aaa,bbb)2.几行数据中的同一单字段值根据连接符拼接string_agg(ccc,'\r\n')3.如果要将多个字段的值拼接成一个:string_agg(concat_ws(':',aaa,bbb),'\r\n'orderbyaaaasc)asxxx
- KINGBASE V7 行转列
我是东山
数据库KINGBASE列转行
KINGBASE数据库是基于PostgreSQL内核研发的国产数据库,在应用开发过程中想使用列转行函数,发现KINGBASEV7版本没有,PostgreSQL列转行函数试试STRING_AGG。没有没关系,我们可以自定义函数来实现列转行,高版本的KINGBASE会支持列转行函数。--创建测试表CREATETABLETESTHAHA(IDINT,DATA_TIMETIMESTAMP,VALUENUM
- postgresql-窗口函数
迷失的小鹿
postgresqlpostgresql数据库
postgresql-窗口函数窗口函数简介窗口函数的定义分区排序选项窗口选项窗口函数简介包括AVG、COUNT、MAX、MIN、SUM以及STRING_AGG。聚合函数的作用是针对一组数据行进行运算,并且返回一条汇总结果分析的窗口函数(WindowFunction)。不过,窗口函数不是将一组数据汇总为单个结果,而是针对每一行数据,基于和它相关的一组数据计算出一个结果。下图演示了聚合函数和窗口函数的
- postgresql-窗口函数
迷失的小鹿
postgresqlpostgresql数据库
postgresql-窗口函数简介窗口函数的定义分区选项(PARTITIONBY)排序选项(ORDERBY)窗口选项(frame_clause)聚合窗口函数排名窗口函数演示了CUME_DIST和NTILE函数取值窗口函数简介常见的聚合函数,包括AVG、COUNT、MAX、MIN、SUM以及STRING_AGG。聚合函数的作用是针对一组数据行进行运算,并且返回一条汇总结果除了聚合函数之外,SQL还定
- PostgreSQL查看索引是否失效
tttzzzqqq2018
PostgreSQLpostgresql数据库
PostgreSQL查看索引是否失效PostgreSQL查看索引是否失效PostgreSQL查看索引是否失效--PostgreSQL查看索引是否失效SELECTtrel.relnameAStable_name,irel.relnameASindex_name,string_agg(a.attname,','ORDERBYc.ordinality)AScolumnsFROMpg_indexASiJO
- ABAP读取工单状态函数优化STATUS_READ
放弃幻想_
ABAPSAPabapSAP
ZSTATUS_READ1.如下是获取工单状态类,可以自行转换RFC或者代码METHODGET_PO_STATUS_LINESBYDATABASEPROCEDUREFORHDBLANGUAGESQLSCRIPTOPTIONSREAD-ONLYUSINGJESTTJ02TJ04TJ02TAUFK.–完成生产订单抬头状态的转换ET_PO_STATUS=SELECTAUFNR,STRING_AGG(TX
- 2022-07-27——Postgresql多行合并一行
薯味
SQL数据库sqlmysql
Postgresql多行合并一行//方式一:使用string_agg函数SELECTstring_agg(DISTINCTfieldname,','orderbyfieldnameASC)FROMtable;//方式二:使用array_agg函数,一般配合array_to_string()函数使用SELECTarray_to_string(array_agg(DISTINCTfieldnameor
- oracle和pg行列转换
sqlboy-yuzhenc
greenplumpostgresqlORACLE数据库oraclepostgresql
postgresql--拆withtmp_tableas(select'a'name1,'A,B,C,D'::varcharast)selectname1,regexp_split_to_table(t,',')tfromtmp_table;--合selectname1,string_agg(t,','orderbyt)tfrom(select'a'name1,'A'tunionallselect
- PostgreSQL:string_agg 多列值聚合成一列
qq_35987023
postgreSQLpostgresql数据库
PostgreSQL:string_agg多列值聚合成一列string_agg是PostgreSQL中的一个聚合函数,用于将一组值连接为一个字符串。它接受两个参数:要连接的值和连接符。语法如下:string_agg(expression,delimiter)其中,expression是要连接的值的表达式,可以是列名、常量或表达式;delimiter是用于分隔连接的字符串。string_agg通常结
- postgreSQL根据表字段生成insert语句
AlfredNing
sqljavapostgresql数据库sql
selectconcat('insertintoXX_TABLE(',string_agg(c.attname,','),')values(',string_agg(c.palce,','),')','onconflict(pk_name)doupdateset(',string_agg(c.attname,','),')','=(',string_agg(c.f,','),')')assqlfr
- 2.Postgresql--array
yan_baby_liu
数据库postgresql数据库
CREATETABLEcity(countrycharactervarying(64),citycharactervarying(64));INSERTINTOcityVALUES('中国','台北'),('中国','香港'),('中国','上海'),('日本','东京'),('日本','大阪');selectcountry,string_agg(city,';'orderbycitydesc)f
- Postgresql行列转换
post_yuan
数据库
环境Postgresql9.4.4列转行1查询测试表数据cqdb=>select*fromtest;name------AABBCC(3rows)2列转行(string_agg)cqdb=>selectstring_agg(name,',')fromtest;string_agg------------AA,BB,CC(1row)行转列1查询测试表数据cqdb=>select*fromtest;n
- sql 常用的分组查询
S等价交换S
postgrepostgresql查询集合结果用逗号分隔返回字符串处理转载https://blog.51cto.com/u_15072903/4379700关键字:string_agg('','')例如:selectstring_agg(name||'',',')fromsys_user
- SQL 中的For Xml Path详解
目录FORXMLPATH是什么创建测试数据使用方法介绍具体实际应用代码优化STUFF()STUFF()函数的作用STUFF()函数的语法参数解释返回类型注意事项最近出的每日一题里面,有一道是关于合并同类型数据为一行的题,使用SQLServer2017版本及以上的直接使用STRING_AGG()函数即可,但是2016版本以下是没有这个功能的,那该如何求解?今天就给大家介绍一下FORXMLPATH,它
- 开发者关心的那些事
圣子足道
ios游戏编程apple支付
我要在app里添加IAP,必须要注册自己的产品标识符(product identifiers)。产品标识符是什么?
产品标识符(Product Identifiers)是一串字符串,它用来识别你在应用内贩卖的每件商品。App Store用产品标识符来检索产品信息,标识符只能包含大小写字母(A-Z)、数字(0-9)、下划线(-)、以及圆点(.)。你可以任意排列这些元素,但我们建议你创建标识符时使用
- 负载均衡器技术Nginx和F5的优缺点对比
bijian1013
nginxF5
对于数据流量过大的网络中,往往单一设备无法承担,需要多台设备进行数据分流,而负载均衡器就是用来将数据分流到多台设备的一个转发器。
目前有许多不同的负载均衡技术用以满足不同的应用需求,如软/硬件负载均衡、本地/全局负载均衡、更高
- LeetCode[Math] - #9 Palindrome Number
Cwind
javaAlgorithm题解LeetCodeMath
原题链接:#9 Palindrome Number
要求:
判断一个整数是否是回文数,不要使用额外的存储空间
难度:简单
分析:
题目限制不允许使用额外的存储空间应指不允许使用O(n)的内存空间,O(1)的内存用于存储中间结果是可以接受的。于是考虑将该整型数反转,然后与原数字进行比较。
注:没有看到有关负数是否可以是回文数的明确结论,例如
- 画图板的基本实现
15700786134
画图板
要实现画图板的基本功能,除了在qq登陆界面中用到的组件和方法外,还需要添加鼠标监听器,和接口实现。
首先,需要显示一个JFrame界面:
public class DrameFrame extends JFrame { //显示
- linux的ps命令
被触发
linux
Linux中的ps命令是Process Status的缩写。ps命令用来列出系统中当前运行的那些进程。ps命令列出的是当前那些进程的快照,就是执行ps命令的那个时刻的那些进程,如果想要动态的显示进程信息,就可以使用top命令。
要对进程进行监测和控制,首先必须要了解当前进程的情况,也就是需要查看当前进程,而 ps 命令就是最基本同时也是非常强大的进程查看命令。使用该命令可以确定有哪些进程正在运行
- Android 音乐播放器 下一曲 连续跳几首歌
肆无忌惮_
android
最近在写安卓音乐播放器的时候遇到个问题。在MediaPlayer播放结束时会回调
player.setOnCompletionListener(new OnCompletionListener() {
@Override
public void onCompletion(MediaPlayer mp) {
mp.reset();
Log.i("H
- java导出txt文件的例子
知了ing
javaservlet
代码很简单就一个servlet,如下:
package com.eastcom.servlet;
import java.io.BufferedOutputStream;
import java.io.IOException;
import java.net.URLEncoder;
import java.sql.Connection;
import java.sql.Resu
- Scala stack试玩, 提高第三方依赖下载速度
矮蛋蛋
scalasbt
原文地址:
http://segmentfault.com/a/1190000002894524
sbt下载速度实在是惨不忍睹, 需要做些配置优化
下载typesafe离线包, 保存为ivy本地库
wget http://downloads.typesafe.com/typesafe-activator/1.3.4/typesafe-activator-1.3.4.zip
解压r
- phantomjs安装(linux,附带环境变量设置) ,以及casperjs安装。
alleni123
linuxspider
1. 首先从官网
http://phantomjs.org/下载phantomjs压缩包,解压缩到/root/phantomjs文件夹。
2. 安装依赖
sudo yum install fontconfig freetype libfreetype.so.6 libfontconfig.so.1 libstdc++.so.6
3. 配置环境变量
vi /etc/profil
- JAVA IO FileInputStream和FileOutputStream,字节流的打包输出
百合不是茶
java核心思想JAVA IO操作字节流
在程序设计语言中,数据的保存是基本,如果某程序语言不能保存数据那么该语言是不可能存在的,JAVA是当今最流行的面向对象设计语言之一,在保存数据中也有自己独特的一面,字节流和字符流
1,字节流是由字节构成的,字符流是由字符构成的 字节流和字符流都是继承的InputStream和OutPutStream ,java中两种最基本的就是字节流和字符流
类 FileInputStream
- Spring基础实例(依赖注入和控制反转)
bijian1013
spring
前提条件:在http://www.springsource.org/download网站上下载Spring框架,并将spring.jar、log4j-1.2.15.jar、commons-logging.jar加载至工程1.武器接口
package com.bijian.spring.base3;
public interface Weapon {
void kil
- HR看重的十大技能
bijian1013
提升能力HR成长
一个人掌握何种技能取决于他的兴趣、能力和聪明程度,也取决于他所能支配的资源以及制定的事业目标,拥有过硬技能的人有更多的工作机会。但是,由于经济发展前景不确定,掌握对你的事业有所帮助的技能显得尤为重要。以下是最受雇主欢迎的十种技能。 一、解决问题的能力 每天,我们都要在生活和工作中解决一些综合性的问题。那些能够发现问题、解决问题并迅速作出有效决
- 【Thrift一】Thrift编译安装
bit1129
thrift
什么是Thrift
The Apache Thrift software framework, for scalable cross-language services development, combines a software stack with a code generation engine to build services that work efficiently and s
- 【Avro三】Hadoop MapReduce读写Avro文件
bit1129
mapreduce
Avro是Doug Cutting(此人绝对是神一般的存在)牵头开发的。 开发之初就是围绕着完善Hadoop生态系统的数据处理而开展的(使用Avro作为Hadoop MapReduce需要处理数据序列化和反序列化的场景),因此Hadoop MapReduce集成Avro也就是自然而然的事情。
这个例子是一个简单的Hadoop MapReduce读取Avro格式的源文件进行计数统计,然后将计算结果
- nginx定制500,502,503,504页面
ronin47
nginx 错误显示
server {
listen 80;
error_page 500/500.html;
error_page 502/502.html;
error_page 503/503.html;
error_page 504/504.html;
location /test {return502;}}
配置很简单,和配
- java-1.二叉查找树转为双向链表
bylijinnan
二叉查找树
import java.util.ArrayList;
import java.util.List;
public class BSTreeToLinkedList {
/*
把二元查找树转变成排序的双向链表
题目:
输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表。
要求不能创建任何新的结点,只调整指针的指向。
10
/ \
6 14
/ \
- Netty源码学习-HTTP-tunnel
bylijinnan
javanetty
Netty关于HTTP tunnel的说明:
http://docs.jboss.org/netty/3.2/api/org/jboss/netty/channel/socket/http/package-summary.html#package_description
这个说明有点太简略了
一个完整的例子在这里:
https://github.com/bylijinnan
- JSONUtil.serialize(map)和JSON.toJSONString(map)的区别
coder_xpf
jqueryjsonmapval()
JSONUtil.serialize(map)和JSON.toJSONString(map)的区别
数据库查询出来的map有一个字段为空
通过System.out.println()输出 JSONUtil.serialize(map): {"one":"1","two":"nul
- Hibernate缓存总结
cuishikuan
开源sshjavawebhibernate缓存三大框架
一、为什么要用Hibernate缓存?
Hibernate是一个持久层框架,经常访问物理数据库。
为了降低应用程序对物理数据源访问的频次,从而提高应用程序的运行性能。
缓存内的数据是对物理数据源中的数据的复制,应用程序在运行时从缓存读写数据,在特定的时刻或事件会同步缓存和物理数据源的数据。
二、Hibernate缓存原理是怎样的?
Hibernate缓存包括两大类:Hib
- CentOs6
dalan_123
centos
首先su - 切换到root下面1、首先要先安装GCC GCC-C++ Openssl等以来模块:yum -y install make gcc gcc-c++ kernel-devel m4 ncurses-devel openssl-devel2、再安装ncurses模块yum -y install ncurses-develyum install ncurses-devel3、下载Erang
- 10款用 jquery 实现滚动条至页面底端自动加载数据效果
dcj3sjt126com
JavaScript
无限滚动自动翻页可以说是web2.0时代的一项堪称伟大的技术,它让我们在浏览页面的时候只需要把滚动条拉到网页底部就能自动显示下一页的结果,改变了一直以来只能通过点击下一页来翻页这种常规做法。
无限滚动自动翻页技术的鼻祖是微博的先驱:推特(twitter),后来必应图片搜索、谷歌图片搜索、google reader、箱包批发网等纷纷抄袭了这一项技术,于是靠滚动浏览器滚动条
- ImageButton去边框&Button或者ImageButton的背景透明
dcj3sjt126com
imagebutton
在ImageButton中载入图片后,很多人会觉得有图片周围的白边会影响到美观,其实解决这个问题有两种方法
一种方法是将ImageButton的背景改为所需要的图片。如:android:background="@drawable/XXX"
第二种方法就是将ImageButton背景改为透明,这个方法更常用
在XML里;
<ImageBut
- JSP之c:foreach
eksliang
jspforearch
原文出自:http://www.cnblogs.com/draem0507/archive/2012/09/24/2699745.html
<c:forEach>标签用于通用数据循环,它有以下属性 属 性 描 述 是否必须 缺省值 items 进行循环的项目 否 无 begin 开始条件 否 0 end 结束条件 否 集合中的最后一个项目 step 步长 否 1
- Android实现主动连接蓝牙耳机
gqdy365
android
在Android程序中可以实现自动扫描蓝牙、配对蓝牙、建立数据通道。蓝牙分不同类型,这篇文字只讨论如何与蓝牙耳机连接。
大致可以分三步:
一、扫描蓝牙设备:
1、注册并监听广播:
BluetoothAdapter.ACTION_DISCOVERY_STARTED
BluetoothDevice.ACTION_FOUND
BluetoothAdapter.ACTION_DIS
- android学习轨迹之四:org.json.JSONException: No value for
hyz301
json
org.json.JSONException: No value for items
在JSON解析中会遇到一种错误,很常见的错误
06-21 12:19:08.714 2098-2127/com.jikexueyuan.secret I/System.out﹕ Result:{"status":1,"page":1,&
- 干货分享:从零开始学编程 系列汇总
justjavac
编程
程序员总爱重新发明轮子,于是做了要给轮子汇总。
从零开始写个编译器吧系列 (知乎专栏)
从零开始写一个简单的操作系统 (伯乐在线)
从零开始写JavaScript框架 (图灵社区)
从零开始写jQuery框架 (蓝色理想 )
从零开始nodejs系列文章 (粉丝日志)
从零开始编写网络游戏 
- jquery-autocomplete 使用手册
macroli
jqueryAjax脚本
jquery-autocomplete学习
一、用前必备
官方网站:http://bassistance.de/jquery-plugins/jquery-plugin-autocomplete/
当前版本:1.1
需要JQuery版本:1.2.6
二、使用
<script src="./jquery-1.3.2.js" type="text/ja
- PLSQL-Developer或者Navicat等工具连接远程oracle数据库的详细配置以及数据库编码的修改
超声波
oracleplsql
在服务器上将Oracle安装好之后接下来要做的就是通过本地机器来远程连接服务器端的oracle数据库,常用的客户端连接工具就是PLSQL-Developer或者Navicat这些工具了。刚开始也是各种报错,什么TNS:no listener;TNS:lost connection;TNS:target hosts...花了一天的时间终于让PLSQL-Developer和Navicat等这些客户
- 数据仓库数据模型之:极限存储--历史拉链表
superlxw1234
极限存储数据仓库数据模型拉链历史表
在数据仓库的数据模型设计过程中,经常会遇到这样的需求:
1. 数据量比较大; 2. 表中的部分字段会被update,如用户的地址,产品的描述信息,订单的状态等等; 3. 需要查看某一个时间点或者时间段的历史快照信息,比如,查看某一个订单在历史某一个时间点的状态, 比如,查看某一个用户在过去某一段时间内,更新过几次等等; 4. 变化的比例和频率不是很大,比如,总共有10
- 10点睛Spring MVC4.1-全局异常处理
wiselyman
spring mvc
10.1 全局异常处理
使用@ControllerAdvice注解来实现全局异常处理;
使用@ControllerAdvice的属性缩小处理范围
10.2 演示
演示控制器
package com.wisely.web;
import org.springframework.stereotype.Controller;
import org.spring