请问,怎么将一个字符串内的所有参数,根据数据库表的同名称列名查询出的结果将它们替换?

benbirdar 2008-09-18 02:59:26
请问一下

我有这样一段打印的命令

JOB NM=cmdprint,ID=1234
{标签编号}
PAPER PG=20,PW=1260,PH=600
{单据编号}
ENV MK=2,DR=1,DK=10,SP=1,PS=207,PO=0,TO=0,CO=0,
{数量}
XO=0,YO=0,MD=1,CP=0
START
RECT SX=138,SY=70,EX=887,EY=513,WD=2,TP=1
FONT TP=3,AT=2,DR=1,
{11位的工令单号}
WD=28,LG=28,SL=0
TEXT X=160,Y=119,L=1
TPOPart:{数量}

另外我有一张这样的表


打印命令里的{XX}是打印的参数,
现在我要做的事情是,如果打印命令里的参数{XX}和这张表的字段ColumnDescription的某个值相同,如打印命令里是{数量},那么,就从这张表里查出ColumnDescription值为“数量”的对应字段TableName为 NN_WorkoutEntry 表里查询对应字段ColumnName 为FAmount的值,也就是
select FAmount from NN_WorkoutEntry where ...
然后将这个查询出来的结果第一行第一列的FAmount 实际值替换打印命令参数里的{数量},,,,,

同理,如果打印命令里有出现{单据编号},那么根据这张表显示的,就应该执行命令select FBillNo from nn_workout where ...
然后将这个查询出来的结果第一行第一列的FAmount 实际值替换打印命令参数里的{单据编号},,,,,

注:打印命令里的参数个数和参数是什么,都是不确定的。

这个应该怎么实现呢???

请各位老大们帮忙啊!!!
...全文
218 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
benbirdar 2008-09-18
  • 打赏
  • 举报
回复
4 楼牛X!!!!!!
非常感谢!!!!!!!!!!
yagebu1983 2008-09-18
  • 打赏
  • 举报
回复
学习ojlovecd!!
我姓区不姓区 2008-09-18
  • 打赏
  • 举报
回复

string str = @"JOB NM=cmdprint,ID=1234
{标签编号}
PAPER PG=20,PW=1260,PH=600
{单据编号}
ENV MK=2,DR=1,DK=10,SP=1,PS=207,PO=0,TO=0,CO=0,
{数量}
XO=0,YO=0,MD=1,CP=0
START
RECT SX=138,SY=70,EX=887,EY=513,WD=2,TP=1
FONT TP=3,AT=2,DR=1,
{11位的工令单号}
WD=28,LG=28,SL=0
TEXT X=160,Y=119,L=1
TPOPart:{数量} ";
Regex reg = new Regex("{(?<param>.*)}");
List<string> list = new List<string>();
Match m = reg.Match(str);
while (m.Success)
{
list.Add(m.Groups["param"].Value);
m = m.NextMatch();
}
using (SqlConnection conn = new SqlConnection("连接字符串"))
{
conn.Open();
foreach (string s in list)
{
string replacement = "", tableName = "", columnName = "";
using (SqlCommand cmd = new SqlCommand("select * from yourtable where ColumnDescription='" + s + "'", conn))
{
using (SqlDataReader dr = cmd.ExecuteReader())
{
if (dr.Read())
{
tableName = dr["TableName"].ToString();
columnName = dr["ColumnName"].ToString();
}
}
}
using (SqlCommand cmd = new SqlCommand("select " + columnName + " from " + tableName, conn))
{
replacement = cmd.ExecuteScalar().ToString();
}
str.Replace(s, replacement);
}
}
fht123 2008-09-18
  • 打赏
  • 举报
回复
比如:
dataset ds=new dataset()
string sql1="select TableName,ColumnName from 表 where ColumnDes='"++"'"
SqlDataAdapter adp=new SqlDataAdapter(sql1,conn)
adp.fill(ds)
string tablename=ds.table[0].rows[0][0].tostring()
string columnname=ds.table[0].rows[0][1].tostring()
string sql2="select "+columnname+" from "+tablename+""
执行sql2
fht123 2008-09-18
  • 打赏
  • 举报
回复
打印参数作为查询条件,查出对应的记录,把该记录的表名和列名再作为参数取相应的数据.
benbirdar 2008-09-18
  • 打赏
  • 举报
回复
我的数据库内有很多张表,要从哪张表内查询什么字段,就是根据这张表来做的



我的问题是,我怎么知道我的打印命令中有哪些参数是在这张表内的ColumnDescription存在的,
我怎么根据打印命令里有什么参数去查这张表的ColumnDescription字段?
只要能将打印命令里的参数{XXX}和ColumnDescription字段对应上,那剩下的我就能做了??

请问各位老大,应该怎么做》?
我要的最后结果就是将打印命令内的所有{参数}都替换为数据库中表的相应字段的实际值!!!!
书名:《Java开发实战1200例(第I卷)》(清华大学版社.李钟尉,陈丹丹) PDF格式扫描版,全书分为24章,共817页。2011年1月版。 全书压缩打包成4部分,这是第3部分 注:本系列图书的第I、II卷再版时均相应改名为《xxx开发实例大全》(基础卷)及(提高卷),但内容基本无变化,需要的童鞋可自由匹配查找。 内容简介   《Java开发实战1200例》分为I、II两卷共计1200个例子,包括了开发中各个方面最常用的实例,是目前市场上实例最全面的开发类图书;书中实例来源于多位工程师的多年积累,具有很强的实用性。 本书是第II卷,以开发人员在项目开发中经常遇到的问题和必须掌握的技术为中心,介绍了应用Java进行桌面程序开发各个方面的知识和技巧,主要包括Java语法与面向对象技术、Java高级应用、窗体与控件应用、文件操作典型应用和数据库应用。全书分5篇24章,共计603个实例和603个经验技巧。每个实例都是经过笔者精心筛选的,具有很强的实用性,其中一些实例是开发人员难于寻觅的解决方案。 本书两卷共计1200个例子,包括了开发中各个方面最常用的实例,是目前市场上实例最全面的开发类图书;本书实例来源于多位工程师的多年积累,具有很强的实用性。   本书非常适合Java的初学者,如高校学生、求职人员作为练习、速查、学习使用,也适合Java程序员参考、查阅。 目 录 第1篇 Java语法与面向对象技术 第1章 开发环境的应用 2 1.1 Java环境 3 实例001 下载JDK开发工具包 3 实例002 把JDK工具包安装到指定磁盘 4 实例003 设置JDK的环境变量 6 实例004 验证Java开发环境 7 实例005 下载并安装JRE执行环境 8 实例006 编程输星号组成的等腰三角形 9 1.2 开发工具 11 实例007 下载最新的Eclipse 11 实例008 为最新的Eclipse安装中文语言包 12 实例009 活用Eclipse的工作空间 14 实例010 在Eclipse项目中编程输字符情 15 实例011 为Eclipse添加新的JDK环境 17 实例012 设置Eclipse中文API提示信息 18 实例013 为项目添加类库 20 实例014 使当前项目依赖另一个项目 21 1.3 界面设计器 22 实例015 安装界面设计器 22 实例016 设计Windows系统的运行对话框 界面 23 实例017 设计计算器程序界面 26 实例018 设计关于进销存管理系统的界面 27 第2章 Java基础应用 29 2.1 基本语法 30 实例019 输错误信息与调试信息 30 实例020 从控制台接收输入字符 31 实例021 重定向输流实现程序日志 31 实例022 自动类型转换与强制类型转换 33 2.2 运算符 34 实例023 加密可以这样简单(位运算) 34 实例024 用三元运算符判断奇数和偶数 35 实例025 更精确地使用浮点数 35 实例026 不用乘法运算符实现2×16 37 实例027 实现两个变量的互换(不借助 第3个变量) 37 2.3 条件语句 38 实例028 判断某一年是否为闰年 38 实例029 验证登录信息的合法性 39 实例030 为新员工分配部门 40 实例031 用Switch语句根据消费金额计算折扣 41 实例032 判断用户输入月份的季节 42 2.4 循环控制 43 实例033 使用while与自增运算符循环遍历 数组 43 实例034 使用for循环输杨辉三角 43 实例035 使用嵌套循环在控制台上输 九九乘法 44 实例036 用while循环计算1+1/2!+1/3!…1/20! 45 实例037 for循环输空心的菱形 46 实例038 foreach循环优于for循环 47 实例039 终止循环体 48 实例040 循环体的过滤器 49 实例041 循环的极限 50 第3章 数组与集合的应用 51 3.1 数组演练 52 实例042 获取一维数组最小值 52 实例043 将二维数组中的行列互换 53 实例044 利用数组随机抽取幸运观众 54 实例045 用数组设置JTable格的列名与列宽 55 3.2 数组操作 57 实例046 数组的下标界限 57 实例047 按钮控件数组实现计数器界面 58 实例048 复选框控件数组 59 实例049 用数组反转字符串 60 3.3 数组排序与查询 61 实例050 使用选择排序法 61 实例051 使用冒泡排序法 62 实例052 使用快速排序法 64 实例053 使用直接插入法 65 实例054 使用sort方法对数组进行排序 67 实例055 反转数组中元素的顺序 68 3.4 常用集合的使用 69 实例056 用动态数组保存学生姓名 69 实例057 用List集合传递学生信息 70 实例058 用TreeSet生成不重复自动排序 随机数组 71 实例059 Map映射集合实现省市级联选择框 73 第4章 字符串处理技术 75 4.1 格式化字符串 76 实例060 把数字格式化为货币字符串 76 实例061 格式化当前日期 77 实例062 货币金额大写格式 78 实例063 String类格式化当前日期 80 实例064 字符串大小写转换 82 实例065 字符与Unicode码的转换 83 4.2 辨别字符串 84 实例066 判断用户名是否正确 84 实例067 用户名排序 85 实例068 判断网页请求与FTP请求 86 实例069 判断文件类型 87 实例070 判断字符串是否为数字 89 实例071 验证IP地址的有效性 90 实例072 鉴别非法电话号码 91 4.3 操作字符串 92 实例073 根据标点符号对字符串进行分行 92 实例074 将字符串的每个字符进行倒序输 94 实例075 获取字符串中汉字的个数 94 实例076 批量替换某一类字符串 95 实例077 把异常与错误信息显示到窗体中 97 实例078 从字符串中分离文件路径、 文件名及扩展名 98 实例079 判断手机号的合法性 99 实例080 用字符串构建器追加字符 100 实例081 去掉字符串中的所有空格 101 实例082 汉字与区位码的转换 102 第5章 面向对象技术应用 103 5.1 Java中类的定义 104 实例083 自定义图书类 104 实例084 温度单位转换工具 105 实例085 域的默认初始化值 106 实例086 编写同名的方法 107 实例087 构造方法的应用 108 5.2 修饰符的使用 109 实例088 单例模式的应用 109 实例089 祖先的止痒药方 110 实例090 统计图书的销售量 111 实例091 汉诺塔问题求解 112 实例092 不能重写的方法 113 5.3 包装类的使用 114 实例093 将字符串转换成整数 114 实例094 整数进制转换器 115 实例095 查看数字的取值范围 116 实例096 ASCII编码查看器 117 实例097 Double类型的比较 118 5.4 面向对象的特征 119 实例098 经理与员工的差异 119 实例099 重写父类中的方法 121 实例100 计算几何图形的面积 122 实例101 提高产品质量的方法 123 实例102 简单的汽车销售商场 124 5.5 Object类的应用 126 实例103 两只完全相同的宠物 126 实例104 简化equals()方法的重写 127 实例105 重新计算对象的哈希码 129 实例106 简化hashCode()方法的重写 130 实例107 使用字符串对象 132 实例108 简化toString()方法的重写 133 5.6 克隆与序列化 134 实例109 Java对象的假克隆 134 实例110 Java对象的浅克隆 135 实例111 Java对象的深克隆 137 实例112 序列化与对象克隆 139 实例113 深克隆效率的比较 141 实例114 transient关键字的应用 143 5.7 接口和内部类 145 实例115 使用sort()方法排序 145 实例116 简化compareTo()方法的重写 146 实例117 策略模式的简单应用 148 实例118 适配器模式的简单应用 149 实例119 普通内部类的简单应用 151 实例120 局部内部类的简单应用 152 实例121 匿名内部类的简单应用 153 实例122 静态内部类的简单应用 154 第2篇 Java高级应用 第6章 多线程技术 158 6.1 线程的基础 159 实例123 新建无返回值的线程 159 实例124 查看线程的运行状态 160 实例125 查看JVM中的线程名 161 实例126 查看和修改线程名称 163 实例127 查看和修改线程优先级 165 实例128 使用守护线程 166 实例129 休眠当前线程 167 实例130 终止指定线程 169 实例131 线程的插队运行 170 6.2 线程的同步 171 实例132 非同步的数据读写 171 实例133 使用方法实现线程同步 172 实例134 使用代码块实现线程同步 174 实例135 使用特殊域变量实现线程同步 175 实例136 使用重入锁实现线程同步 176 实例137 使用线程局部变量实现线程同步 177 实例138 简单的线程通信 179 实例139 简单的线程死锁 180 实例140 解决线程的死锁问题 182 6.3 线程的进阶 183 实例141 使用阻塞队列实现线程同步 183 实例142 新建有返回值的线程 184 实例143 使用线程池优化多线程编程 186 实例144 Object类中线程相关的方法 187 实例145 哲学家就餐问题 189 实例146 使用信号量实现线程同步 190 实例147 使用原子变量实现线程同步 191 实例148 使用事件分配线程更新Swing控件 193 实例149 使用SwingWorker类完成耗时操作 194 第7章 反射与异常处理 195 7.1 反射的基础 196 实例150 实例化Class类的5种方式 196 实例151 获得Class对象示实体的名称 197 实例152 查看类的声明 198 实例153 查看类的成员 199 实例154 按继承层次对类排序 201 实例155 查看内部类信息 202 7.2 反射的进阶 203 实例156 动态设置类的私有域 203 实例157 动态调用类中的方法 204 实例158 动态实例化类 205 实例159 创建长度可变的数组 206 实例160 利用反射重写toString()方法 208 实例161 反射与动态代理 209 7.3 常见的未检查型异常 210 实例162 算数异常 210 实例163 数组存值异常 211 实例164 数组下标越界异常 212 实例165 空指针异常 213 7.4 常见的已检查型异常 214 实例166 类未发现异常 214 实例167 非法访问异常 215 实例168 文件未发现异常 216 实例169 数据库操作异常 217 7.5 处理异常 218 实例170 方法中抛异常 218 实例171 方法上抛异常 219 实例172 自定义异常类 220 实例173 捕获单个异常 221 实例174 捕获多个异常 222 第8章 枚举与泛型的应用 223 8.1 枚举使用的简介 224 实例175 查看枚举类型的定义 224 实例176 枚举类型的基本特性 225 实例177 增加枚举元素的信息 226 实例178 选择合适的枚举元素 227 实例179 高效的枚举元素集合 228 实例180 高效的枚举元素映射 229 实例181 遍历枚举接口的元素 230 实例182 简单的文件合并工具 231 8.2 泛型使用的简介 233 实例183 自定义非泛型栈结构 233 实例184 使用泛型实现栈结构 234 实例185 自定义泛型化数组类 235 实例186 泛型方法与数据查询 236 实例187 泛型化方法与最小值 238 实例188 泛型化接口与最大值 239 实例189 使用通配符增强泛型 240 实例190 泛型化的折半查找法 241 第9章 编程常用类 343 9.1 Calendar类的使用 244 实例191 简单的数字时钟 244 实例192 简单的电子时钟 245 实例193 简单的模拟时钟 246 实例194 简单的公历万年历 248 实例195 查看生日相关信息 249 9.2 SimpleDateFormat与TimeZone 类的使用 250 实例196 日期格式有效性判断 250 实例197 常见日期格式使用 252 实例198 查看本地时区 253 实例199 简单的时区转换工具 254 9.3 System类的使用 255 实例200 查看常用系统属性 255 实例201 重定向标准输 256 实例202 计算程序运行时间 257 实例203 从控制台输入密码 258 9.4 Math类的使用 259 实例204 角度和弧度的转换 259 实例205 三角函数的使用 260 实例206 反三角函数的使用 261 实例207 双曲函数的使用 262 实例208 指数与对数运算 263 9.5 其他常用类的使用 264 实例209 高精度整数运算 264 实例210 高精度浮点运算 265 实例211 七星彩号码生成器 266 实例212 大乐透号码生成器 267 实例213 监视JVM内存状态 268 实例214 启动默认文本工具 269 实例215 简单的截图软件 270 第10章 Commons组件 272 10.1 Commons Lang组件简介 273 实例216 数组元素的增加 273 实例217 数组元素的删除 274 实例218 生成随机字符串 275 实例219 序列化与反序列化 276 实例220 分数的常见运算 277 实例221 整数取值范围判断 279 10.2 Commons Math组件简介 280 实例222 描述统计学应用 280 实例223 绘制简单直方图 281 实例224 一元线性回归计算 282 实例225 实数矩阵的运算 283 实例226 复数的常见运算 284 实例227 T分布常用计算 285 10.3 Commons IO组件简介 286 实例228 简化文件(夹)删除 286 实例229 简化文件(夹)复制 287 实例230 简化文件(夹)排序 288 实例231 简化文件(夹)过滤 289 实例232 简化文件的读写操作 290 10.4 Commons BeanUtils组件简介 291 实例233 设置JavaBean简单属性 291 实例234 设置JavaBean级联属性 293 实例235 动态生成JavaBean 295 实例236 复制JavaBean属性 296 实例237 动态排序JavaBean 298 10.5 其他Commons组件简介 299 实例238 优雅的JDBC代码 299 实例239 结果集与Bean列 301 实例240 编写MD5查看器 302 实例241 基于Base64编码 304 实例242 基于Base64解码 305 实例243 发送简单的Email 306 实例244 发送带附件的Email 308 实例245 读取XML文件属性 310 第3篇 窗体与控件应用 第11章 窗体设计 314 11.1 设置窗体位置 315 实例246 控制窗体加载时的位置 315 实例247 设置窗体在屏幕中的位置 315 实例248 从上次关闭位置启动窗体 316 实例249 始终在桌面最顶层显示的窗体 317 11.2 设置窗体大小 319 实例250 设置窗体大小 319 实例251 根据桌面大小调整窗体大小 320 实例252 自定义最大化、最小化和关闭按钮 321 实例253 禁止改变窗体的大小 323 11.3 设置窗体的标题栏 324 实例254 指定窗体标题栏图标 324 实例255 拖动没有标题栏的窗体 325 实例256 取消窗体标题栏与边框 326 实例257 设置闪烁的标题栏 328 11.4 设置窗体的背景 329 实例258 设置窗体背景颜色为淡蓝色 329 实例259 实现带背景图片的窗体 330 实例260 使背景图片自动适应窗体的大小 331 实例261 背景为渐变色的主界面 332 实例262 随机更换窗体背景 334 11.5 窗体形状及应用 335 实例263 椭圆形窗体界面 335 实例264 钻石形窗体 336 实例265 创建透明窗体 337 11.6 对话框 338 实例266 模态对话框与非模态对话框 338 实例267 信息提示对话框 340 实例268 设置信息提示对话框的图标 341 实例269 文件选择对话框指定数据库备份文件 342 实例270 指定打开对话框的文件类型 343 实例271 文件的保存对话框 344 实例272 为保存对话框设置默认文件名 346 实例273 支持图片预览的文件选择对话框 347 实例274 颜色选择对话框 348 实例275 信息输入对话框 350 实例276 定制信息对话框 350 11.7 MDI窗体的使用 352 实例277 创建内部子窗体 352 实例278 使子窗体最大化显示 353 实例279 对子窗体进行平铺排列 354 实例280 禁用MDI窗体控制栏中的“最大化” 按钮 355 第12章 窗体特效 357 12.1 让窗体更有活力 358 实例281 右下角弹信息窗体 358 实例282 淡入淡的窗体 359 实例283 窗体顶层的进度条 361 实例284 设置窗体的鼠标光标 362 实例285 窗体抖动 363 实例286 窗体标题显示计时器 364 实例287 动态展开窗体 365 实例288 仿QQ隐藏窗体 366 实例289 窗体百叶窗登场特效 367 实例290 关闭窗体打开网址 368 12.2 窗体与控件外观 369 实例291 Nimbus外观 369 实例292 本地系统外观 370 实例293 分割的窗体界面 371 实例294 圆周运动的窗体 373 第13章 基本控件应用 375 13.1 顶层容器的应用 376 实例295 框架容器的背景图片 376 实例296 更多选项的框架容器 377 实例297 拦截事件的玻璃窗格 378 实例298 简单的每日提示信息 379 实例299 震动效果的提示信息 380 13.2 布局管理器应用 382 实例300 边框布局的简单应用 382 实例301 流式布局的简单应用 383 实例302 网格布局的简单应用 384 实例303 制作圆形布局管理器 385 实例304 制作阶梯布局管理器 386 13.3 输入控件的应用 387 实例305 可以打开网页的标签 387 实例306 密码域控件的简单应用 389 实例307 给文本域设置背景图片 390 实例308 给文本区设置背景图片 391 实例309 简单的字符统计工具 392 13.4 选择控件的应用 393 实例310 能预览图片的复选框 393 实例311 简单的投票计数软件 394 实例312 单选按钮的简单应用 395 实例313 能显示图片的组合框 396 实例314 使用滑块来选择日期 398 13.5 菜单控件的应用 400 实例315 模仿记事本的菜单栏 400 实例316 自定义纵向的菜单栏 401 实例317 复选框与单选按钮菜单 402 实例318 包含图片的弹菜单 404 实例319 工具栏的实现与应用 405 13.6 其他技术的应用 406 实例320 自定义软件安装向导 406 实例321 查看系统支持的外观 407 实例322 制作软件的闪屏界面 408 实例323 自定义系统托盘图标 410 实例324 使用撤销与重做功能 412 第14章 复合数据类型控件应用 414 14.1 列的简单应用 415 实例325 修改列项显示方式 415 实例326 修改列项选择模式 416 实例327 列项的全选与不选 417 实例328 列元素与提示信息 419 实例329 监听列项单击事件 420 实例330 监听列项双击事件 421 14.2 列的高级应用 422 实例331 实现自动排序的列 422 实例332 列项的增加与删除 423 实例333 查找特定的列元素 425 实例334 包含边框的列元素 426 实例335 包含图片的列元素 427 实例336 可以预览字体的列 428 14.3 格的简单应用 430 实例337 头与列的高度设置 430 实例338 调整格各列的宽度 431 实例339 设置格的选择模式 433 实例340 为头增添提示信息 434 实例341 单元格的粗粒度排序 436 实例342 实现格的查找功能 437 14.4 格的高级应用 438 实例343 在格中应用组合框 438 实例344 删除格中选中的行 440 实例345 实现格的分页技术 442 实例346 为单元格绘制背景色 444 实例347 实现格的栅栏效果 445 实例348 单元格的细粒度排序 446 14.5 树控件简单应用 448 实例349 编写中国省市信息树 448 实例350 树控件常用遍历方式 449 实例351 自定义树节点的图标 451 实例352 监听节点的选择事件 452 实例353 设置树控件选择模式 453 实例354 查看节点的各种状态 455 14.6 树控件高级应用 456 实例355 在树控件中增加节点 456 实例356 在树控件中删除节点 458 实例357 在树控件中查找节点 459 实例358 自定义树节点的外观 460 实例359 为树节点增加提示信息 463 实例360 双击编辑树节点功能 464 第15章 其他高级控件应用 466 15.1 JTextPane控件的应用 467 实例361 自定义文档标题的样式 467 实例362 文档中显示自定义图片 468 实例363 检查代码中的括号是否匹配 469 实例364 描红显示100以内的质数 471 15.2 JEditorPane控件的应用 472 实例365 自定义RTF文件查看器 472 实例366 编写简单的浏览器 474 实例367 支持超链接的浏览器 474 实例368 高亮用户指定的关键字 476 15.3 其他文本控件的应用 477 实例369 只能输入整数的文本域 477 实例370 强制输入合法的整数 478 实例371 使用微调控件调整时间 479 实例372 使用微调控件浏览图片 480 15.4 进度指示器的应用 481 实例373 显示完成情况的进度条 481 实例374 监听进度条的变化事件 482 实例375 进度监视器控件的应用 484 实例376 监视文件读入的进度 485 15.5 控件组织器的应用 487 实例377 分割面板的简单应用 487 实例378 为选项卡增加快捷键 488 实例379 为选项卡标题设置图标 489 实例380 记录选项卡的访问状态 490 第16章 控件特效与自定义控件 492 16.1 控件边框效果 493 实例381 实现标签控件的立体边框 493 实例382 实现按钮控件边框留白 494 实例383 实现文本域控件的浮雕化边框 495 实例384 为文本框控件添加LineBorder 线形边框 496 实例385 控件的纯色边框与图标边框 498 实例386 实现带标题边框的面板容器 499 实例387 指定字体的标题边框 501 实例388 嵌套的标题边框 502 实例389 带图标边框的标题边框 503 实例390 文本框的下划线边框 504 16.2 控件渲染让界面UI更灵活 506 实例391 支持图标的列控件 506 实例392 在列控件中显示单选按钮 507 实例393 列控件折行显示列项 508 实例394 使用图片制作绚丽按钮 510 实例395 实现按钮关键字描红 511 实例396 忙碌的按钮控件 512 实例397 实现透明效果的格控件 513 实例398 在格中显示工作进度百分比 515 实例399 在格中显示图片 517 16.3 让控件活起来 518 实例400 鼠标经过时按钮放大效果 518 实例401 迟到的登录按钮 520 实例402 焦点按钮的缩放 521 实例403 标签文本的跑马灯特效 522 实例404 延迟生效的按钮 524 实例405 动态加载格数据 525 16.4 自定义控件 526 实例406 石英钟控件 526 实例407 IP输入文本框控件 527 实例408 日历控件 530 实例409 平移面板控件 531 实例410 背景图面板控件 533 第4篇 文件操作典型应用 第17章 文件与文件夹操作 536 17.1 文件操作 537 实例411 修改文件属性 537 实例412 显示指定类型的文件 538 实例413 以树结构显示文件路径 540 实例414 查找替换文本文件内容 541 实例415 支持图片预览的文件选择对话框 543 实例416 设置Windows的文件属性 545 实例417 文件批量重命名 547 实例418 快速批量移动文件 549 实例419 删除磁盘中所有的.tmp临时文件 551 17.2 文件与数据库 553 实例420 提取数据库内容到文件 553 实例421 提取文本文件的内容到MySQL数据库 555 实例422 将图片文件保存到SQL Server数据库 556 实例423 显示数据库中的图片信息 558 实例424 提取技术网站数据到文件夹 559 实例425 读取文件路径到数据库 561 实例426 在数据库中建立磁盘文件索引 562 17.3 操作磁盘文件夹 564 实例427 窗体动态加载磁盘文件 564 实例428 删除文件夹中所有文件 565 实例429 创建磁盘索引文件 567 实例430 快速全盘查找文件 568 实例431 获取磁盘所有文本文件 570 实例432 网络文件夹备份 571 第18章 文件的读取、写入、整理和控制 573 18.1 文件的读取与写入 574 实例433 键盘录入内容保存到文本文件 574 实例434 将数组写入到文件中并逆序输 575 实例435 利用StringBuffer避免文件的多次写入 576 实例436 合并多个txt文件 577 实例437 实现文件简单加密与解密 579 实例438 对大文件实现分割处理 581 实例439 将分割后的文件重新合并 583 实例440 读取属性文件的单个属性值 584 实例441 向属性文件中添加信息 585 实例442 在复制文件时使用进度条 586 实例443 从XML文件中读取数据 587 实例444 读取Jar文件属性 589 实例445 电子通讯录 590 18.2 实现文件整理 592 实例446 批量复制指定扩展名的文件 592 实例447 计数器小程序 594 实例448 将某文件夹中的文件进行分类存储 595 18.3 文件控制 597 实例449 利用StreamTokenizer统计文件的 字符数 597 实例450 在指定目录下搜索文件 598 实例451 序列化和反序列化对象 600 实例452 文件锁定 602 实例453 投票统计 603 第19章 文件压缩 605 19.1 Java实现文件压缩 606 实例454 压缩所有文本文件 606 实例455 压缩包解压到指定文件夹 607 实例456 压缩所有子文件夹 608 实例457 深层文件夹压缩包的释放 610 实例458 解决压缩包中文乱码 611 实例459 Apache实现文件解压缩 612 实例460 把窗体压缩成ZIP文件 613 实例461 解压缩Java对象 615 19.2 RAR文件压缩 616 实例462 文件压缩为RAR文档 616 实例463 解压缩RAR压缩包 619 实例464 文件分卷压缩 621 实例465 为RAR压缩包添加注释 623 实例466 获取压缩包详细文件列 625 实例467 从RAR压缩包中删除文件 627 实例468 在压缩文件中查找字符串 628 实例469 重命名RAR压缩包中的文件 629 实例470 创建自解压RAR压缩包 631 实例471 设置RAR压缩包密码 632 19.3 数据压缩的网络应用 634 实例472 以压缩格式传输网络数据 634 实例473 压缩远程文件夹 637 实例474 压缩存储网页 638 第20章 操作办公文档 640 20.1 操作Word 641 实例475 把文本文件导入到Word中 641 实例476 浏览本地Word文件 642 实例477 将员工插入到Word文档中 644 实例478 将员工照片插入到Word简历 645 实例479 将Word文档保存为HTML格式 646 20.2 操作Excel 647 实例480 将员工信息保存到Excel中 647 实例481 通过Excel公式计算商品中的 总售价 649 实例482 将数据库中的内容写入到Excel 651 实例483 将Excel中的内容保存到数据库 653 实例484 将Excel文件转换为HTML格式 654 20.3 操作PDF 655 实例485 应用iText组件生成PDF 655 实例486 在窗体中显示PDF文件 657 实例487 应用PDF Renderer组件实现放大 PDF文件 658 实例488 应用PDF Renderer组件实现缩小 PDF文件 660 实例489 应用PDF Renderer组件实现抓手功能 661 实例490 全屏显示PDF文件 662 第5篇 数据库应用 第21章 SQL应用 666 21.1 排序和分组函数应用 667 实例491 对数据进行降序查询 667 实例492 对数据进行多条件排序查询 669 实例493 对统计结果进行排序 670 实例494 查询SQL Server数据库中的前3条 数据 671 实例495 查询SQL Server数据库中的后3 条数据 672 实例496 查询MySQL数据库中的前3条数据 673 实例497 查询MySQL数据库中的后3条数据 674 实例498 按照字母顺序对留学生进行排序 675 实例499 按姓氏笔画排序 677 实例500 将汉字按音序排序 678 实例501 按列的编号排序 679 实例502 从中随机返回记录 680 实例503 使用GROUP BY子句实现对数据的 分组统计 681 实例504 使用GROUP BY子句实现多 分组统计 682 21.2 聚集函数与日期查询 683 实例505 利用SUM函数实现数据汇总 683 实例506 利用AVG函数实现计算平均值 684 实例507 利用MIN函数求数据中的最小值 685 实例508 利用MAX函数求数据中的最大值 686 实例509 利用COUNT函数求销售额大于某值的 图书种类 688 实例510 查询编程词典6月的销售量 689 实例511 查询与张静同一天入司的员工信息 690 实例512 使用IN谓词查询某几个时间的数据 692 实例513 日期查询中避免千年虫问题 693 21.3 大小比较与逻辑应用 694 实例514 在查询结果中不显示重复记录 694 实例515 使用NOT查询不满足条件的记录 695 实例516 使用between进行区间查询 697 实例517 列销量中的重复记录和记录条数 698 实例518 使用关系运算符查询某一时间段数据 699 实例519 计算两个日期之间的月份数 700 实例520 格式化金额 702 实例521 在查询语句中过滤掉字符串中的空格 703 第22章 数据库操作 705 22.1 通过JDBC-ODBC桥连接数据库 706 实例522 通过JDBC-ODBC桥连接SQL Server 2000数据库 706 实例523 JDBC-ODBC桥连接Access数据库 708 实例524 JDBC-ODBC桥与Oracle数据库 建立连接 710 22.2 JDBC技术连接数据库 711 实例525 通过JDBC连接SQL Server 2000 数据库 711 实例526 JDBC连接MySQL数据库 713 实例527 JDBC连接SQL Server 2005数据库 714 实例528 JDBC技术连接Oracle数据库 715 实例529 JDBC连接JavaDB数据库 716 22.3 数据库与数据 717 实例530 列举SQL Server数据库下的数据 717 实例531 列举MySQL数据库下的数据 718 实例532 查看数据结构 719 实例533 动态维护投票数据库 721 实例534 SQL Server数据备份 722 实例535 SQL Server数据恢复 725 实例536 MySQL数据备份 728 实例537 MySQL数据恢复 730 实例538 动态附加数据库 731 实例539 生成SQL数据库脚本 733 实例540 获取SQL Server数据字段的描述信息 734 22.4 数据增加、更新与删除操作 736 实例541 将员工信息添加到数据 736 实例542 添加数据时使用数据验证 737 实例543 插入用户登录日志信息 739 实例544 生成有规律的编号 740 实例545 生成无规律的编号 742 实例546 在插入数据时过滤掉危险字符 743 实例547 将用户选择的爱好以字符串形式保存 到数据库 744 实例548 将数据从一张复制到另一张 745 实例549 使用UNION ALL语句批量插入数据 746 实例550 更新指定记录 747 实例551 在删除数据时给提示信息 748 实例552 将数据清空 749 实例553 字符串大小写转换 750 第23章 数据查询 752 23.1 使用子查询 753 实例554 将子查询作为达式 753 实例555 用子查询作为派生 754 实例556 通过子查询关联数据 755 实例557 使用IN谓词限定查询范围 756 实例558 使用NOT IN子查询实现差集运算 758 实例559 使用NOT IN子查询实现反向查询 759 实例560 返回笛卡尔乘积 760 实例561 比较运算符引入子查询 761 实例562 在子查询中使用聚集函数 762 实例563 在删除数据时使用子查询 763 23.2 嵌套查询 764 实例564 查询平均成绩在85分以上的学生信息 764 实例565 查询本科部门经理月收入情况 766 实例566 在嵌套中使用EXISTS关键字 767 实例567 动态指定查询条件 768 23.3 连接查询 769 实例568 使用UNION运算符使学生档案归档 769 实例569 内连接获取指定课程的教师信息 771 实例570 左外连接查询员工信息 772 实例571 右外连接查询员工信息 773 实例572 多外连接查询 774 实例573 完全连接查询 775 23.4 函数查询 777 实例574 在查询中使用patindex()函数进行 模糊查询 777 实例575 对查询结果进行格式化 778 实例576 在查询中使用字符串函数 780 实例577 在查询中使用ALL谓词 781 实例578 在查询中使用ANY谓词 782 实例579 使用UNION运算符消除重复的行 784 实例580 使用UNION ALL运算符保留重复的行 785 实例581 计算商品销售额所占的百分比 786 第24章 数据库高级应用 787 24.1 在Java程序中使用存储过程 788 实例582 调用存储过程实现用户身份验证 788 实例583 应用存储过程添加数据 789 实例584 调用加密存储过程 791 实例585 获取数据库中所有存储过程 792 实例586 修改存储过程 793 实例587 删除存储过程 795 24.2 使用触发器 796 实例588 应用触发器添加日志信息 796 实例589 在删除成绩时将学生中的数据删除 798 实例590 在程序中调用UPDATE触发器 799 实例591 获取数据库中的触发器名称 801 实例592 创建带有触发条件的触发器 802 24.3 使用批处理 803 实例593 使用批处理删除数据 803 实例594 使用批处理提升部门员工工资 805 实例595 将教师中的数据全部添加到选课 806 实例596 在批处理中使用事务 807 24.4 使用视图 809 实例597 创建视图 809 实例598 使用视图过滤不想要的数据 810 实例599 使用视图与计算数据 812 实例600 使用视图重新格式化检索来的数据 813 实例601 获取数据库中的全部用户视图 814 实例602 修改视图 815 实例603 删除视图 816
本文是由笔者2012年学习oracle数据库时编写的学习札记,其中的题目 多数为老师留下的思考题目。 我相信本文会对初学者使用oracle有一个初步的使用印象。右图为我所参 考的书籍。 目录 第一讲 Oacle关系数据库 9 一. Oracle的安装 9 二. 用浏览器进入em 企业管理器 11 三.启动DBCA的方法 11 四.服务设置 11 五. Oracle的卸载 11 六. Oracle数据库的应用系统结构 11 七. 补充资料——oracle安装时现的问题 12 第二讲 Oacle数据库体系结构 14 一. 物理存储结构——(数据库载体) 14 1.数据文件(.DBF) 14 2.日志文件 (.Log) 14 1) 日志文件 15 2) 数据库工作模式 15 3.控制文件(.ctl) 15 4.参数文件 (.ora) 16 二. 逻辑存储结构 17 1.数据块 (Data Blocks) 17 2.盘区(Extent) 18 3.段 (Segment) 18 4.空间(Table Spaces) P34 18 三. 内存结构 19 1.数据缓冲区: 内存的40% 19 2.日志缓冲区: 19 3.数据字典缓冲区: 19 4.共享池 内存的10% 19 5.大池 5-10M 20 6.JAVA池 不小于20M 20 7.Streams池 20 8.软件代码区: 20 9.程序全局区(PGA) 20 四. 实例的进程结构(实例=SGA + 后台进程) 20 1.DBWR (数据库写入进程) 21 2.LGWR(日志写入进程) 22 3.ARCH(归档进程)-可选进程 22 4.CKPT(检查点进程)-可选进程 22 5.SMON (系统监控进程) 22 6.PMON (进程监控进程) 22 7.RECO (恢复进程) 22 8. Dnnn (调度进程)-可选进程(略) 22 五. 数据字典 22 第三讲 用户、模式和 24 一. 用户和模式 24 1.模式 24 2.模式对象 24 3.用户 24 (1)创建用户 24 (2)授权 24 (3)删除用户及该模式下对象 26 二. 26 1. 数据类型 26 (1)字符型 26 (2)数值型 26 (3)日期时间型 26 (4)LOB (大型对象) 26 (5)RowID (伪列类型) 27 2. 创建 27 (1)Create Table 名 27 (2)在原来已有上建一个(结构和数据) 27 (3)使用OEM建 27 3.默认值和NULL值 27 三. 修改 28 四. 删除 28 五. 数据完整性 28 1.Primary Key 约束 28 2.NOT NULL约束 29 3.Unique 约束 29 4.Foreign Key 约束 29 5.Check约束 (最复杂)列级 | 级 29 第四讲 SQL基本查询 31 一. SQL语句概述 31 1. SQL简介 31 2. SQL分类 31 3. PL/SQL (Procedure Language) 31 二. SQL*Plus 31 1.启动 SQL*Plus 单行编辑 31 2.启动iSQL*Plus 多行编辑 31 3.退 32  直接关闭 32  输入:Exit 或 quit 32 三. 本书所使用的示例模式 32 1.Vendition:销售管理系统(11个)(略) 32 2. School:学生成绩管理系统(6个) 32 四. SQL SELECT语句 34 1.Select语句的格式 34 2.Select … From … ——选择列(投影) 35 3.Where子句——选择行(选择)数据过滤 35 4.Order By子句 35 5.统计函数——列名应指定别名 35 6. Group By分组 36 7.Having子句 36 8.练习:查询 36 五. 在SQL *Plus中使用函数 37 1.字符串函数 37 2.数字函数 37 3.日期时间函数 38 4.转换函数 38 第五讲 修改SQL数据与SQL*Plus命令 40 一.添加数据 40 1.Insert Into 名 [ 字段列 ] Values (值) 40 2.向中插入空值 40 3.从其它中拷贝数据 40 二. 更新数据 41 三. 删除数据 42 1.Delete 语句 42 2.Truncate 语句 42 四. SQL*Plus命令 42 1.设置环境变量命令 42 (1)Pause 43 (2)pagesize 和 newpage 43 (3)linesize 43 (4)numformat 选项 43 (5)timing 选项 44 2.格式化查询结果命令 44 (1)column : 44 (2)Ttitle 和 Btitle 命令 44 3.文件操作命令 45 (1)保存命令到文件 45 (2)检索命令文件到缓冲区 45 (3)运行命令文件 45 (4)保存查询结果到文件 46 4.交互命令:动态查询 46 (1)定义命令 46 (2)替换符 (用来临时存储有关的数据) 46 5.帮助命令 46 (1)help index 将显示SQL*Plus的所有命令 47 (2)help 命令名称 显示该命令的功能和选项 47 6.其他的SQL*Plus命令 47 (1)退 SQL> Exit | Quit; 47 (2)清除命令 47 (3)查看结构信息 47 (4)执行操作系统命令 47 第六讲 高级查询 50 一.简单连接 50 1.简单连接 50 2.别名 P136 50 3.各个之间的连接 50 二. 使用Join连接 50 1.内连接 50 (1)等值连接(有相同的,逐个匹配) 50 (2)不等连接 51 (3)自然连接 51 2.外连接 (左、右、完全) 51 3.交叉连接 52 三.集合操作 52 1.Union(并)——结果集相加 “Or” 52 2.Intersect(交) “And” 52 3. Minus(差) 52 四.子查询 53 1.使用的是中的列 53 (1) IN 53 (2)Exist 53 (3)Some、Any和All 53 五.查询练习 54 第七讲 PL/SQL编程基础 56 7.1 PL/SQL 程序结构 56 1.PL/SQL块结构 56 2.PL/SQL块的分类(按照特性划分) 56 7.2变量与常量 56 (一)PL/SQL标识符 (给变量命名) 56 (二)标量变量 56 1.PL/SQL标识符 56 2.变量声明(名称、类型、值) 57 3.常量声明 57 (三)为变量和常量赋值 57 1.赋值的位置 57 2.赋值方式 57 (四)作用域:可以访问该变量的程序部分 58 7.3 PL/SQL 块中的SQL 语句 58 7.4 使用%TYPE和%ROWTYPE类型的变量 58 1.%Type 59 2.%RowType 59 7.5 复合变量 60 1.记录类型(“行”) 60 2.记录类型(“” ) 60 (1)使用的原因: 60 (2)定义记录类型(联合数组) 60 7.6 条件判断语句 61 (一)If语句 61 (二)Case语句 62 7.7循环语句 63 1.“直到”循环 63 2.当型循环(While) 63 3.计数型循环(For) 63 7.8游标 64 (一)隐式游标 64 1.含义: 64 2.游标的属性:(获取游标的状态) 64 3.另一种隐式游标 64 (二)显示游标 64 1.声明 64 2.打开和关闭 65 3.检索数据 65 (三)游标For循环 65 (四)游标变量 (动态游标) 66 1.定义 66 2.声明游标变量 66 3.打开游标变量 66 (五) 使用游标更新数据库 66 7.9 异常处理 66 (一)预定义异常 66 (二)非预定义异常 67 1.声明异常名 67 2.将异常名与标准的Oracle错误号联系起来 67 3.在Exception中对异常做处理 67 (三) 用户自定义异常 68 3.处理异常 68 Exception 68 (四)异常传播 68 1.自定义异常的传播 68 2.声明中的异常 68 (五)使用SQLCODE和SQLERRM 68 第八讲 过程、函数和程序包 72 8.1存储过程(procedure) 72 1.创建 72 2.调用存储过程 72 3.修改(替换同名的存储过程) 73 4.参数 73 (1)In 参数:向过程传入一个值 73 (2)Out参数: 73 (3)In Out参数: 74 (4)默认值 74 5.局部变量和子过程 74 8.2函数(function) 75 1.创建 75 2.调用函数 75 8.3程序包(package) 76 1.规范 76 2.主体 76 3.私有成员 77 4.实例化 77 5.重载 77 6.管理程序包和执行权限 77 8.4依赖性 78 练习 78 第九讲 索 引 80 一.了解索引 80 1.B树索引(Balanced) 80 2.位图索引 80 3.反向索引 81 4.基于函数的索引 81 二. 创建索引 81 1.B树索引 81 2.位图索引 81 3.反向索引 81 4.基于函数的索引 81 三. 索引与约束 82 第十讲 视图、序列和同义词 83 一. 视图 83 1.先关概念 83 2.创建 83 3.修改视图 84 4.检索视图定义 84 5.视图的编译 84 6.视图的删除 84 二. 可更新的视图 84 三. 管理序列 84 1.创建 85 2.伪列 85 3.修改序列 85 4.查询序列 85 5.删除序列 85 四. 管理同义词 85 1.同义词 86 3.分类 86 4.创建 86 5.删除 86 第11讲 触发器 88 一. 触发器的组成 88 1.组成 88 2.事件 89 二.触发器的类型 89 1.DML触发器 89 (1)格式 90 (2)语句级触发器 90 (3)多条件触发的条件谓词 91 (4)行级触发器 92 2.替代触发器(instead of) 92 3.系统事件触发器 93 三.Alter Trigger语句 94 四.与触发器有关的数据字典 95 第12讲 安 全 98 一. 用户账号 98 1.用户配置文件(概要文件) 98 2.监视用户 98 二. 权限管理 99 (一)系统权限 99 (二) 对象权限 ---9种 100 三. 角色管理 101 1.系统预定义角色 101 2.自定义角色 101 3.启用和禁用角色 102 4.修改用户设置的角色 102 5.删除角色 102 四. 练习 102 五. 练习 103 六. 练习 104 七. 练习 105 第13讲 备份与恢复 106 一.数据库备份概述 106 1.备份和恢复 106 2.备份的类型 106 二. 数据库备份模式 106 三. 备份数据库 107 (一)物理备份 107 1.脱机备份 (无成本复制 copy paste) 107 2.联机备份 24*7模式 108 (二)逻辑备份 108 1.Export 导 108 2.Import 导入 109 四. 数据库手动恢复 109 1. 完全恢复 109
ExtAspNet v2.2.1 ExtAspNet是一组专业的Asp.net控件库,拥有原生的AJAX支持和丰富的UI效果, 目标是创建没有JavaScript,没有CSS,没有UpdatePanel,没有WebServices的Web应用程序。 支持的浏览器: IE 7.0+, Firefox 3.0+, Chrome 2.0+, Opera 9.5+, Safari 3.0+ 注:ExtAspNet基于一些开源的程序ExtJS, HtmlAgilityPack, Nii.JSON, YUICompressor。 示例: http://extasp.net/ 开源: http://extaspnet.codeplex.com/ 博客: http://sanshi.cnblogs.com/ 邮箱: sanshi.ustc@gmail.com 发布历史: +2010-03-28 v2.2.1 +为TabStrip的GetAddTabReference函数增加重载方法,以便指定Tab的图标(feedback:mmdcup)。 -修正此函数通过PageContext.RegisterStartupScript调用时不能正确显示Icon的BUG(feedback:zhaowenke)。 -修正basic/hello.aspx示例在单独浏览器打开后,不能弹对话框的BUG。 -隐藏示例首页最外层RegionPanel的边框ShowBorder="false"。 +集成Extjs最新版本v3.1.1。 -增加一个新的Theme - Access。 -修正了Firefox下Zoom In/Out时页面消失的BUG。 -删除Panel的EnableLightBackgroundColor属性,同时EnableBackgroundColor只支持Blue和Gray两种Theme。 +2010-01-31 v2.2.0 -使得Asp.net的控件ImageButton具有和Asp.net的Button控件类似的行为(Ajax提交)(feedback:261629698)。 +TabStrip增加GetAddTabReference和GetRemoveTabReference两个函数,用来向TabStrip控件动态增加删除Tab。 -增加示例tabstrip/tabstrip_addtab.aspx。 -重构了示例网站的架构,目前只有一层IFrame结构。 -为TabStrip增加EnableTabCloseMenu属性,是否启用右键菜单,可用来关闭当前Tab和所有其他Tab。 -为NumberBox增加DecimalPrecision属性,用来控制小数点后的位数(需要设置NoDecimal="false")(feedback:zqmars)。 -Window控件更新。 -关闭按钮默认直接关闭,不会弹确认对话框。 -GetConfirmFormModifiedHideReference的函数中的ConfirmFormModified简化为Confirm,所以此函数更名为GetConfirmHideReference。 -增加两个属性EnableConfirmOnClose(默认false),CloseAction(Hide, HideRefresh, HidePostBack)。 -修正EnableMaximize属性不能使Window最大化的BUG,修正了双击标题栏不能最大化的BUG。 -删除Button控件的SystemIcon属性,比如以前这样定义SystemIcon="Close",现在需要这样定义Icon="SystemClose"。 -WindowPosition默认居中,而不是黄金分割位置。 +Button, Window等控件弹位置属性的变化。 -Window的Target属性由字符串类型变为枚举类型,注意更新以前的代码:Target="_self" -> Target="Self", Target="_parent" -> Target="Parent"。 -MenuButton, LinkButton, Button, LinkButtonField的ConfirmTarget属性由字符串变为枚举类型,可以取三个枚举值Self, Parent, Top。 -Confirm.GetShowReference的最后一个参数target变为枚举类型。 -Alert.GetShowReference中的showInParent参数也变为Target枚举类型。 -MenuButton, LinkButton, Button, LinkButtonField增加ValidateTarget用来控制单验证失败时提示对话框的显示位置。 +2010-01-06 v2.1.9 -集成Extjs最新版本v3.1.0。 -修正灰色皮肤的CSS问题。 -修正Grid的列名中不能包含中文字符的BUG(feedback:davidwen)。 -为Web.config和PageManager增加属性AjaxTimeout(单位秒,默认30秒)。 -修正了在Grid的PageIndexChange事件中不能获取SelectedRowIndexArray属性的BUG(feedback:Violet)。 -Button控件将不再自动拥有display:inline属性,如果希望两个按钮在一行显示,请为第一个按钮设置CssStyle="float:left;"属性。 -修正了弹菜单的位置在Firefox下不正确的BUG(feedback:eroach)。 -为TriggerBox和TwinTriggerBox增加EnableEdit属性。 -使用Hidden来显示隐藏ExtAspNet控件,而不是使用Visible属性(Visible目前设置为只读属性)。 -使用Hidden控制Window控件的显示隐藏,Popup已经标记为Obsolete属性。 -Window的实例方法GetCloseReference等以及ActiveWindow的静态方法GetCloseReference等,其中的Close全部改为Hide。 -增加TabStrip中Tab控件可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。 -修正绑定到Tree的XMLDocument中Icon属性映射错误(feedback:nopnop9)。 -修正HtmlEditor不能编辑的BUG(feedback:TheBox)。 -修正IE下有时会现空白页面的情况(feedback:olivia919)。 +2009-12-06 v2.1.8 -修正了使用IFrame的Window关闭后不能再次打开的BUG(feedback:alexa99)。 -修正了IE下Grid中的一个JS问题(feedback:lqm4108)。 -修正Alert消息中引号未编码导致的JS错误(feedback:sun1299shine)。 +集成extjs3.0.3。 -修正弹对话框的宽度计算错误(会保持最小的状态)。 -增加新的皮肤Gray。 -为示例工程添加改变语言和皮肤的下拉列。 -为PageContext增加静态函数Refresh,在切换语言和皮肤时使用。 +2009-12-01 v2.1.7 -增加示例(iframe/parent_postback_run3.aspx),如何通过简单的Javascript代码回发父页面(feedback:eroach)。 -修正一些书写错误(feedback:bmck)。 -从Region控件中删除SplitColor属性,增加CollapseMode, EnableSplitTip, SplitTip, CollapsibleSplitTip属性(feedback:bmck)。 -BorderPanel更名为RegionPanel。 -DropDownList拥有MarkInvalid方法(feedback:sun1299shine)。 -增加中国的省市县三级联动示例(data/shengshixian.aspx)(feedback:Blues T)。 -修正了使用IFrameUrl的Tab在切换过程中会重复加载的问题,这是一个在v2.1.6引入的问题(feedback:eroach)。 -修正了启用AutoPostBack的Grid,其RowClick会覆盖LinkButtonField, HyperLinkField, CheckBoxField的点击事件(feedback:yymaoji)。 +2009-11-26 v2.1.6 +修正动态创建Grid列的BUG(feedback:gxpan)。 -增加示例(data/grid_dynamic_columns.aspx)。 -修正Form不能自适应浏览器大小的改变(feedback:kaywood)(WorkItem#6309)。 -增加重载方法Alert.Show(message, title, icon)(feedback:TheBox)(WorkItem#6353)。 -为容器控件(比如Panel,Region,Tab等)增加AJAX属性IFrameUrl(feedback:BluesT)。 -重新设计模拟树的下拉列的实现,避免选中某项后的闪烁。 +2009-11-21 v2.1.5 +Tree优化。 -修正Expanded项和Checked项的状态在回发改变后不能保持的BUG。 -GetNodeById更名为FindNode,保持和FindControl一致命名。 -删除CheckedNodeIDArray属性,增加GetCheckedNodes和GetCheckedNodeIDs函数。 -删除ExpandedNodeIDArray属性,增加GetExpandedNodes和GetExpandedNodeIDs函数。 -增加示例(data/tree_select_run.aspx),如何选中当前节点的所有子节点(feedback:wjl_wjl520)。 +TreeNode的属性NodeId被重命名为NodeID,这是ExtAspNet中的一个命名约定。 -同时更名的还有GridColumn的ColumnId->ColumnID,GetColumnId->GetColumnID。 -Grid1.Columns.FindColumnById函数被Grid1.FindColumn所替代。 -为TreeCheckEventArgs,TreeExpandEventArgs,TreeCommandEventArgs增加Node属性。 -为所有控件增加Focus(覆盖Control默认的Focus函数)和GetFocusReference函数。 -增加示例(other/custom_postback.aspx)(feedback:thebox)。 -如何自定义Javascript脚本和C#处理函数来响应键盘事件。 -为Tree增加AutoLeafIdentification属性。 -增加示例(tree_auto_leaf_identification.aspx)(feedback:wdrabbit)。 +2009-11-17 v2.1.4 -修正Window的关闭按钮提示信息一直是中文的BUG(feedback:thebox)。 -部分ExtAspNet控件的设计时支持(会在后续版本中逐步完善)。 -v0.2beta2版本中关于PersistChildren(true)的描述有误,这个是设计时属性,和运行时是否保持状态没有关系。 -修正CheckBox控件的CheckedChanged事件会被触发两次的BUG(Data PostBack->AutoPostBack, Event PostBack->EnablePostBack)。 -为TextBox,TextArea,DatePicker,NumberBox,TriggerBox等控件增加AutoPostBack属性(feedback:dk3214)。 +为单字段增加RequiredMessage,MaxLengthMessage,MinLengthMessage属性,用于指定验证失败时提示信息。 -为空则使用默认的提示信息,默认的提示信息支持多语言,建议一般情况下使用默认信息。 +为单字段增加MarkInvalid和GetMarkInvalidReference函数(feedback:sun1299shine)。 -增加示例:form/form_validate.aspx +2009-10-19 v2.1.3 +增加支持在AJAX时改变的控件属性列(/ajax.aspx)。 -ExtAspNet支持原生的AJAX,也就是说控件的属性改变在AJAX过程中会反映到页面中,但并不是所有的控件属性都支持AJAX改变。 -加载s.gif图片在本机进行,不会请求extjs.com远程资源(feedback:efrigate43,abaocoole)。 -在AJAX回发后确保Asp.net的按钮控件仍然具有AJAX的特性。 -更新/basic/login.aspx示例,使用验证图片(feedback:kedee)。 -为Grid增加AutoPostBack属性和RowClick事件,示例在/data/grid_autopostback.aspx(feedback:chenguizhu2006)。 -为所有的单字段增加AJAX属性ReadOnly(feedback:skydb)。 -Grid中TemplateField生成到页面中控件具有唯一ID,例如Grid1_ct5_Label2,Grid1_ct6_Label2(feedback:geruger)。 +2009-09-27 v2.1.2 -为Tree控件增加GetExpandAllNodesReference和GetCollapseAllNodesReference两个函数。 -修正RELEASE版本下多语言加载的BUG(feedback:yigehaoren)。 -增加pt_BR语言,由Ujvari提供。 +为所有Panel(包括Grid,Tree,Form等)增加枚举类型Icon,其中包含1700多个小图标。 -如果Panel具有IconUrl属性,则IconUrl优先于Icon。 -所有Icon的列在icon.aspx。 -为Button,MenuItem(MenuButton,MenuHyperLink),AccordionLink,TreeNode,Image(如果ImageUrl为空,则取Icon的值)增加Icon属性。 +2009-09-15 v2.1.1 -修正不能动态修改AccordionPane属性Items的BUG。 +为Button, MenuButton, LinkButton, LinkButtonField增加ConfirmTarget。 -如果需要在父页面弹确认对话框,需要设置ConfirmTarget="_parent"(类似Window控件的Target="_parent")。 +为ExtAspNet.Alert.Show增加点击确定的JavaScript回调函数。 -一个典型应用,在Window控件中打开新页面,如果传递的参数不正确,则首先提示参数不对然后关闭此弹窗口。 -ExtAspNet.Alert.Show("参数错误!", String.Empty, ExtAspNet.ActiveWindow.GetCloseReference()); +TreeNode的前面的多选框可以自动回发了。 -为TreeNode增加AutoPostBack属性,增加事件数据类TreeCheckEventArgs,为Tree增加事件NodeCheck。 -示例在:http://extasp.net/data/tree_run.aspx -Grid增加GetNoSelectionAlertInParentReference函数,用来示没有选中任何一项时在父页面弹对话框的JS代码。 -修正IE7下不能以下划线作为CSS中类名的前缀的BUG(feedback:Steve.Wei)。 -添加定时器控件Timer,用来定时发起AJAX请求。 +2009-09-06 v2.1.0 -Button的Pressed属性值能够正确的反映客户端的变化。 -优化Tree控件的AJAX实现。 +为页面的Form添加autocomplete="off"属性。 -参考http://www.cnblogs.com/sanshi/archive/2009/09/04/1560146.html#1635830 +添加对extjs3.0中所有语言的支持。 -ExtAspNet扩展的多语言包在js\languages\extaspnet目录下,目前只有en,zh_CN,zh_TW三种实现 -你可以向其中添加自己的语言版本,并执行js\languages下的pack.bat打包,最后编译工程。 +2009-09-01 v2.0.9 -为ExtAspNet.Alert添加两个静态方法ShowInParent和GetShowInParentReference,用于在父页面弹窗口。 +在aspx页面中必须显示的声明控件的集合属性(比如Tabs(TabStrip), Items(PanelBase), Nodes(TreeNode))。 -这将会影响所有的aspx页面,所以要特别关注。 -重命名AccordionPanel为AccordionPane (这也是在Asp.net AJAX中使用的名称). +所有的面板默认有两个集合属性(Toolbars和Items). -尽管TabStrip, From, Tree, Accordion继承了Items属性,但是你并不能对其设置(此时Items是只读的). -这将会影响所有的aspx页面,一定要将工具条(Toolbars)和Items区分开来。 -祝你生日快乐 - 小师妹妹。 +2009-08-29 v2.0.8 -ExtAspNet支持多语言(en,zh_CN,zh_TW),可以在Web.config中修改。 -将所有的示例转化为英语版本。 -修正Tree控件的一个BUG(定义Mappings属性时)。 +PageManager.Instance应该存在于HttpContext.Current,而不是一个全局变量。 -这个BUG导致Asp.net compatibility中的示例无法完成,现在已经修正。 +去除PageManager中方法AddAjaxAspnetControls,增加属性AjaxAspnetControls。 -这个属性和Button得ValidateForms属性类似,可以查看Asp.net compatibility中的示例。 +2009-08-25 v2.0.7 -为按钮增加DisableControlBeforePostBack属性 - 回发之前是否禁用按钮,防止重复提交 - 默认为true。 -Grid的Values属性访问限制由internal改为public,这就意味这可以自由改变Grid中每个单元格的值了。 -增加示例-如何将Grid控件导为Excel(data\grid_excel_run.aspx)(feedback:503684912)。 -如果TreeNode的属性Enabled="false",则此项变灰并且不会被选中(feedback:your568)。 -修正TreeNode的属性NavigateUrl不接受服务器端URL(以~/开头)的BUG。 -增加Accordion和Tree配合使用的示例(other\accordion_tree_run.aspx)。 -修正Panel图标不能显示的BUG(CSS中class名不能有$字符)。 +去除PageLayout控件,此控件可以使用BorderLayout和指定PageManager的AutoSizePanelID属性来代替。 -这样所有需要占据全屏的Panel(不管你是Accordion,Panel,ContentPanel,Form,GroupPanel,SimpleForm,Tree还是Grid,TabStrip)都可以通过这种方式全屏。 -简单方便,示例可以参考 default.aspx 或者 other\accordion_tree_run.aspx。 +2009-08-14 v2.0.6 -动态生成菜单实例(other\menu_dynamic_run.aspx和other\menu_dynamic2_run.aspx)(feedback:shguo)。 -优化AJAX的内部实现,每个页面保存的ViewState现在减少1/3左右(重要更新)。 -优化Tree节点的NodeId自动生成,减少ViewState占用。 +2009-08-09 v2.0 beta5 +ExtAspNet和Asp.net的提交按钮兼容问题(feedback:千帆)。 -在2009-03-03 v1.3.0曾经提到这个兼容问题,并有这样的规则,如果Asp.net的按钮AJAX提交,必须设置UseSubmitBehavior="false" --也就是说生成的input的type不能是"submit",而这个限制在有些情况下是不可原谅的。 --我们做了优化,现在要使一个Asp.net的按钮能够AJAX提交,你不需要做任何设置(PageManager的属性EnableAjax为true即可,这是默认属性)。 +PageManager的实例方法AddAjaxUpdateControl改名为AddAjaxAspnetControls,现在可以在Page_Load中设置需要在AJAX中需要更新的Asp.net控件了。 -在Page_Load中设置了哪些需要在AJAX中更新的Asp.net控件会在回发时保持状态,可以通过RemoveAjaxAspnetControls来去除不需要更新的控件。 -示例在aspnet\fckeditor_run.aspx和aspnet\aspnet_run.aspx。 -FCKEditor和上传控件兼容。示例在aspnet\fileupload_run.aspx。 -修正ToolbarText的文本在AJAX下更新的BUG。 -Button的Pressed属性在AJAX可更新(feedback:mgzhenhong)。 -更新所有示例。在IE7.0,IE8.0,Firefox3.5,Chrome2.0下测试通过。 +2009-08-02 v2.0 beta4 +和Asp.Net的Forms Authentication兼容[feedback:mgzhenhong]。 -采用和Asp.Net Ajax类似的处理方式,需要在配置文件Web.config增加一个httpModules。 -现在支持Response.Redirect,你可以选择Response.Redirect或者ExtAspNet.PageContext.Redirect重定向页面,两者效果一样。 -支持FormsAuthentication.RedirectFromLoginPage(accountID, false);这样的方法。 -Button增加Type属性(button,reset,submit)[feedback:mgzhenhong]。 -修正Alert.Show方法不能指定文本前图片的BUG[feedback:xmq&mgzhenhong]。 -修正IE下某些弹窗口的IFrame第一次不能加载的BUG。 -增加Menu和Accordion的示例。 -修正Window控件的IconUrl有时不显示(Target="_parent")的BUG[feedback:xmq&mgzhenhong]。 +2009-07-22 v2.0 beta3 -兼容FCKEditor。 -在IE8.0,Firefox3.5下测试通过。以后ExtAspNet将不会对IE6.0提供支持。 +2009-07-13 v2.0 beta2 -集成extjs最新版本v3.0。 +兼容IE6.0-7.0-8.0。 -这应该是Extjs3.0的一个BUG,在IE6.0-7.0下面设置Ext.QuickTips.init();会导致button的click事件无法响应(IE8下无此问题)。 -目前先禁用IE6.0-7.0的QuickTips。 -优化底层JavaScript。 +2009-07-05 v2.0 beta1 -更新extjs库到最新版本v3.0 RC2; 目前只有一个缺省皮肤(Theme)。 -使用YUI Compressor压缩JavaScript和CSS文件。 -Release版本每个页面只包含一个JavaScript文件(语言文件除外)和一个CSS文件。 -ExtAspNet自身的CSS会紧挨着页面标签引入,这样在<head>中自定义的样式可以覆盖ExtAspNet缺省样式。 +Alert对话框会遮挡所有的Window窗口。 -使用<em>一个</em>变通的方法解决,因为无法改变Ext.Message的默认z-index(9000)所以将box.window_default_group的zseed调整为6000。 -为所有按钮的左右增加5px的空白边距:.x-btn button { margin: 0 5px !important; }。 -因为下拉列<em>表</em>不可编辑,所以不能为空,如果不设置SelectedIndex或SelectedValue,则默认选中第一项。 -重新绑定模拟树的下拉列<em>表</em>后,选中项的前面有图片的HTML标签的BUG。 -更新自定义JavaScript组件Ext.ux.SimplePagingToolbar。 -更新示例工程。 +2009-03-25 v1.3.1 -Tree在AJAX回发展开节点时JS错误[feedback:xlli]。[fixed] -Window中的EnableIFrame==false,则点击关闭按钮时报JS错误。[fixed] -页面包含FileUpload控件,需要点击按钮回发并上传文件,则不能采用原生AJAX方式。(参见示例aspnet/fileupload.aspx)[fixed] -HtmlEditor显示隐藏工具栏按钮不起作用,HtmlEditor目前不支持Enabled和Readonly两个属性。[fixed] +2009-03-03 v1.3.0 -如果弹<em>出</em>的窗口(Ext-Window)含有ASP.NET控件FileUpload,则此弹<em>出</em>窗口在关闭时<em>出</em>现JS错误(http://extjs.com/forum/showthread.php?t=8129)[feedback:xlli]。[fixed] -如果页面中存在ASP.NET控件(TextBox),则第二次提交<em>表</em>单就会报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的问题)。[fixed] -页面上放置ExtAspNet-Button和ASP.NET-Button,则点击ExtAspNet-Button时激发的是ASP.NET-Button的事件,这个BUG和Extjs2.2.1中Ext.Ajax.serializeForm的实现有关。[fixed] -ExtAspNet内部包含HtmlAgilityPack和Nii.JSON两个开源的第三方类库。[added] +如果以前你听过不要在ExtAspNet工程中使用ASP.NET标准控件的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在ExtAspNet控件和ASP.NET标准控件和平共处了。[fixed] -如果<em>一个</em>ASP.NET按钮控件要使用ExtAspNet的原生AJAX,只需要设置属性 UseSubmitBehavior="false" 即可。 -如果要在一次ExtAspNet的原生AJAX回发时更新ASP.NET控件的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:aspnet/aspnet.aspx)。 +2009-02-27 v1.2 beta9 -网络连接<em>出</em>错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接<em>出</em>错,请刷新页面重试。”。[fixed] -自动测试功能会在以后版本中逐步完善。这个版本完成测试框架,采用Extjs中JS函数进行大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed] +系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed] -底层使用Javascript创建<em>一个</em>Window控件的代码由原来的2000字符减少为500个字符。 -PageContext静态类中的GetPageStateChangedFunction改名为GetConfirmFormModifiedReference,底层代码优化。<em>表</em>示“获取当前页面中<em>表</em>单修改的确认提示框的脚本”。 ---[updated]删除PageContext中的GetConfirmFormModifiedReference,使用CurrentActiveWindow中的GetConfirmFormModifiedCloseReference/GetConfirmFormModifiedCloseRefreshReference/GetConfirmFormModifiedClosePostBackReference三个方法代替。 -不会修改弹<em>出</em>页面的URL(Ext-Window中的IFrame),以前为了实现功能为每个弹<em>出</em>页面添加box_parent_client_id<em>查询</em><em>字符串</em> -去除PageManager的RegisterPageStateChangedScript属性,现在已经将这个功能实现为静态的JS方法。可以通过PageContext.GetFormModifiedConfirmReference获取此方法的客户端脚本。 ---注意:以前的项目需要在所有的ASPX页面中查找RegisterPageStateChangedScript属性,并删除,否则会运行错误! -A页面有Ext-Window控件弹<em>出</em>B页面,B页面有Ext-Window控件弹<em>出</em>C页面,B页面的Ext-Window控件设置Target='_parent',则弹<em>出</em>的Ext-Window(C页面)会覆盖整个A页面,这是正确的。 ---当时如果用户直接访问B页面,就会报JS错误,因为此时找不到B页面的父页面A了。现在的版本修正为如果找不到父页面,则就在当前页面弹<em>出</em>窗口,这样用户直接访问B页面也不会<em>出</em>错了。 -Window控件的GetIFramePageStateChangedFunction函数改名为GetConfirmFormModifiedCloseReference,<em>表</em>示“获取先确认IFrame的页面中<em>表</em>单改变,然后关闭弹<em>出</em>窗口的客户端脚本”。 ---为Window控件增加如下两个方法GetConfirmFormModifiedCloseRefreshReference和GetConfirmFormModifiedClosePostBackReference,<em>表</em>示“先确认<em>表</em>单改变,然后关闭弹<em>出</em>Ext-Window,再然后刷新父页面或回发父页面”。 ---Window控件的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirmFormModifiedCloseReference,也即是先判断<em>表</em>单是否更新,然后在关闭窗口。 ---现在可以很方便的为Window控件的关闭按钮添加关闭后刷新父页面或者关闭后回发父页面的行为。 -如果弹<em>出</em>窗口(Window控件)中IFrame的页面不能正常加载(网络暂时<em>出</em>错或页面抛<em>出</em>异常),则此时点击右上角的关闭按钮会报JS错误,因为此时页面尚未加载完毕。 ---此版本修正了这个BUG,即时页面不能加载完全,也能通过右上角的关闭按钮关闭弹<em>出</em>含IFrame的窗体。 -Window控件的IFrameName属性是自动生成的,只读属性。(因为有可能所有的Ext-Window最终都渲染到最外层的页面,为了保证这些IFrame的name不同,IFrameName使用的是GUID,内部处理)。 -CurrentActiveWindow改名为ActiveWindow。 -[特别注意]GetWriteBackValueReference(string controlClientIds, string value, params string[] values)函数现在的定义是GetWriteBackValueReference(params string[] values) ---所有调用GetWriteBackValueReference的地方,需要删除第<em>一个</em><em>参数</em>(一般是ActiveWindow.GetLoadStateReference())。 +2009-02-23 v1.2 beta8 -ContentPanel中内容不能自动扩展高度的BUG[feedback:huihuang]。[fixed] -DropDownList在Ajax回发时不能计算模拟树的数据[feedback:huihuang]。[fixed] -DropDownList在页面第一次加载时没有不可选择项,则回发时也不会有不可选择项的BUG。[fixed] -升级底层ExtJS类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏问题的修正)。[fixed] -页面加载过程中的时间信息保存在Javascript变量window.box.timeInfo中。[added] +增加部分自动测试支持(使用WatiN和NUnit),下个版本将会提供完整的自动测试支持。[fixed] +2008-10-28 v1.2 beta7 -DropDownList没有选中任何一项,回发时报错[feedback:huihuang]。[fixed] -Window显示位置不对,以及不能拖动的BUG[feedback:huihuang]。[fixed] +PageContext优化。[fixed] -去除RegisterExclusiveScript静态函数(这是没有原生ajax之前的产物),使用RegisterStartupScript替代。 -去除RegisterStartupScript的重载函数,只保留最简单的PageContext.RegisterStartupScript(string script)函数。 -Resirect增加重载函数Redirect(string url, string target),其中target可能的取值为_self,_parent,_top,分别<em>表</em>示在当前窗口,父窗口,顶级窗口重定向[feedback:jqpeng]。 -Image控件增加ImageWidth/ImageHeight/ImageCssStyle/ImageCssClass/ImageAlt属性[feedback:jqpeng]。[fixed] -发布包中增加<em>一个</em>Web.config.txt,这是<em>一个</em>空的Web.config文件,包含BOX基本的配置信息。[fixed] -ContentPanel的ShowHeader和ShowBorder属性默认也是true(注意更新以前的应用)。[fixed] -Row和Column布局时,修正IE下设置RowHeight="100%"时显示不正确的BUG。[fixed] -AccordionLink当鼠标移上和移开时,有背景色的变化效果[feedback:huihuang]。[fixed] +TabStrip的Tab控件的EnablePostBack属性会在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此Tab都会回发)。[fixed] -有这样<em>一个</em>效果,如果Tab1默认显示,Tab1的EnablePostBack=true,则页面加载完毕后会回发Tab1一次。 +2008-10-20 v1.2 beta6 +使用控件的站点必须建立虚拟目录,否则会报JS错误(即是脚本资源没有加载),却原来是HTTPCompress组件的问题。[fixed] -需要<em>替换</em>新的blowery.Web.HttpCompress.dll,解决方案见http://pohee.com/it/http-compression-in-aspnet-20/。 +DropDownList优化。[fixed] -去除EnableFirstItem/FirstItemText/FirstItemValue,这个并不能带来很大的好处,反而容易让开发人员困惑。 现在可以方便的在后台DropDownList1.Items.Insert(0, new ExtAspNet.ListItem("全部", "-1"));来达到同样的效果。 +如果某项(ListItem)的Value为空<em>字符串</em>,则通过SelectedIndex和SelectedValue不能选中[feedback:jqpeng]。 -和Asp.net中的保持一致,ListItem的Value值可以为空<em>字符串</em>。 也就是可以这样写DropDownList1.SelectedValue = ""; -ListItemCollection增加重载函数Add(string text, string value),这样方便后台添加列<em>表</em>项。 -处于布局内的容器控件(Layout!=LayoutType.Container),AutoHeight会自动设置为false(避免开发人员发生此类错误)。[fixed] -注意,控件的高度指的是整个控件的高度,包含BodyPadding(这和CSS中的height不同,CSS中的height是指内容的高度,除去padding/border-width/margin)。[fixed] +为所有控件属性增加在VS中的智能提示。[fixed] -需要将ExtAspNet.XML和ExtAspNet.dll放在一起,这样引用dll时xml会被拷贝到bin目录下,提供VS的智能提示。 +控件的属性如果是枚举类型,如果此属性可以不取值,则默认为None。[fixed] -TriggerIconType.Default -> TriggerIconType.None -SystemIconType.Empty -> SystemIconType.None -RegexPattern.USER_DEFINED -> RegexPattern.None -<em>表</em>单验证属性<em>名称</em>变化(ValueToCompare->CompareValue,ControlToCompare->CompareControl)。[fixed] +注意:<em>一个</em>属性可以拥有多个值的情况。[fixed] -属性和CSS相关则用空格分隔(比如ColumnWidths,BodyPadding)。 -其他的都是逗号分隔(比如ValidateForms,DataKeyNames,DataNavigateUrlFields)。 +AccordionLink实现为控件。[fixed] -可以方便的在子页面(iframe)中通过js切换父页面中选中的菜单项(Accordion->AccordionLink)(示例在other/accordion_links_run.aspx,other/accordion_links_run_iframe_htm)[feedback:jima]。 +确认:可以方便的动态添加控件,并且可以给控件添加服务器端事件(示例在form/form_dynamic_run.aspx)。[fixed] +2008-10-15 v1.2 beta5 -验证<em>表</em>单字段的ValueToCompare属性,为<em>字符串</em>时会<em>出</em>错的BUG。[fixed] +优化下拉列<em>表</em>。[fixed] -验证下拉列<em>表</em>时,应该取ListItem的Value属性进行验证,而不是Text属性。 -DropDownList的Items增加Insert方法(可方便的下拉列<em>表</em>选项添加“全部”)。 -DropDownList不支持EmptyText属性。 -ListItem启用EnableSelect和SimulateTreeLevel属性,这样就可以直接在前台(ASPX)中设置哪些项不可选择,以及创建模拟下拉树。 -DropDownList增加EnableSimulateTree属性(默认为false),如果设置了DataSimulateTreeLevelField,则自动将EnableSimulateTree设置为true。 +2008-09-27 v1.2 beta4 +EnableLargeHeader属性对所有容器的效果一样,Accordion的属性EnableLargeHeader只会改变Accordion的标题大小,而不会对AccordionPanel起作用(示例见other/accordion_run.aspx)。[fixed] -Accordion去除EnableHightlight属性,AccordionPanel增加EnableHightlight属性。 -影响以前使用Box的应用,需要将Accordion的属性去掉,然后为每个AccordionPanel增加EnableLargeHeader和EnableHightlight属性。 -AccordionPanel鼠标移上去的样式调整(现在没有下面的一条白线了)。[fixed] +AccordionPanel增加Links属性,可以绑定列<em>表</em>数据到AccordionPanel,呈现的是链接的列<em>表</em>(示例在other/accordion_links_run.aspx)。[fixed] -原来放置在AccordionPanel中的容器,比如ContentPanel需要在外层加上<Items>标签。 -适当增大AccordionPanel中链接的高度20px->22px,同时对链接的样式也做了微调。 -通过BodyPadding控制链接列<em>表</em>的边距。 -这样能大大减少ASPX中HTML代码和Javascript代码的书写,可以在后台动态添加链接,效果很赞,此需求由马季提<em>出</em>。 +2008-09-25 v1.2 beta3 +代码优化与设计时支持(尚需要不断完善,目前可以在ASPX页切换到“设计时”,方便属性的更改和事件处理函数的添加)。[fixed] -Panel/GroupPanel/ContentPanel/Tree/HiddenField/PageLoading -TabStrip/Toolbar -TabStrip去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed] -向Form中动态添加控件的BUG,现在form/form_dynamic_run.aspx示例已经能正确运行。[fixed] +大部分容器的子控件集合更正为Items(以前有些是Rows)。[fixed] -影响的控件包括Toolbar/Accordion/AccordionPanel/GroupPanel/Panel/SimpleForm/Window等。 -保留Form的Rows(FormRowCollection)属性和Grid的Rows属性(GridRowCollection)。 -保留TabStrip的Tabs(TabCollection)属性。 -保留PageLayout/BorderLayout的Regions(RegionCollection)属性。 -预祝今晚神七发射成功。 +2008-09-22 v1.2 beta2 +Grid选中项(SelectedRowIndexArray)在ajax回发过程中存在BUG [feedback:xmzhu]。[fixed] -<em>表</em>现为对Grid进行多次删除添加操作后,SelectedRowIndexArray选中项中会存在当前不存在的行序号,导致服务器端遍历选中项时数组越界。所有使用box控件的应用程序都受到此BUG的影响,需尽快更新到新版本。 +代码优化与设计时支持(示例中<em>表</em>单控件都已支持设计)。[fixed] -PageManager/SimpleForm/Button/HyperLink/Label/Image/LinkButton/TextBox -TriggerBox/TwinTriggerBox/Window/TextArea/HtmlEditor/DatePicker/NumberBox -CheckBox/RadioButton/RadioButtonList/DropDownList -Grid +2008-09-19 v1.2 beta1 -Image/LinkButton/HyperLink增加一些Ajax可更新属性。[fixed] +隐藏的方式由HideMode属性控制Visibility/Offsets/Display。[fixed] -修正Form/SimpleForm中隐藏<em>一个</em><em>表</em>单字段(Hidden=false)会占据页面空间的BUG。 -ToolbarText/ToolbarFill/ToolbarSeparator在ASPX中设置Hidden=true不起作用的BUG [feedback:jbzhang]。[fixed] -Button去除MarginRight属性(可以通过CssStyle="margin-right:5px;"达到相同的效果)[fixed] +2008-09-09 v1.1 +Toolbar去除IsPageMenu属性,在网报中可以用自定义样式实现,而不应该写在控件中。[fixed] -网报:CssClass="toolbar-pagemenu" CssStyle="border:0px;",同时定义样式:.toolbar-pagemenu{ background: rgb(208, 222, 240) url(../images/pagemenu_toolbar_background.gif) repeat-x left top;}。 -Region去除默认的Layout=Fit,如果希望Region使用Fit/Anchor/Column/Row等布局的话,需要手工指定。[fixed] -ToolbarSeparator/ToolbarFill在Ajax更新Hidden属性的BUG。[fixed] +布局整理。[fixed] -新增Column/Absolute/Row三种布局,加上以前的Container/Fit/Anchor/Accordion/Border/Form六种布局,总共有9中布局可供使用。 -其中一些控件默认使用一种布局:SimpleForm(Form)/Form(Form)/Panel-GroupPanel(Container)/Accordion(Accordion)/PageLayout(Border)/BorderLayout(Border)/TabStrip(Card),所有布局控件默认的布局是Container。 -经常用到的布局控件:SimpleForm/Form/Accordion/TabStrip/BorderLayout,经常用到的布局:Fit/Row/Anchor +2008-09-08 v1.1 beta7 -MenuButton/MenuHyperLink增加HideOnClick属性,如果<em>一个</em>菜单项的作用仅仅为了弹<em>出</em>下级菜单,点击没反应,则可以这样设置HideOnClick="false" CssStyle="cursor:default;" [feedback:huayu]。[fixed] -MenuButton/MenuHyperLink/MenuSeparator/MenuText增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed] +大部分的ExtAspNet控件增加Hidden属性(少数几个控件没有此属性:Menu),这样在Ajax时可以显示隐藏控件。[fixed] -注意Visible和Hidden的区别:Visible=false的属性不会渲染到客户端,Hidden=true的控件渲染到客户端但是隐藏。 -US的ExtAspNet改造强烈依赖于此属性,这个版本发布后可以继续。 -网报中唯一没有用到ExtAspNetAjax的地方就是显示隐藏<em>表</em>单字段,现在也可以使用Ajax了。 +2008-09-04 v1.1 beta6 -PageContext.Redirect支持普通页面转向和ExtAspNetAjax下页面转向。[fixed] +模拟树的下拉列<em>表</em>的BUG(会使一些可选项变成不可选项)[feedback:xmzhu]。[fixed] -因为if("0,2,9,11,".indexOf('1,')>=0){ok},这显然是不对的,此BUG涉及很多控件(Grid,DropDownList,TabStrip)。 -解决方法:testValue += '';if(domValue.split(',').indexOf(testValue) >= 0){ok}。 -DropDownList在Ajax时应该先更新数据再设置选定项 [feedback:xmzhu]。[fixed] -Button/MenuButton增加Ajax可更新属性OnClientClick [feedback:xmzhu]。[fixed] -Tree的Ajax支持(尚需优化)。[fixed] +2008-09-02 v1.1 beta5 -DropDownList如果第一次没有绑定值,应该绑定到[[]](二维数组),而不是[](一维数组)。[fixed] -模拟树的DropDownList,在Ajax重新绑定DataSource后,保持项是否可选状态是最新的(页面第一次加载时,即使没有数据也需要设置DataTextField/DataValueField/DataSimulateTreeLevelField/DataEnableSelectField等属性的值,否则Ajax回发时会<em>出</em>错)。[fixed] -UserControlConnector导致的Ajax错误,去除UpdatePanelConnector控件(以后不会用AspnetAjax,这个控件已经完成使命)。[fixed] -不要使用Asp.net的控件HiddenField,而是使用ExtAspNet的HiddenField,因为Asp.net的控件在Ajax不会被更新,所以会导致视图状态不一致的错误。[fixed] -网报Ajax整合基本完成(除了待审批->下一步[审核/归档/<em>出</em>纳]操作,由于需要显示隐藏<em>表</em>单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed] -IE下,RadioButtonList中项如果存在汉字,则会换行的BUG。[fixed] -增加两个Theme[Slate/Black](样式尚需完善)。[fixed] +2008-09-01 v1.1 beta4 -非当前Tab中如果有ContentPanel,则在页面上方会有空白(可以通过设置EnableDeferredRender=false解决,但会减慢页面的加载速度),现在已经解决这个问题。[fixed] -RadioButtonList去除EnableBackgroundColor/EnableLightBackgroundColor属性,背景色是透明的,也就是和父控件(SimpleForm/Form)的背景色一致。[fixed] -TwinTriggerBox的第<em>一个</em>Trigger图标不会先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed] -Web.config中增加配置项FormLabelWidth="80"(默认为80),同时PageManager增加FormLabelWidth属性用来控制页面上所有SimpleForm/Form的<em>表</em>单字段标题的宽度。[fixed] +完善Ajax。[fixed] -RadioButtonList增加Ajax可更新属性SelectedIndex(SelectedValue/SelectedItem)。 -DropDownList增加Ajax可更新属性Enable/SelectedIndex(SelectedValue/SelectedItem)/DataSource。 -Grid增加Ajax可更新属性Columns(也就是说Grid列在回发时隐藏显示了一些,也能正确的Ajax)。 -ToolbarText增加Ajax可更新属性Text。 +2008-08-31 v1.1 beta3 -TabStrip增加EnableDeferredRender属性(是否启用延迟加载Tab,默认启用)。[fixed] -重定向页面,使用系统的方法 PageContext.Redirect(string url),使用Response.Redirect方法会<em>出</em>错。[fixed] +安全的Ajax设计。[fixed] -这个版本Ajax和上个版本(v1.1beta1)在设计思路上有很大区别,同时在速度上会有进一步的提升。 -基本思想:安全的Ajax交互,明确Ajax回发时支持控件哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供控件级别的EnableAjax属性。 -整理支持Ajax的控件属性改变列<em>表</em>(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不会对UI起作用,同时是安全的,不会有js错误)。 -网报Ajax整合(目前只支持所有的列<em>表</em>页面)(v0.8.1)。[fixed] +2008-08-29 v1.1 beta1 +Window控件是否弹<em>出</em>的状态在回发时维持。[fixed] -控件设计的<em>一个</em>原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。 +完全抛弃Asp.NetAjax,ExtAspNet控件内置Ajax支持。[fixed] -这是<em>一个</em>值得骄傲的设计,可以明显提高页面回发的速度(相比普通的回发和Asp.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。 -不需要做任何配置,所有的回发都是Ajax(在Web.config和PageManager中有设置启用Ajax回发的属性-EnableAjax-默认为true)。 +在这种设计下,其实可以完全抛弃Javascript。 -比如简单的点击<em>一个</em>按钮弹<em>出</em>窗口,可以在Button的OnClick事件中设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。 -第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。 -推荐的做法是尽量用客户端实现,客户端实现复杂的直接用服务器端实现。 +目前ExtAspNetAjax的限制。 -只对ExtAspNet控件起作用,对Asp.net控件不起作用。 -对容器控件(有子控件的控件)不起作用,只对最底层的控件起作用。 -对改变控件的Visible属性会有错误。 -Window控件的属性改变只有少数几个起作用(Popup,IFrameUrl)。 -PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用页面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个页面都添加PageLoading控件。[fixed] -Grid中的回发事件(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执行,这样当前行被选中的状态在回发后会得到保持。[fixed] -Grid选中行的状态在第一次回发时不能保持的BUG。[fixed] +2008-08-26 v1.0 +已知问题:IE的ActiveX插件IE Developer Toolbar会对IFrame的加载造成0.5m左右的延迟。 -主要是父页面加载<em>一个</em>比较大的css文件(~100k),则每次打开iframe页面,onload事件的调用都会有500ms左右的延迟,在测试IE性能时要禁用此插件。 +优化弹<em>出</em>窗口中IFrame的显示速度。[fixed] -在当前页面弹<em>出</em>窗口需要~20ms,在父页面弹<em>出</em>窗口需要100~300ms。通过缓存弹<em>出</em>的窗口实例,从而第二次弹<em>出</em>窗口不再需要创建时间。 -PageLayout的Region增加SplitColor属性,默认的背景色是透明的。(在网报中需要设置SplitColor="#CADDF7",以便分隔符的颜色和Toolbar的颜色一致)[fixed] +PageManager增加属性Theme、Language、FormMessageTarget、FormOffsetRight等属性,这些属性可以在Web.config中设置(推荐方法),也可以为每个页面设置。[fixed] -<em>一个</em>典型的应用是为每个用户设置不同的皮肤(根据用户浏览器中Cookie设置的值)(示例在default.aspx)。 -TreeNode增加属性SingleClickExpand,<em>表</em>示点击可切换节点的折叠展开状态。[fixed] +TabStrip中非当前Tab会延迟渲染。[fixed] -这会明显加快页面的渲染速度,网报中<em>一个</em>典型的费用审批页面可以减少200ms的渲染时间。 -由于非当前Tab不会在页面加载时渲染,所以那些Tab中的节点在页面加载后也是不可见的,需要将相关的脚本移动到控件的render事件中。 -不能比较两个DataPicker大小的BUG。[fixed] -TabStrip延迟加载引起的BUG(非当前Tab中的ContentPanel会占据页面空间,已修正)。[fixed] -全新的ExtAspNet.Examples(基础知识/<em>表</em>单控件/数据绑定/容器布局/IFrame框架)。[fixed] +2008-08-19 v0.4 beta6 +PageManager增加两个属性(EnableInlineStyleJavascript/ApplyParentStyleJavascript),可以在IFrame页面中使用父页面的脚本和样式(示例在iframe/default.aspx和iframe/page3.aspx)。[fixed] -测试发现,IFrame页面的加载速度并没有明显加快,可以先不使用此属性。 -RadioButtonList放在在BorderLayout中显示不了的BUG [feedback:zgjiang2]。[fixed] +extjs的BUG,当页面中含有iframe时,Ext.onReady会被调用两次(IE6/IE7)(http://www.extjs.net/forum/showthread.php?t=43246)(示例在test.aspx)[fixed] -现在的解决方法是在初始化时:if(this.initialized){return;}this.initialized=true; +需要先回发页面再弹<em>出</em>IFrame窗口。[fixed] -在回发时设置窗口的Popup和IFrameUrl属性,因为这些属性是可以保持状态的,所以在关闭窗口时要注意设置Popup=false。 -另一种做法(推荐):PageContext.RegisterStartupScript(Window99.GetShowReference("./simpleform.aspx"));。 +2008-08-15 v0.4 beta5 -点击关闭窗口的按钮,在IE6下会有JS错误。[fixed] -增加BorderLayout控件,示例在iframe/borderlayout.aspx。[fixed] +Radiobuttonlist显示有重影(示例在radio.aspx)。[fixed] -全新的样式。 -去除Horizontal属性,增加ColumnNumber(可以设置渲染成几列)。 -GetValueReference取得的值不正确的BUG。 -动态向Form中添加FormRow,并动态的向FormRow中添加<em>表</em>单字段,以及如何取得<em>表</em>单字段的值。(示例在form_dynamic.aspx)[fixed] +IFrame弹<em>出</em>窗口关闭后回发父页面,则会多加载IFrame一次,再次打开窗口会重复加载IFrame2-3次[feedback:xmzhu]。[fixed] -这是<em>一个</em>重要的BUG,会严重影响页面的加载速度。原因是通过脚本改变的IFrameUrl会在回发时保持状态,从而回发父页面后Window中的IFrame被添加到页面,而这是不需要的。 -现在"是否弹<em>出</em>窗口、窗口标题、IFrameUrl"在客户端的改变,不会影响服务器端的属性,也即是不保持状态。此问题解决。(示例在button_iframe.aspx) +2008-08-13 v0.4 beta4 -点击关闭窗口的按钮,在IE下会有JS错误。[fixed] -Window的右上角关闭图标增加提示,优化事件响应。[fixed] -Window的代码重构。[fixed] +修正<em>一个</em>的内存泄漏。[fixed] -IE7下测试,打开iframe/default.aspx页面,iexplorer占内存68.368M。 -内存存在泄漏时,点击iframe/page3.aspx页面8次后iexplorer占118.792M内存。 -修正后,点击iframe/page3.aspx页面8次后iexplorer占76.492M内存。 -IE窗口最小化时,IE会自动进行垃圾回收。 +2008-08-12 v0.4 beta3 -底层的javascript框架Extjs升级为v2.2,Grid的渲染速度有很大提升。[fixed] -Grid的EnableDelayRender默认为true(如果没有设置Grid的高度或通过布局间接设置高度,则行不可见,可以通过AutoHeight="true"解决)。[fixed] +页面正在加载的提示尽早的显示<em>出</em>来。[fixed] -首先在执行js来完成页面渲染之前延迟5ms,以便浏览器把当前页面内容显示<em>出</em>来。 -加载js脚本的script标签放置在页面的最后,放置加载js而阻塞PageLoading的显示。 +2008-08-08 v0.4 beta2 -TabStrip延时加载<em>出</em>错。[fixed] -Window的IFrameUrl处理的BUG,比如Pages_ExtAspNet目录下的页面应该为./FE_ApplyEditor.aspx或~/Pages_ExtAspNet/FE_ApplyEditor.aspx。[fixed] -Window的WindowPosition="Center"并且Target="_parent",则会JS错误。[fixed] -实现网报首页下拉菜单和左侧菜单的导航功能。[fixed] -Window的创建在页面显示后进行,不计算在js渲染时间内。[fixed] -优化费用申请页面(尽量减少不必要的层次嵌套)。[fixed] -button_iframe.aspx默认会加载form.aspx页面(Window控件的BUG)。[fixed] -Window中的保存并关闭按钮和Asp.netAjax冲突。[fixed] -优化关闭Window的js脚本,减少写到页面的js大小。[fixed] -加快“保存并关闭”按钮关闭窗口的速度,使用PageContext.RegisterExclusiveScript(CurrentActiveWindow.GetClosePostBackReference());,示例在(simpleform.aspx)。[fixed] +2008-08-05 v0.4 beta1 -DropDownList去除Traditional属性,和传统的Asp.net控件一样不可编辑。[fixed] -DropDownList增加SelectedText属性(去除了模拟树时通过SelectedItem.Text的多余html字符)。[fixed] -为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed] -将生成的js对象的<em>名称</em>简单化,这样可以减少生成的js内容,加快页面加载速度(<em>一个</em>典型页面的js由原来的33.0k降低为21.4k)。[fixed] +弹<em>出</em>窗口中,点击按钮回发然后点击关闭按钮,<em>出</em>现js错误 [feedback:xmzhu]。[fixed] -因为在页面的Page_Load中,if (!IsPostBack){PageContext.RegisterPageStateChangedStartupScript();}通过这样方法向页面注册了一段脚本,但是这段脚本在回发时没有注册到页面,因为js调用此脚本时报错。 -一种解决方法是将向页面注册脚本的函数移动到if语句的外面,即每次都向页面注册此脚本。 -另一种办法就是在PageManager控件中增加RegisterPageStateChangedScript(向页面注册监视页面中<em>表</em>单内容改变的脚本)的属性(会在每次页面回发(包含ajax回发)时注册脚本)(示例在button_iframe.aspx/simpleform.aspx)。 +PageManager控件增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.aspx)。[fixed] -这个手工添加onReady函数能够在每次页面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去做的麻烦(已经在网报中遇到这种情况)。 -每个页面必须添加<em>一个</em>PageManager控件,否则会<em>出</em>错,同时去除DesignTimeStyle控件(作为PageManager的属性<em>出</em>现)。[fixed] -TextField等<em>表</em>单字段增加Readonly属性。[fixed] +全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和Asp.net Ajax保持兼容)。[fixed] -最大的好处是可以减少页面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下) +示例1,通过点击按钮弹<em>出</em>IFrame窗口,可直接关闭父页面,也可在关闭后刷新或回发父页面。(default.aspx/page2.aspx/simpleform.aspx) -虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要做的仅仅是为Window控件增加<em>一个</em>属性(Target="_parent"),就完成了两种框架的转换,是不是很酷。 -显然,控件本身封装了大量的代码,简单来看现在有三个页面(default.aspx(A)/page2.aspx(B)/simpleform.aspx(C)),其中A包含B页面,当你在B中打开包含有页面C的窗口时,窗口不是在B中打开,而是在A中打开,这样才能保证窗口覆盖整个页面,当你从C中返回需要回发页面B时,却发现取得的是A页面,因为我们窗口是在A页面中创建的。我会通过一篇文章来揭示这一过程,敬请期待。 -示例2,Grid中弹<em>出</em>窗口。(default.aspx/page3.aspx/simpleform.aspx) +示例3,TriggerBox弹<em>出</em>窗口。(default.aspx/triggerbox.aspx/simpleform.aspx) -在整个页面弹<em>出</em>窗口或者在当前页面弹<em>出</em>窗口,仅仅设置Window的Target属性即可。 -示例4,弹<em>出</em>窗口中的弹<em>出</em>窗口。 -对整个Examples更新测试。[fixed] +2008-07-31 v0.3 beta12 -IE下TabStrip在Ajax回发后不会去掉x-hide-display样式,导致Tab显示为空的BUG。[fixed] -对TabStrip/Panel/Window中的IFrame重新设计,如果设置IFrameUrl="#"或者"about:blank",则不渲染iframe到页面节点,同时第二次打开Window中的IFrame不会有残影<em>出</em>现。[fixed] -如果TabStrip的Tab不是激活Tab并且设置了IFrameUrl,则会延迟加载(示例在tabstrip_iframe.aspx)。[fixed] -Tree控件,点击<em>一个</em>节点自动回发,则当前点击的那个节点的选中状态不会保持的BUG [feedback:zgjiang2]。[fixed] +规范关闭窗口时提示用户保存已经修改的内容提示的调用方式(包含iframe中关闭按钮和window右上角关闭图标的调用方式)(示例在grid_iframe.aspx/simpleform.aspx)。[fixed] -内部实现上,点击“保存并关闭按钮”,可以将关闭窗口的脚本更早的执行(在simpleform.aspx,PageContext.RegisterStartupScript增加重载函数),而不是原来的先创建整个页面UI,再关闭窗口。 -参照Yslow的评分规则,将JS文件引用由head移动到body中。[fixed] -Firefox下,如果页面太长会<em>出</em>滚动条,原来在ViewPort样式中有body{overflow:hidden;}。[fixed] +IFrame内的页面宽度和高度会自动设置(是不是还在为1px/2px的白边而烦恼,现在不用了:-)(示例在iframe_autosize.aspx/simpleform.aspx/simpleform2.aspx)[fixed] -增加PageManager控件(需要指定AutoSizePanelID,即需要设置宽度和高度为整个页面的宽度和高度的Panel),HideScrollbar属性用于隐藏滚动条(IE/Firefox)。 +2008-07-24 v0.3 beta11 -web.config配置信息中MessageTarget改名为FormMessageTarget,增加FormOffsetRight配置项,用来定义全局<em>表</em>单字段距离右边界的宽度,同时每个<em>表</em>单字段都增加OffsetRight属性 [feedback:jima]。[fixed] -Window在回发时设置的Title不起作用的BUG。[fixed] -增加Image控件 [feedback:jima]。[fixed] -Tree控件,如果<em>一个</em>节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则会引起页面死循环回发 [feedback:zgjiang2]。[fixed] -Image增加ToolTipTitle/ToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.aspx)。[fixed] -去掉DropDownList控件的Text属性(强制性),可以通过设置SelectedValue来设置选中哪一项 [feedback:xmzhu]。[fixed] -过滤提示消息中的换行符(转换为<br/>),否则提示信息可能导致页面渲染错误 [feedback:dcding]。[fixed] +2008-07-23 v0.3 beta10 +完善Tree控件。[fixed] -如何将<em>数据库</em>中的数据绑定到Tree(示例在tree2_bind_database.aspx)。 -ajax加载树节点,放在UpdatePanel中才有ajax的效果(示例在tree2_ajax.aspx)。 -更改TreeNode的ID为NodeId,否则两个树中不能有相同ID的TreeNode,这是不合理的。 -Grid的GridColumn的ID改名成ColumnId,否则同<em>一个</em>页面放置两个Grid,它们的GridColumn的ID不能同名,这是不合理的。注意需要更新以前的代码![fixed] -Grid所有类型的列增加DataTooltipField/DataTooltipFormatString两个字段,以显示ToolTip(示例在grid.aspx)。[fixed] +2008-07-22 v0.3 beta9 +IE6下,左侧导航链接的选中样式,以及鼠标移上去和移开的样式不对。[fixed] -发现原来ie6不能正确解析li的高度,必须手工设置才行(style="height:20px;")。 +IE6/IE7下,模拟树的下拉列<em>表</em>如果文字长度太长,则显示的文字会换行,导致错位。[fixed] -虽然最后未能解决<div style="width: 60px; white-space: nowrap; overflow: hidden; border: solid 1px red;"><div style="width: 16px; height: 18px; float: left;">##</div>差旅交通费</div>在IE和Firefox下显示的不同效果。 -但是通过用<img src="##" />来代替<div style="background:url(##)" />,从而实现FF和IE下样式的统一。 -刚看到old9的解决方案:把“差旅交通费”改成“<span style="margin-right: -1000px;">差旅交通费</span>”,在IE下和FF下的都不换行,:-) -LinkButton增加OnClick事件 [feedback:huihuang]。[fixed] -Window通过设置IFrameUrl和Popup不起作用的BUG。[feedback:xmzhu]。[fixed] +增加树控件(Tree)(示例在tree2.aspx)。[fixed] -可以在回发时维持树的状态(选中行,折叠/展开,CheckBox)。 -可以通过Inline的方式添加树节点,也可以绑定到XmlDocument/XmlDataSource/SiteMap。 -点击树节点可以链接到页面,也可以引发PostBack事件,可以添加自定义脚本。 +2008-07-16 v0.3 beta8 +ContentPanel中放置ExtAspNet控件,则渲染时会<em>出</em>现各种问题,比如下拉列<em>表</em>显示样式<em>出</em>错,Grid没了滚动条等等。[fixed] -隐蔽性非常强,原来在ContentPanel中渲染ExtAspNet控件,如果容器的display='none',则会<em>出</em>现各种问题(主要是大小不对)。 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。 -现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局实现),只要超过Grid容器就会显示滚动条。 +IE6下,在应用Asp.NetAjax后,Form中字段的宽度渲染不正确。[fixed] -调试相当困难,如果你有过在IE下通过alert发现问题的经历,你就能明白。 -最后发现IE6下应用Asp.NetAjax后不仅Form中列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG: 在MasterPage的onReady函数中,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正页面中所有<em>表</em>单的宽度(box_fixFormWidthInIE6();): 示例在 Site.Master 页面。 +集成的AspNetAjax有<em>一个</em>很大的BUG,只要你在页面上进行过ajax操作,当改变窗口大小时你会惊讶的发现内容区域的内容全部为空了![fixed] -解决方法相当怪异,经过<em>一个</em>下午的不断尝试,终于用<em>一个</em>怪异的方法解决(box.{0}.setSize(box.{0}.getSize());box.{0}.doLayout();), 这样的代码让我想起刷新窗口时那个方法(window.location.href=window.location.href;),不管怎么说,我对能很好的解决这个重大的BUG很是欣喜。 +2008-07-14 v0.3 beta6 -增加FlashObject控件。[fixed] -PageLoading增加EnableFadeOut属性(默认false),可以启用淡<em>出</em>效果。[fixed] -Accordion选中样式微调。[fixed] -预加载Form<em>表</em>单<em>出</em>错时提示信息的背景图片。[fixed] +Grid增加EnableDelayRender属性(默认false),可以加快页面的渲染速度(<em>一个</em>典型的20个记录的页面,可提前0.7s-1s显示<em>出</em>来)。[fixed] -因为延迟加载数据不会改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置"EnableDelayRender=false"。 -改变Grid中静态的CheckBoxField图片。[fixed] -TabStrip增加TabIndexChanged事件,同时Tab增加EnablePostBack,可以在点击<em>一个</em>Tab时引起回发事件。这在延迟加载Tab的内容非常有用。(示例在tabstrip.aspx)[fixed] +2008-07-12 v0.3 beta5 -页面菜单Toolbar的分割符和背景不相融合。[fixed] -<em>表</em>单字段之间可以比较大小,比如NumberBox可以和Label比较大小,同时增加CompareType,来指定比较的类型(示例在form_compare.aspx)。[fixed] -如果是同种类型的<em>表</em>单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而<em>一个</em>NumberBox和TextBox比较大小需要指定CompareType。 +如果在编辑页面使用AspNetAjax,则不能在回发时关闭当前窗口[feedback:huihuang](示例在ajax_editor_main.aspx/ajax_editor.aspx)。[fixed] -这是由于ajax后执行的javascript中不能有return false语句。 +在文本框失去焦点时,执行一些Javascript脚本(示例在textbox_blur.aspx) [feedback:xmzhu]。[fixed] -在页面添加onReady函数(会被系统调用),然后用javascript监视文本框值的改变。 -弹<em>出</em>Window默认显示的错误页面,解决方法在当前目录添加<em>一个</em>空的html页面,然后把Window控件的IFrameUrl指向这个页面而不是"#"。[fixed] +弹<em>出</em>的窗口中的弹<em>出</em>窗口的如果内容发生变化,则点击右上角的关闭按钮时会有提示用户先保存的对话框,但是这个对话框的被第二个弹<em>出</em>窗口覆盖了 [feedback:xmzhu]。[fixed] -原来的调用方法太麻烦(见示例中alert\alert_1.aspx和alert\alert_2.aspx,总计 6 行代码),现在只需要 3 行代码就OK了。 -点击提交按钮后变成灰色不可再次点击(示例在button_click_gray.aspx)[feedback:jima]。[fixed] +增加Menu、MenuText、MenuSeparator、MenuButton、MenuHyperLink控件,用于按钮的下拉菜单(示例在button_menu.aspx)。[fixed] -增加SplitButton控件。[fixed] +2008-07-09 v0.3 beta4 -DataPicker默认的日期格式为(yyyy-MM-dd)。[fixed] +Form<em>表</em>单字段(TextBox,DropDownList...)之间可以比较大小 [feedback:huihuang]。[fixed] -增加ControlToCompare/ValueToCompare/CompareOperator/CompareMessage四个属性,示例在form_compare.aspx。 +TabStrip中放置IFrame会<em>出</em>现渲染错误 (示例在tabstrip_iframe.aspx)[feedback:jima]。[fixed] -特殊处理,拥有IFrame的Tab如果不是激活Tab,则不设置Url,只有在激活时才设置Url。 -RadioButtonList增加AutoPostBack属性(示例在radio.aspx) [feedback:xmzhu]。[fixed] -FormRow可以设置各列的宽度百分比 (示例在form_columnwidths.aspx)[feedback:jima]。[fixed] +<em>表</em>单字段Enable=false时显示颜色太浅 [feedback:jima]。[fixed] -覆盖缺省样式的.x-item-disabled,设置不透明。 +2008-07-08 v0.3 beta3 -Grid没有数据,向后翻页按钮可以点击的BUG [feedback:huihuang]。[fixed] +增加HiddenField控件。[fixed] -其实用TextBox也能模拟HiddenField的行为,只需要设置CssStyle="display:none;"即可。 +TriggerBox 如果 EnableTextBox = true,则不能将Text回发(这是html的限制)。[fixed] -最后的解决方案居然是设置 readonly=true,同时更改属性为 Readonly(示例在textbox2.aspx)。 -模拟树的下拉列<em>表</em>在失去焦点后显示的文字不对的BUG。[fixed] +控制下拉列<em>表</em>某些项不可以选择(示例在dropdownlist2.aspx)。[fixed] -增加 DataEnableSelectField 属性,不可选择的项变灰,并且鼠标经过时没有样式。 -LinkButton和Grid的LinkButtonField增加Enable属性(示例在hyperlink.aspx和grid.aspx)。[fixed] +2008-07-07 v0.3 beta2 +增加UpdatePanelConnector控件,支持在布局构建的页面使用Asp.net Ajax。[fixed] -使用UpdatePanelConnector有<em>一个</em>要求:ContentTemplate下只能有<em>一个</em>子节点,比如box:Panel。 -示例在ajax3.aspx/content_page4.aspx。 -示例content_page3.aspx中,点击“Ajax<em>查询</em>”按钮和关闭弹<em>出</em>的窗口(点击右上角的叉)都引发异步更新。 +2008-07-03 v0.3 beta1 +容器控件的AutoHeight/AutoWidth默认为false。[fixed] -使用GroupPanel的地方需要手工添加AutoHeight="true"属性。 +增加UserControlConnector,可以在其中放置用户控件(示例在page_usercontrol.aspx)。[fixed] -也可以在ContentPanel中放置用户控件,注意两者的区别。 +增加ContentPlaceHolderConnector,<em>替换</em>原来Region的ContentPlaceHolderId属性(示例在Site.master)。[fixed] +支持Asp.net ajax异步加载。[fixed] -有很大局限性,只能在ContentPanel中使用,示例在ajax1.aspx/content_ajax2.aspx中。 -对于使用布局构建的页面(比如content_page1.aspx)还不能使用Asp.net ajax,因为页面是整体渲染的,先放弃。 +2008-07-02 v0.2 beta12 +关闭前提示当前页面已经被修改(示例在content_page1.aspx/simpleform.aspx)[fixed] -支持Iframe内按钮和window右上角关闭按钮。 -删除CloseAction属性,可以在后台通过OnClientCloseButtonClick属性指定(为了和iframe中做法一致)。 +iframe中的alert/confirm要覆盖整个父页面,而不仅仅是iframe页面。[fixed] -在Firefox下还有问题。[fix pending] +排序时在标题栏显示排序箭头,可以排序的列标题光标为手形(示例在grid_sorting.aspx)。[fixed] -可以通过设置Grid1.CurrentSortColumnIndex = 0;来强制某列显示排序箭头。 -可以通过 Grid1.Columns[Grid1.CurrentSortColumnIndex].SortExpression 的方式取得当前Grid的排序<em>表</em>达式。 +HyperLinkField/WindowField的链接地址支持服务器端格式(即是~/alert.aspx)。[fixed] -TabStrip的Tab中如果放置ContentPanel,则内容渲染位置不正确。[fixed] -可以在ContentPanel中放置用户控件(示例在page_usercontrol.aspx)。[fixed] +2008-06-30 v0.2 beta11 -增加TwinTriggerBox控件(示例在twintriggerbox.aspx)。[fixed] -Grid的<em>数据库</em>分页需要增加属性IsDatabasePaging=true,以便普通分页和<em>数据库</em>分页,否则在添加删除记录时总记录数不会变化 [feedback:zgjiang2]。[fixed] -关闭Window时PostBack事件OnClose可以指定<em>参数</em>,来区分是哪些操作引发的PostBack事件 [feedback:zgjiang2](示例在window_postback.aspx)。[fixed] -如果<em>表</em>单验证不通过,则需要弹<em>出</em>对话框提示(第<em>一个</em>没通过验证的字段)(目前还不能切换到相应的tab)。[fixed] +页面中任意可输入<em>表</em>单字段发生变化,可提示先保存。(示例在content_page1.aspx/simpleform.aspx)[fixed] -目前还不支持Window右上角关闭按钮的提示保存功能。 -Master/Content的内容页中Grid的Sort事件不起作用的BUG [feedback:zgjiang2]。[fixed] -Grid中的LinkButtonField设置ConfirmText会<em>出</em>错 [feedback:huihuang]。[fixed] -增加静态类Confirm。[fixed] +2008-06-27 v0.2 beta10 +Grid完善。[fixed] -CheckBoxField在回发时不能保持状态的BUG (已经更新了grid_checkboxfield.aspx示例)。 -Grid中模拟树显示,GridColumn增加DataSimulateTreeLevelField属性(<em>一个</em>Grid只能有<em>一个</em>Column指定此属性),指定此列模拟树显示时的层次字段(0,1,2,...)(示例在grid_simulate_tree.aspx)。 -切换分页时清空选中的值 [feedback:jqpeng]。 -增加PreRowDataBound事件,可以在数据绑定之前设置某列的属性 [feedback:xmzhu] (示例在grid_prerowdatabound.aspx)。 -DropDownList模拟树的方式显示,增加DataSimulateTreeLevelField属性,使用方法和Grid的类似(示例在dropdownlist_simulate_tree.aspx)。 +2008-06-25 v0.2 beta9 +Window窗体中的Iframe只让内容区域滚动,而Toolbar不滚动的规则。(示例在content_page2.aspx/simpleform.aspx)[fixed] -在simpleform.aspx中:Panel[BodyPadding=5](Toolbar,Panel[Height=450 Layout=Fit](SimpleForm[AutoScroll=true])),则外面窗口的高度=450 + 5*2 + 26 + 32,其中26是Toolbar的高度,32是窗口的标题栏和下边框的高度。 +关闭Iframe的LoadMask,所以需要Iframe页面添加PageLoading控件,这样效果统一。[fixed] +Grid完善。 -去除EnableClientPaging和EnableClientSort属性,客户端排序和客户端分页在ASP.NET应用中会有很多问题(主要是状态保持的问题)。 +EnableServerSort改名AllowSorting。(示例在grid_sorting.aspx) -使用非常简单:设置AllowSorting=true,注册OnSort事件,在事件处理函数中重新绑定数据。 +增加AllowPaging属性。(示例在grid_paging.aspx) -使用非常简单:设置AllowPaging=true,PageSize=3,注册OnPageIndexChange事件,在事件处理函数中Grid1.PageIndex = e.NewPageIndex;OK。 +<em>数据库</em>分页支持。(示例在grid_database_paging.aspx) -使用也非常简单:设置AllowPaging=true,PageSize=3,在绑定时设置RecordCount为总的记录数,在OnPageIndexChange事件处理函数中Grid1.PageIn</a></div><div data-report-view="{"mod":"popu_645","index":"4","dest":"https://blog.csdn.net/luosai19910103/article/details/122990447","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~Rate-4-122990447-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1715086686466_68342\"}","spm":"1035.2023.3001.6557"}" class="list-item" data-v-ca2d15ac><div class="recommend-title" data-v-ca2d15ac><img src="" alt data-v-ca2d15ac> <a target="_blank" href="https://blog.csdn.net/luosai19910103/article/details/122990447" data-report-click="{"mod":"popu_645","index":"4","dest":"https://blog.csdn.net/luosai19910103/article/details/122990447","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~Rate-4-122990447-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1715086686466_68342\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~Rate-4-122990447-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~Rate-4-122990447-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default" class="title" data-v-ca2d15ac>mysql <em>字符串</em>转数组,并将对应的<em>名称</em>拼接存到某个字段上</a></div> <a target="_blank" href="https://blog.csdn.net/luosai19910103/article/details/122990447" data-report-click="{"mod":"popu_645","index":"4","dest":"https://blog.csdn.net/luosai19910103/article/details/122990447","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~Rate-4-122990447-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1715086686466_68342\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~Rate-4-122990447-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~Rate-4-122990447-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default" class="desc" data-v-ca2d15ac>一、背景 由于<em>名称</em>字段因为bug,导致缺失需要修复。而该字段可以由另外<em>一个</em>字段<em>查询</em><em>出</em>来多条进行拼接。现在需要处理所有此类的数据。 二、 处理 – 1获得所有以“某个符号“分割的<em>字符串</em>的个数 DELIMITER $$ CREATE FUNCTION `func_get_split_string_total`( f_string varchar(1000),f_delimiter varchar(5) ) RETURNS int(11) BEGIN -- Get the total number of giv</a></div><div data-report-view="{"mod":"popu_645","index":"5","dest":"https://blog.csdn.net/weixin_43914604/article/details/105171740","strategy":"2~default~OPENSEARCH~activity","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~activity-5-105171740-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1715086686466_68342\"}","spm":"1035.2023.3001.6557"}" class="list-item" data-v-ca2d15ac><div class="recommend-title" data-v-ca2d15ac><img src="" alt data-v-ca2d15ac> <a target="_blank" href="https://blog.csdn.net/weixin_43914604/article/details/105171740" data-report-click="{"mod":"popu_645","index":"5","dest":"https://blog.csdn.net/weixin_43914604/article/details/105171740","strategy":"2~default~OPENSEARCH~activity","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~activity-5-105171740-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1715086686466_68342\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~activity-5-105171740-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~activity-5-105171740-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default" class="title" data-v-ca2d15ac>3.4 《<em>数据库</em>系统概论》之数据<em>查询</em>---SELECT(单<em>表</em><em>查询</em>、连接<em>查询</em>、嵌套<em>查询</em>、集合<em>查询</em>、多<em>表</em><em>查询</em>)</a></div> <a target="_blank" href="https://blog.csdn.net/weixin_43914604/article/details/105171740" data-report-click="{"mod":"popu_645","index":"5","dest":"https://blog.csdn.net/weixin_43914604/article/details/105171740","strategy":"2~default~OPENSEARCH~activity","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~activity-5-105171740-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1715086686466_68342\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~activity-5-105171740-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~activity-5-105171740-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default" class="desc" data-v-ca2d15ac>文章目录0.前言1.思维导图2.Student/SC/Course<em>表</em>数据及结构3.SELECT语句的一般格式4.单<em>表</em><em>查询</em>(1)选择<em>表</em>中的若干列① <em>查询</em>指定列② <em>查询</em>全部列③ <em>查询</em>经过计算的值❶ 算术<em>表</em>达式❷ <em>字符串</em>常量及函数❸ 使用列别名改变<em>查询</em>结果的列标题(2)选择<em>表</em>中的若干元组(行)① 关键词DISTINCT去掉<em>表</em>中重复的行② <em>查询</em>满足条件的元组(行)❶ 比较大小❷ 确定范围❸ 确定集合❹ 字...</a></div></div></div></div> <div class="public_pc_right_footer2020" style="display:none;" data-v-4a5a7f56></div></div> <div id="right-floor-user-content_562" data-editor="{"type":"floor","pageId":143,"floorId":562}" class="user-right-floor right-box main-box detail-user-right" data-v-229a00b0><div class="__vuescroll" style="height:100%;width:100%;padding:0;position:relative;overflow:hidden;"><div class="__panel __hidebar" style="position:relative;box-sizing:border-box;height:100%;overflow-y:hidden;overflow-x:hidden;transform-origin:;transform:;"><div class="__view" style="position:relative;box-sizing:border-box;min-width:100%;min-height:100%;"><!----><div comp-data="[object Object]" baseInfo="[object Object]" community="[object Object]" class="introduce" data-v-4722a3ae><div class="introduce-title" data-v-4722a3ae><div class="img-info" data-v-4722a3ae><a href="https://bbs.csdn.net/forums/CSharp" class="community-img" data-v-4722a3ae><img src="https://img-community.csdnimg.cn/avatar/a7b2a15d77ba47b6968a126366232f4f.png?x-oss-process=image/resize,m_fixed,h_88,w_88" alt data-v-4722a3ae> <div title="C#" class="community-name" data-v-4722a3ae> C# </div></a></div></div> <div class="content" data-v-4722a3ae><div class="detail" data-v-4722a3ae><div title="110548" class="item" data-v-4722a3ae><p class="num" data-v-4722a3ae> 110,548 </p> <p class="desc" data-v-4722a3ae> 社区成员 </p></div> <div title="642562" class="item" data-v-4722a3ae><a href="https://bbs.csdn.net/forums/CSharp" target="_blank" data-v-4722a3ae><p class="num" data-v-4722a3ae> 642,562 </p> <p class="desc" data-v-4722a3ae> 社区内容 </p></a></div></div> <div class="detail-btns" data-v-4722a3ae><div class="community-ctrl-btns_wrapper" data-v-0ebf603c data-v-4722a3ae><div class="community-ctrl-btns" data-v-0ebf603c><div class="community-ctrl-btns_item" data-v-0ebf603c><div data-v-160be461 data-v-0ebf603c><div data-report-click="{"spm":"3001.5975"}" data-v-160be461><img src="https://csdnimg.cn/release/cmsfe/public/img/topic.427195d5.png" alt="" class="img sendTopic" data-v-160be461 data-v-0ebf603c> <span data-v-160be461 data-v-0ebf603c>发帖</span></div> <!----> <!----></div></div><div class="community-ctrl-btns_item" data-v-0ebf603c><div data-v-0ebf603c><img src="https://csdnimg.cn/release/cmsfe/public/img/me.40a70ab0.png" alt="" class="img me" data-v-0ebf603c> <span data-v-0ebf603c>与我相关</span></div></div><div class="community-ctrl-btns_item" data-v-0ebf603c><div data-v-0ebf603c><img src="https://csdnimg.cn/release/cmsfe/public/img/task.87b52881.png" alt="" class="img task" data-v-0ebf603c> <span data-v-0ebf603c>我的任务</span></div></div><div class="community-ctrl-btns_item" data-v-0ebf603c><div class="community-share" data-v-4ca34db9 data-v-0ebf603c><div class="handle-item share" data-v-ca030a68 data-v-4ca34db9><span height="384" data-v-ca030a68><div role="tooltip" id="el-popover-6265" aria-hidden="true" class="el-popover el-popper popo share-popover" style="width:265px;display:none;"><!----><div id="tool-QRcode" class="QRcode" data-v-ca030a68><img src="https://csdnimg.cn/release/cmsfe/public/img/shareBg2.05330abf.png" alt="" class="share-bg" data-v-ca030a68> <div class="share-bg-box" data-v-ca030a68><div class="share-content" data-v-ca030a68><img src="https://img-community.csdnimg.cn/avatar/a7b2a15d77ba47b6968a126366232f4f.png?x-oss-process=image/resize,m_fixed,h_88,w_88" alt="" class="share-avatar" data-v-ca030a68> <div class="share-tit" data-v-ca030a68>C#</div> <div class="share-dec" data-v-ca030a68>.NET技术 C#</div> <span class="copy-share-url" data-v-ca030a68>复制链接</span> <div class="shareText" data-v-ca030a68> </div></div> <div class="share-code" data-v-ca030a68><div class="qrcode" data-v-ca030a68></div> <div class="share-code-text" data-v-ca030a68>扫一扫</div></div></div></div> </div><span class="el-popover__reference-wrapper"><div data-v-0ebf603c><img src="https://csdnimg.cn/release/cmsfe/public/img/share-circle.3e0b7822.png" alt="" class="img share" data-v-0ebf603c> <span data-v-0ebf603c>分享</span></div></span></span></div> <!----></div></div></div> <!----> <div data-v-4fb59baf data-v-0ebf603c><div class="el-dialog__wrapper ccloud-pop-outer2" style="display:none;" data-v-4fb59baf><div role="dialog" aria-modal="true" aria-label="dialog" class="el-dialog el-dialog--center" style="margin-top:15vh;width:70%;"><div class="el-dialog__header"><span class="el-dialog__title"></span><!----></div><!----><div class="el-dialog__footer"><span class="dialog-footer clearfix" data-v-4fb59baf><div class="confirm-btm fr" data-v-4fb59baf>确定</div></span></div></div></div></div></div></div></div> <div style="display:none;" data-v-4722a3ae data-v-4722a3ae><!----> <div class="introduce-desc" data-v-4722a3ae><div class="introduce-desc-title" data-v-4722a3ae>社区描述</div> <span data-v-4722a3ae> .NET技术 C# </span></div></div> <div class="introduce-text" data-v-4722a3ae><div class="label-box" data-v-4722a3ae><!----> <!----> <!----></div></div> <!----> <div class="manage" data-v-4722a3ae><div class="manage-inner" data-v-4722a3ae><span data-v-4722a3ae>社区管理员</span> <ul data-v-4722a3ae><li data-v-4722a3ae><a href="https://blog.csdn.net/community_109" target="_blank" class="start-img" data-v-4722a3ae><img src="https://profile-avatar.csdnimg.cn/default.jpg!1" alt="C#" class="el-tooltip item" data-v-4722a3ae data-v-4722a3ae></a></li><li data-v-4722a3ae><a href="https://blog.csdn.net/sunhui" target="_blank" class="start-img" data-v-4722a3ae><img src="https://profile-avatar.csdnimg.cn/4da5553c0cca498aa6129165b431f71b_sunhui.jpg!1" alt="Web++" class="el-tooltip item" data-v-4722a3ae data-v-4722a3ae></a></li><li data-v-4722a3ae><a href="https://blog.csdn.net/diaodiaop" target="_blank" class="start-img" data-v-4722a3ae><img src="https://profile-avatar.csdnimg.cn/1bbdb34c745a495686ef96bd81e655c3_diaodiaop.jpg!1" alt="by_封爱" class="el-tooltip item" data-v-4722a3ae data-v-4722a3ae></a></li></ul></div></div> <div class="actions" data-v-4722a3ae><!----> <div style="flex:1;" data-v-4722a3ae><div class="join-btn" data-v-4722a3ae> 加入社区 </div></div> <!----> <!----></div> <div class="el-dialog__wrapper" style="display:none;" data-v-38c57799 data-v-4722a3ae><div role="dialog" aria-modal="true" aria-label="获取链接或二维码" class="el-dialog join-qrcode-dialog" style="margin-top:15vh;width:600px;"><div class="el-dialog__header"><span class="el-dialog__title">获取链接或二维码</span><button type="button" aria-label="Close" class="el-dialog__headerbtn"><i class="el-dialog__close el-icon el-icon-close"></i></button></div><!----><div class="el-dialog__footer"><span class="dialog-footer" data-v-38c57799></span></div></div></div> <div class="collapse-btn" data-v-4722a3ae><img src="" alt data-v-4722a3ae></div></div><!----><!----><div comp-data="[object Object]" baseInfo="[object Object]" typePage="detail" community="[object Object]" class="floor-user-right-rank" data-v-3d3affee><div class="el-tabs el-tabs--top" data-v-3d3affee><div class="el-tabs__header is-top"><div class="el-tabs__nav-wrap is-top"><div class="el-tabs__nav-scroll"><div role="tablist" class="el-tabs__nav is-top" style="transform:translateX(-0px);"><div class="el-tabs__active-bar is-top" style="width:0px;transform:translateX(0px);ms-transform:translateX(0px);webkit-transform:translateX(0px);"></div></div></div></div></div><div class="el-tabs__content"><div role="tabpanel" id="pane-integral" aria-labelledby="tab-integral" class="el-tab-pane" data-v-3d3affee></div><div role="tabpanel" aria-hidden="true" id="pane-3" aria-labelledby="tab-3" class="el-tab-pane" style="display:none;" data-v-3d3affee></div><div role="tabpanel" aria-hidden="true" id="pane-5" aria-labelledby="tab-5" class="el-tab-pane" style="display:none;" data-v-3d3affee></div><div role="tabpanel" aria-hidden="true" id="pane-6" aria-labelledby="tab-6" class="el-tab-pane" style="display:none;" data-v-3d3affee></div></div></div> <div class="floor-user-right-rank-score" data-v-608528ce data-v-3d3affee><div class="floor-user-right-rank-score-tabs" data-v-608528ce><ul data-v-608528ce><li data-v-608528ce> 近7日 </li><li data-v-608528ce> 近30日 </li><li class="active" data-v-608528ce> 至今 </li></ul></div> <div class="floor-user-right-rank-common" data-v-46cf600d data-v-608528ce><div class="rank-list" data-v-46cf600d><!----> <div class="no-data loading" data-v-46cf600d><i class="el-icon-loading" data-v-46cf600d></i> <p data-v-46cf600d>加载中</p></div> <!----> <a href="https:///CSharp/rank/list/total" target="_blank" class="show-more" data-v-46cf600d> 查看更多榜单 </a></div></div></div></div><div comp-data="[object Object]" baseInfo="[object Object]" typePage="detail" community="[object Object]" class="floor comunity-rule" data-v-3cfa4dbd><div class="title" data-v-3cfa4dbd> 社区公告 </div> <div class="contain" data-v-3cfa4dbd><div class="inner-content" data-v-3cfa4dbd><p>让您成为最强悍的C#开发者</p> </div></div></div><div comp-data="[object Object]" baseInfo="[object Object]" typePage="detail" community="[object Object]" class="user-right-adimg empty-arr" data-v-15c6aa4f><div class="adImgs" data-v-2a6389b9 data-v-15c6aa4f><!----> <div data-v-2a6389b9><div data-v-2a6389b9></div></div></div></div><div comp-data="[object Object]" baseInfo="[object Object]" community="[object Object]" class="content-right-recommend" data-v-0f781e88><div data-v-3798762e data-v-0f781e88><!----> <!----></div></div><div comp-data="[object Object]" baseInfo="[object Object]" typePage="detail" community="[object Object]" class="ai-entrance" data-v-eb1c454c><p data-v-eb1c454c>试试用AI创作助手写篇文章吧</p> <div class="entrance-btn-line" data-v-eb1c454c><a href="https://mp.csdn.net/edit?guide=1" target="_blank" data-report-click="{"spm":"3001.9712"}" data-report-query="spm=3001.9712" class="entrance-btn" data-v-eb1c454c>+ 用AI写文章</a></div></div></div></div></div></div></div></div></div></div></div></div></div> <div> <script type="text/javascript" src="https://g.csdnimg.cn/common/csdn-footer/csdn-footer.js" data-isfootertrack="false" defer></script> </div></div></div><script> window.__INITIAL_STATE__= {"csrf":"xkV9QeHE-fIWM7yMo0oPLQeRHer1Xd3uOIVE","origin":"http:\u002F\u002Fbbs.csdn.net","isMobile":false,"cookie":"uuid_tt_dd=10_3165213370-1715086686431-669313;","ip":"18.221.187.121","pageData":{"page":{"pageId":143,"title":"社区详情","keywords":"社区详情","description":"社区详情","ext":{"isMd":"true","armsfe1":"{pid:\"dyiaei5ihw@1a348e4d05c2c78\",appType:\"web\",imgUrl:\"https:\u002F\u002Farms-retcode.aliyuncs.com\u002Fr.png?\",sendResource:true,enableLinkTrace:true,behavior:true}","redPacketCfg":"{\"presetTitle\":[\"成就一亿技术人!\",\"大吉大利\",\"节日快乐\",\"Bug Free\",\"Hello World\",\"Be Greater Than Average!!\"],\"defaultTitle\":\"成就一亿技术人!\",\"preOpenSty\":{},\"redCardSty\":{}}","blogStar":"[{\"year\":\"2021\",\"enable\":true,\"communityIds\":[3859],\"url\":\"https:\u002F\u002Fbbs.csdn.net\u002Fsummary2021\"},{\"year\":\"2022\",\"enable\":true,\"communityIds\":[3860],\"url\":\"https:\u002F\u002Fbbs.csdn.net\u002Fsummary2022\"}]","mdVersion":"https:\u002F\u002Fcsdnimg.cn\u002Frelease\u002Fmarkdown-editor\u002F1.1.0\u002Fmarkdown-editor.js","componentSortCfg":"{ \"right\":[\"ratesInfo\",\"cty-profile\",\"pub-comp\",\"user-right-introduce\",\"post-event\",\"my-mission\",\"user-recommend\",\"user-right-rank\",\"user-right-rule\",\"user-right-adimg\"] }","show_1024":"{\"enable\":false,\"useWhitelist\":false,\"whitelist\":[76215],\"home\":\"https:\u002F\u002F1111.csdn.net\u002F\",\"logo\":\"https:\u002F\u002Fimg-home.csdnimg.cn\u002Fimages\u002F20221104102741.png\",\"hideLive\":true}","iframes":"[\"3859\"]","pageCfg":"{\"disableDownloadPDF\": false,\"hideSponsor\":false}"}},"template":{"templateId":71,"templateComponentName":"ccloud-detail","title":"ccloud-detail","floorList":[{"floorId":562,"floorComponentName":"floor-user-content","title":"社区详情页","description":"社区详情页","indexOrder":3,"componentList":[{"componentName":"baseInfo","componentDataId":"cloud-detail1","componentConfigData":{},"relationType":3},{"componentName":"user-right-introduce","componentDataId":"","componentConfigData":{},"relationType":2},{"componentName":"user-recommend","componentDataId":"","componentConfigData":{},"relationType":2},{"componentName":"user-right-rank","componentDataId":"","componentConfigData":{},"relationType":2},{"componentName":"user-right-rule","componentDataId":"","componentConfigData":{},"relationType":2},{"componentName":"user-right-adimg","componentDataId":"","componentConfigData":{},"relationType":2},{"componentName":"default2014LiveRoom","componentDataId":"20221024DefaultLiveRoom","componentConfigData":{},"relationType":3}]}]},"data":{"baseInfo":{"customDomain":"","uriName":"CSharp","communityHomePage":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FCSharp","owner":{"userName":"community_109","nickName":"C#","avatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","position":"","companyName":""},"user":{"userRole":3,"userName":null,"nickName":null,"avatarUrl":null,"rank":null,"follow":2,"communityBase":null,"joinCollege":null,"isVIP":null},"community":{"name":"C#","description":".NET技术 C#","avatarUrl":"https:\u002F\u002Fimg-community.csdnimg.cn\u002Favatar\u002Fa7b2a15d77ba47b6968a126366232f4f.png?x-oss-process=image\u002Fresize,m_fixed,h_88,w_88","qrCode":"","createTime":"2007-09-28","communityAvatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","communityNotice":null,"userCount":110548,"contentCount":642562,"followersCount":87166,"communityRule":"\u003Cp\u003E让您成为最强悍的C#开发者\u003C\u002Fp\u003E\n","communityId":227,"bgImage":"","hashId":"den17ynj","domain":"","uriName":"CSharp","externalDisplay":1,"adBanner":{"img":"","url":"","adType":0,"adCon":null},"rightBanner":{"img":"","url":"","adType":0,"adCon":null},"tagId":null,"tagName":null,"communityType":1,"communityApplyUrl":"https:\u002F\u002Fmarketing.csdn.net\u002Fquestions\u002FQ2106040308026533763","joinType":0,"visibleType":0,"collapse":0,"topicMoveAble":0,"allowActions":{},"communityOwner":"community_109","tagNameInfo":{"provinceTag":null,"areaTag":null,"technologyTags":null,"customTags":null}},"tabList":[{"tabId":1386,"tabName":"全部","tabUrl":"","tabSwitch":1,"tabType":4,"tabContribute":0,"cardType":0,"indexOrder":-1,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FCSharp?typeId=1386","iframe":false,"sortType":1},{"tabId":860,"tabName":"问答","tabUrl":"https:\u002F\u002Fask.csdn.net\u002Flist\u002F12\u002Ftag\u002F288","tabSwitch":1,"tabType":0,"tabContribute":0,"indexOrder":0,"iframe":true,"sortType":1},{"tabId":1184,"tabName":"C#综合技术","tabUrl":"","tabSwitch":1,"tabType":1,"tabContribute":1,"cardType":0,"indexOrder":1,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FCSharp?typeId=1184","iframe":false,"sortType":1},{"tabId":1183,"tabName":"C#互联网桌面应用","tabUrl":"","tabSwitch":1,"tabType":1,"tabContribute":1,"cardType":0,"indexOrder":2,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FCSharp?typeId=1183","iframe":false,"sortType":1},{"tabId":1185,"tabName":"AppLauncher","tabUrl":"","tabSwitch":1,"tabType":1,"tabContribute":1,"cardType":0,"indexOrder":3,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FCSharp?typeId=1185","iframe":false,"sortType":1},{"tabId":1180,"tabName":"WinForm&WPF","tabUrl":"","tabSwitch":1,"tabType":1,"tabContribute":1,"cardType":0,"indexOrder":4,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FCSharp?typeId=1180","iframe":false,"sortType":1},{"tabId":1181,"tabName":"C#开发新技术","tabUrl":"","tabSwitch":1,"tabType":1,"tabContribute":1,"cardType":0,"indexOrder":5,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FCSharp?typeId=1181","iframe":false,"sortType":1},{"tabId":4055669,"tabName":"博文收录","tabUrl":"","tabSwitch":1,"tabType":2,"tabContribute":0,"cardType":0,"indexOrder":19,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FCSharp?typeId=4055669","iframe":false,"sortType":1},{"tabId":1637785,"tabName":"Ada助手","tabUrl":"","tabSwitch":1,"tabType":2,"tabContribute":0,"cardType":0,"indexOrder":20,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FCSharp?typeId=1637785","iframe":false,"sortType":1}],"dataResource":{"mediaType":"c_cloud","subResourceType":"8_c_cloud_long_text","showType":"long_text","tabId":0,"communityName":"C#","communityHomePageUrl":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FCSharp","communityType":1,"content":{"id":"270013448","contentId":270013448,"cateId":0,"cateName":null,"url":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F270013448","shareUrl":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F270013448","createTime":"2008-09-18 02:59:26","updateTime":"2021-05-28 17:02:44","resourceUsername":"benbirdar","best":0,"top":0,"text":null,"publishDate":"2008-09-18","lastReplyDate":"2008-09-18","type":"13","nickname":"benbirdar","avatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F1da16d61ccac4860a9b0461eca25e31d_benbirdar.jpg!1","username":"benbirdar","commentCount":6,"diggNum":0,"digg":false,"viewCount":218,"hit":false,"resourceSource":6,"status":10,"taskStatus":null,"expired":false,"taskCate":0,"taskAward":0,"taskExpired":null,"checkRedPacket":null,"avgScore":0,"totalScore":0,"topicTitle":"请问,怎么将一个字符串内的所有参数,根据数据库表的同名称列名查询出的结果将它们替换?","insertFirst":false,"likeInfo":null,"description":"请问一下 我有这样一段打印的命令 JOB NM=cmdprint,ID=1234 {标签编号} PAPER PG=20,PW=1260,PH=600 {单据编号} ENV MK=2,DR=1,DK=10,SP=1,PS=207,PO=0,TO=0,CO=0, {数量} XO=0,YO=0,MD=1,CP=0 START RECT SX=138,SY=70,EX=887,EY=513,WD=2,TP=1 FONT TP=3,AT=2,DR=1, {11位的工令单号} WD=28,LG=28,SL=","coverImg":"https:\u002F\u002Fimg-home.csdnimg.cn\u002Fimages\u002F20221109054125.png","content":"请问一下\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n我有这样一段打印的命令\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\nJOB NM=cmdprint,ID=1234\u003Cbr \u002F\u003E\n{标签编号}\u003Cbr \u002F\u003E\nPAPER PG=20,PW=1260,PH=600\u003Cbr \u002F\u003E\n{单据编号}\u003Cbr \u002F\u003E\nENV MK=2,DR=1,DK=10,SP=1,PS=207,PO=0,TO=0,CO=0,\u003Cbr \u002F\u003E\n{数量}\u003Cbr \u002F\u003E\nXO=0,YO=0,MD=1,CP=0\u003Cbr \u002F\u003E\nSTART\u003Cbr \u002F\u003E\nRECT SX=138,SY=70,EX=887,EY=513,WD=2,TP=1\u003Cbr \u002F\u003E\nFONT TP=3,AT=2,DR=1,\u003Cbr \u002F\u003E\n{11位的工令单号}\u003Cbr \u002F\u003E\nWD=28,LG=28,SL=0\u003Cbr \u002F\u003E\nTEXT X=160,Y=119,L=1\u003Cbr \u002F\u003E\nTPOPart:{数量}\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n另外我有一张这样的表\u003Cbr \u002F\u003E\n\u003Cimg src=\"http:\u002F\u002Falbum.hi.csdn.net\u002FApp_Uploads\u002Fbenbirdar\u002F20080918\u002F145217512.jpg?d=20080918145247809\" alt=\"\" \u002F\u003E\u003Cbr \u002F\u003E\n \u003Cbr \u002F\u003E\n打印命令里的{XX}是打印的参数,\u003Cbr \u002F\u003E\n现在我要做的事情是,如果打印命令里的参数{XX}和这张表的字段ColumnDescription的某个值相同,如打印命令里是{数量},那么,就从这张表里查出ColumnDescription值为“数量”的对应字段TableName为 NN_WorkoutEntry 表里查询对应字段ColumnName 为FAmount的值,也就是\u003Cbr \u002F\u003E\nselect FAmount from NN_WorkoutEntry where ...\u003Cbr \u002F\u003E\n然后将这个查询出来的结果第一行第一列的FAmount 实际值替换打印命令参数里的{数量},,,,,\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n同理,如果打印命令里有出现{单据编号},那么根据这张表显示的,就应该执行命令select FBillNo from nn_workout where ...\u003Cbr \u002F\u003E\n然后将这个查询出来的结果第一行第一列的FAmount 实际值替换打印命令参数里的{单据编号},,,,,\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n\u003Cspan style=\"color:#0000FF;\"\u003E注:打印命令里的参数个数和参数是什么,都是不确定的。\u003C\u002Fspan\u003E\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n这个应该怎么实现呢???\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n请各位老大们帮忙啊!!!\u003Cbr \u002F\u003E\n","mdContent":null,"pictures":null,"videoInfo":null,"linkInfo":null,"student":{"isCertification":false,"org":"","bala":""},"employee":{"isCertification":false,"org":"","bala":""},"userCertification":[],"dependId":"0","dependSubType":null,"videoUrl":null,"favoriteCount":0,"favoriteStatus":false,"taskType":null,"defaultScore":null,"syncAsk":false,"videoPlayLength":null},"communityUser":null,"allowPost":false,"submitHistory":[{"user":{"registerurl":"https:\u002F\u002Fg.csdnimg.cn\u002Fstatic\u002Fuser-reg-year\u002F1x\u002F17.png","avatarurl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F1da16d61ccac4860a9b0461eca25e31d_benbirdar.jpg!1","nickname":"benbirdar","selfdesc":"","createdate":"2007-07-16 09:38:00","days":"6141","years":"17","username":"benbirdar","school":null,"company":null,"job":null},"userName":"benbirdar","event":"创建了帖子","body":"2008-09-18 02:59","editId":null}],"resourceExt":{}},"contentReply":{"pageNo":1,"pageSize":20,"totalPages":1,"totalCount":6,"total":0,"list":[{"hit":null,"hitMsg":null,"content":"\u003Cspan style=\"color:#FF0000;\"\u003E4 楼牛X!!!!!!\u003Cbr \u002F\u003E\n非常感谢!!!!!!!!!!\u003C\u002Fspan\u003E","topicTitle":null,"description":"4 楼牛X!!!!!! 非常感谢!!!!!!!!!!","id":240201379,"contentResourceId":270013448,"bindContentResourceId":0,"communityId":227,"username":"benbirdar","userNickName":"benbirdar","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F1da16d61ccac4860a9b0461eca25e31d_benbirdar.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":3662642964,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2008-09-18 05:12:13","updateTime":"2008-09-18 05:12:15","formatTime":"2008-09-18","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"学习ojlovecd!!","topicTitle":null,"description":"学习ojlovecd!!","id":240198422,"contentResourceId":270013448,"bindContentResourceId":0,"communityId":227,"username":"yagebu1983","userNickName":"yagebu1983","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fac29e0d50c6d45848662c496b8be0b3f_yagebu1983.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":1020529912,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2008-09-18 03:59:28","updateTime":"2008-09-18 03:59:29","formatTime":"2008-09-18","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"\u003Cpre\u003E\u003Ccode class=\"language-C#\"\u003E\u003Cbr \u002F\u003E\n string str = @"JOB NM=cmdprint,ID=1234\u003Cbr \u002F\u003E\n{标签编号}\u003Cbr \u002F\u003E\nPAPER PG=20,PW=1260,PH=600\u003Cbr \u002F\u003E\n{单据编号}\u003Cbr \u002F\u003E\nENV MK=2,DR=1,DK=10,SP=1,PS=207,PO=0,TO=0,CO=0,\u003Cbr \u002F\u003E\n{数量}\u003Cbr \u002F\u003E\nXO=0,YO=0,MD=1,CP=0\u003Cbr \u002F\u003E\nSTART\u003Cbr \u002F\u003E\nRECT SX=138,SY=70,EX=887,EY=513,WD=2,TP=1\u003Cbr \u002F\u003E\nFONT TP=3,AT=2,DR=1,\u003Cbr \u002F\u003E\n{11位的工令单号}\u003Cbr \u002F\u003E\nWD=28,LG=28,SL=0\u003Cbr \u002F\u003E\nTEXT X=160,Y=119,L=1\u003Cbr \u002F\u003E\nTPOPart:{数量} ";\u003Cbr \u002F\u003E\n Regex reg = new Regex("{(?<param>.*)}");\u003Cbr \u002F\u003E\n List<string> list = new List<string>();\u003Cbr \u002F\u003E\n Match m = reg.Match(str);\u003Cbr \u002F\u003E\n while (m.Success)\u003Cbr \u002F\u003E\n {\u003C!-- --\u003E\u003Cbr \u002F\u003E\n list.Add(m.Groups["param"].Value);\u003Cbr \u002F\u003E\n m = m.NextMatch();\u003Cbr \u002F\u003E\n }\u003Cbr \u002F\u003E\n using (SqlConnection conn = new SqlConnection("连接字符串"))\u003Cbr \u002F\u003E\n {\u003C!-- --\u003E\u003Cbr \u002F\u003E\n conn.Open();\u003Cbr \u002F\u003E\n foreach (string s in list)\u003Cbr \u002F\u003E\n {\u003C!-- --\u003E\u003Cbr \u002F\u003E\n string replacement = "", tableName = "", columnName = "";\u003Cbr \u002F\u003E\n using (SqlCommand cmd = new SqlCommand("select * from yourtable where ColumnDescription='" + s + "'", conn))\u003Cbr \u002F\u003E\n {\u003C!-- --\u003E\u003Cbr \u002F\u003E\n using (SqlDataReader dr = cmd.ExecuteReader())\u003Cbr \u002F\u003E\n {\u003C!-- --\u003E\u003Cbr \u002F\u003E\n if (dr.Read())\u003Cbr \u002F\u003E\n {\u003C!-- --\u003E\u003Cbr \u002F\u003E\n tableName = dr["TableName"].ToString();\u003Cbr \u002F\u003E\n columnName = dr["ColumnName"].ToString();\u003Cbr \u002F\u003E\n }\u003Cbr \u002F\u003E\n }\u003Cbr \u002F\u003E\n }\u003Cbr \u002F\u003E\n using (SqlCommand cmd = new SqlCommand("select " + columnName + " from " + tableName, conn))\u003Cbr \u002F\u003E\n {\u003C!-- --\u003E\u003Cbr \u002F\u003E\n replacement = cmd.ExecuteScalar().ToString();\u003Cbr \u002F\u003E\n }\u003Cbr \u002F\u003E\n str.Replace(s, replacement);\u003Cbr \u002F\u003E\n }\u003Cbr \u002F\u003E\n }\u003Cbr \u002F\u003E\n\u003C\u002Fcode\u003E\u003C\u002Fpre\u003E","topicTitle":null,"description":" string str = @\"JOB NM=cmdprint,ID=1234 {标签编号} PAPER PG=20,PW=1260,PH=600 {单据编号} ENV MK=2,DR=1,DK=10,SP=1,PS=207,PO=0,TO=0,CO=0, {数量} XO=0,YO=0,MD=1,CP=0 START RECT SX=138,SY=70,EX=887,EY=513,WD=2,TP=1 FONT TP=3,AT=2,DR=1, {11位的工令单号} WD=28,LG=28,SL=0","id":240197709,"contentResourceId":270013448,"bindContentResourceId":0,"communityId":227,"username":"ojlovecd","userNickName":"我姓区不姓区","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F4a6f532530af4fd199fc4a5b2c5d87d1_ojlovecd.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":3412352281,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2008-09-18 03:40:23","updateTime":"2008-09-18 03:40:24","formatTime":"2008-09-18","userRoleHonorary":{"userName":"ojlovecd","roleId":232,"roleType":0,"roleStatus":1,"honoraryId":0,"roleName":"","honoraryName":null,"communityNickname":"","communitySignature":""},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"比如:\u003Cbr \u002F\u003E\ndataset ds=new dataset()\u003Cbr \u002F\u003E\nstring sql1="select TableName,ColumnName from 表 where ColumnDes='"++"'"\u003Cbr \u002F\u003E\nSqlDataAdapter adp=new SqlDataAdapter(sql1,conn)\u003Cbr \u002F\u003E\nadp.fill(ds)\u003Cbr \u002F\u003E\nstring tablename=ds.table[0].rows[0][0].tostring()\u003Cbr \u002F\u003E\nstring columnname=ds.table[0].rows[0][1].tostring()\u003Cbr \u002F\u003E\nstring sql2="select "+columnname+" from "+tablename+""\u003Cbr \u002F\u003E\n执行sql2","topicTitle":null,"description":"比如: dataset ds=new dataset() string sql1=\"select TableName,ColumnName from 表 where ColumnDes='\"++\"'\" SqlDataAdapter adp=new SqlDataAdapter(sql1,conn) adp.fill(ds) string tablename=ds.table[0].rows[0][0].tostring() string columnname=ds.table[0].rows[0","id":240196888,"contentResourceId":270013448,"bindContentResourceId":0,"communityId":227,"username":"fht123","userNickName":"fht123","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":1947841254,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2008-09-18 03:18:58","updateTime":"2008-09-18 03:18:59","formatTime":"2008-09-18","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"打印参数作为查询条件,查出对应的记录,把该记录的表名和列名再作为参数取相应的数据.","topicTitle":null,"description":"打印参数作为查询条件,查出对应的记录,把该记录的表名和列名再作为参数取相应的数据.","id":240196564,"contentResourceId":270013448,"bindContentResourceId":0,"communityId":227,"username":"fht123","userNickName":"fht123","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":1947841254,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2008-09-18 03:11:26","updateTime":"2008-09-18 03:11:27","formatTime":"2008-09-18","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"我的数据库内有很多张表,要从哪张表内查询什么字段,就是根据这张表来做的\u003Cbr \u002F\u003E\n\u003Cimg src=\"http:\u002F\u002Falbum.hi.csdn.net\u002FApp_Uploads\u002Fbenbirdar\u002F20080918\u002F145217512.jpg?d=20080918145247809\" alt=\"\" \u002F\u003E\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n我的问题是,我怎么知道我的打印命令中有哪些参数是在这张表内的ColumnDescription存在的,\u003Cbr \u002F\u003E\n我怎么根据打印命令里有什么参数去查这张表的ColumnDescription字段?\u003Cbr \u002F\u003E\n只要能将打印命令里的参数{XXX}和ColumnDescription字段对应上,那剩下的我就能做了??\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n请问各位老大,应该怎么做》?\u003Cbr \u002F\u003E\n\u003Cspan style=\"color:#FF0000;\"\u003E我要的最后结果就是将打印命令内的所有{参数}都替换为数据库中表的相应字段的实际值!!!!\u003C\u002Fspan\u003E","topicTitle":null,"description":"我的数据库内有很多张表,要从哪张表内查询什么字段,就是根据这张表来做的 我的问题是,我怎么知道我的打印命令中有哪些参数是在这张表内的ColumnDescription存在的, 我怎么根据打印命令里有什么参数去查这张表的ColumnDescription字段? 只要能将打印命令里的参数{XXX}和ColumnDescription字段对应上,那剩下的我就能做了?? 请问各位老大,应该怎么做》? 我要的最后结果就是将打印命令内的所有{参数}都替换为数据库中表的相应字段的实际值!!!!","id":240196374,"contentResourceId":270013448,"bindContentResourceId":0,"communityId":227,"username":"benbirdar","userNickName":"benbirdar","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F1da16d61ccac4860a9b0461eca25e31d_benbirdar.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":3662642964,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2008-09-18 03:06:18","updateTime":"2008-09-18 03:06:20","formatTime":"2008-09-18","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null}],"maxPageSize":3000},"defaultActiveTab":1386,"recommends":[{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fpczlang\u002F9546866","title":"Java开发实战1200例(第1卷).(清华\u003Cem\u003E出\u003C\u002Fem\u003E版.李钟尉.陈丹丹).part3","desc":"书名:《Java开发实战1200例(第I卷)》(清华大学\u003Cem\u003E出\u003C\u002Fem\u003E版社.李钟尉,陈丹丹)\nPDF格式扫描版,全书分为24章,共817页。2011年1月\u003Cem\u003E出\u003C\u002Fem\u003E版。\n全书压缩打包成4部分,这是第3部分\n\n注:本系列图书的第I、II卷再版时均相应改名为《xxx开发实例大全》(基础卷)及(提高卷),但内容基本无变化,需要的童鞋可自由匹配查找。\n\n内容简介\n  《Java开发实战1200例》分为I、II两卷共计1200个例子,包括了开发中各个方面最常用的实例,是目前市场上实例最全面的开发类图书;书中实例来源于多位工程师的多年积累,具有很强的实用性。\n 本书是第II卷,以开发人员在项目开发中经常遇到的问题和必须掌握的技术为中心,介绍了应用Java进行桌面程序开发各个方面的知识和技巧,主要包括Java语法与面向对象技术、Java高级应用、窗体与控件应用、文件操作典型应用和\u003Cem\u003E数据库\u003C\u002Fem\u003E应用。全书分5篇24章,共计603个实例和603个经验技巧。每个实例都是经过笔者精心筛选的,具有很强的实用性,其中一些实例是开发人员难于寻觅的解决方案。 本书两卷共计1200个例子,包括了开发中各个方面最常用的实例,是目前市场上实例最全面的开发类图书;本书实例来源于多位工程师的多年积累,具有很强的实用性。\n  本书非常适合Java的初学者,如高校学生、求职人员作为练习、速查、学习使用,也适合Java程序员参考、查阅。\n\n目 录\n\n第1篇 Java语法与面向对象技术\n第1章 开发环境的应用 2\n1.1 Java环境 3\n实例001 下载JDK开发工具包 3\n实例002 把JDK工具包安装到指定磁盘 4\n实例003 设置JDK的环境变量 6\n实例004 验证Java开发环境 7\n实例005 下载并安装JRE执行环境 8\n实例006 编程输\u003Cem\u003E出\u003C\u002Fem\u003E星号组成的等腰三角形 9\n1.2 开发工具 11\n实例007 下载最新的Eclipse 11\n实例008 为最新的Eclipse安装中文语言包 12\n实例009 活用Eclipse的工作空间 14\n实例010 在Eclipse项目中编程输\u003Cem\u003E出\u003C\u002Fem\u003E字符\u003Cem\u003E表\u003C\u002Fem\u003E情 15\n实例011 为Eclipse添加新的JDK环境 17\n实例012 设置Eclipse中文API提示信息 18\n实例013 为项目添加类库 20\n实例014 使当前项目依赖另\u003Cem\u003E一个\u003C\u002Fem\u003E项目 21\n1.3 界面设计器 22\n实例015 安装界面设计器 22\n实例016 设计Windows系统的运行对话框\n界面 23\n实例017 设计计算器程序界面 26\n实例018 设计关于进销存管理系统的界面 27\n第2章 Java基础应用 29\n2.1 基本语法 30\n实例019 输\u003Cem\u003E出\u003C\u002Fem\u003E错误信息与调试信息 30\n实例020 从控制台接收输入字符 31\n实例021 重定向输\u003Cem\u003E出\u003C\u002Fem\u003E流实现程序日志 31\n实例022 自动类型转换与强制类型转换 33\n2.2 运算符 34\n实例023 加密可以这样简单(位运算) 34\n实例024 用三元运算符判断奇数和偶数 35\n实例025 更精确地使用浮点数 35\n实例026 不用乘法运算符实现2×16 37\n实例027 实现两个变量的互换(不借助\n第3个变量) 37\n2.3 条件语句 38\n实例028 判断某一年是否为闰年 38\n实例029 验证登录信息的合法性 39\n实例030 为新员工分配部门 40\n实例031 用Switch语句根据消费金额计算折扣 41\n实例032 判断用户输入月份的季节 42\n2.4 循环控制 43\n实例033 使用while与自增运算符循环遍历\n数组 43\n实例034 使用for循环输\u003Cem\u003E出\u003C\u002Fem\u003E杨辉三角 43\n实例035 使用嵌套循环在控制台上输\u003Cem\u003E出\u003C\u002Fem\u003E\n九九乘法\u003Cem\u003E表\u003C\u002Fem\u003E 44\n实例036 用while循环计算1+1\u002F2!+1\u002F3!…1\u002F20! 45\n实例037 for循环输\u003Cem\u003E出\u003C\u002Fem\u003E空心的菱形 46\n实例038 foreach循环优于for循环 47\n实例039 终止循环体 48\n实例040 循环体的过滤器 49\n实例041 循环的极限 50\n第3章 数组与集合的应用 51\n3.1 数组演练 52\n实例042 获取一维数组最小值 52\n实例043 将二维数组中的行列互换 53\n实例044 利用数组随机抽取幸运观众 54\n实例045 用数组设置JTable\u003Cem\u003E表\u003C\u002Fem\u003E格的\u003Cem\u003E列名\u003C\u002Fem\u003E与列宽 55\n3.2 数组操作 57\n实例046 数组的下标界限 57\n实例047 按钮控件数组实现计数器界面 58\n实例048 复选框控件数组 59\n实例049 用数组反转\u003Cem\u003E字符串\u003C\u002Fem\u003E 60\n3.3 数组排序与\u003Cem\u003E查询\u003C\u002Fem\u003E 61\n实例050 使用选择排序法 61\n实例051 使用冒泡排序法 62\n实例052 使用快速排序法 64\n实例053 使用直接插入法 65\n实例054 使用sort方法对数组进行排序 67\n实例055 反转数组中元素的顺序 68\n3.4 常用集合的使用 69\n实例056 用动态数组保存学生姓名 69\n实例057 用List集合传递学生信息 70\n实例058 用TreeSet生成不重复自动排序\n随机数组 71\n实例059 Map映射集合实现省市级联选择框 73\n第4章 \u003Cem\u003E字符串\u003C\u002Fem\u003E处理技术 75\n4.1 格式化\u003Cem\u003E字符串\u003C\u002Fem\u003E 76\n实例060 把数字格式化为货币\u003Cem\u003E字符串\u003C\u002Fem\u003E 76\n实例061 格式化当前日期 77\n实例062 货币金额大写格式 78\n实例063 String类格式化当前日期 80\n实例064 \u003Cem\u003E字符串\u003C\u002Fem\u003E大小写转换 82\n实例065 字符与Unicode码的转换 83\n4.2 辨别\u003Cem\u003E字符串\u003C\u002Fem\u003E 84\n实例066 判断用户名是否正确 84\n实例067 用户名排序 85\n实例068 判断网页请求与FTP请求 86\n实例069 判断文件类型 87\n实例070 判断\u003Cem\u003E字符串\u003C\u002Fem\u003E是否为数字 89\n实例071 验证IP地址的有效性 90\n实例072 鉴别非法电话号码 91\n4.3 操作\u003Cem\u003E字符串\u003C\u002Fem\u003E 92\n实例073 根据标点符号对\u003Cem\u003E字符串\u003C\u002Fem\u003E进行分行 92\n实例074 将\u003Cem\u003E字符串\u003C\u002Fem\u003E的每个字符进行倒序输\u003Cem\u003E出\u003C\u002Fem\u003E 94\n实例075 获取\u003Cem\u003E字符串\u003C\u002Fem\u003E中汉字的个数 94\n实例076 批量\u003Cem\u003E替换\u003C\u002Fem\u003E某一类\u003Cem\u003E字符串\u003C\u002Fem\u003E 95\n实例077 把异常与错误信息显示到窗体中 97\n实例078 从\u003Cem\u003E字符串\u003C\u002Fem\u003E中分离文件路径、\n文件名及扩展名 98\n实例079 判断手机号的合法性 99\n实例080 用\u003Cem\u003E字符串\u003C\u002Fem\u003E构建器追加字符 100\n实例081 去掉\u003Cem\u003E字符串\u003C\u002Fem\u003E中的所有空格 101\n实例082 汉字与区位码的转换 102\n第5章 面向对象技术应用 103\n5.1 Java中类的定义 104\n实例083 自定义图书类 104\n实例084 温度单位转换工具 105\n实例085 域的默认初始化值 106\n实例086 编写同名的方法 107\n实例087 构造方法的应用 108\n5.2 修饰符的使用 109\n实例088 单例模式的应用 109\n实例089 祖先的止痒药方 110\n实例090 统计图书的销售量 111\n实例091 汉诺塔问题求解 112\n实例092 不能重写的方法 113\n5.3 包装类的使用 114\n实例093 将\u003Cem\u003E字符串\u003C\u002Fem\u003E转换成整数 114\n实例094 整数进制转换器 115\n实例095 查看数字的取值范围 116\n实例096 ASCII编码查看器 117\n实例097 Double类型的比较 118\n5.4 面向对象的特征 119\n实例098 经理与员工的差异 119\n实例099 重写父类中的方法 121\n实例100 计算几何图形的面积 122\n实例101 提高产品质量的方法 123\n实例102 简单的汽车销售商场 124\n5.5 Object类的应用 126\n实例103 两只完全相同的宠物 126\n实例104 简化equals()方法的重写 127\n实例105 重新计算对象的哈希码 129\n实例106 简化hashCode()方法的重写 130\n实例107 使用\u003Cem\u003E字符串\u003C\u002Fem\u003E输\u003Cem\u003E出\u003C\u002Fem\u003E对象 132\n实例108 简化toString()方法的重写 133\n5.6 克隆与序列化 134\n实例109 Java对象的假克隆 134\n实例110 Java对象的浅克隆 135\n实例111 Java对象的深克隆 137\n实例112 序列化与对象克隆 139\n实例113 深克隆效率的比较 141\n实例114 transient关键字的应用 143\n5.7 接口和内部类 145\n实例115 使用sort()方法排序 145\n实例116 简化compareTo()方法的重写 146\n实例117 策略模式的简单应用 148\n实例118 适配器模式的简单应用 149\n实例119 普通内部类的简单应用 151\n实例120 局部内部类的简单应用 152\n实例121 匿名内部类的简单应用 153\n实例122 静态内部类的简单应用 154\n第2篇 Java高级应用\n第6章 多线程技术 158\n6.1 线程的基础 159\n实例123 新建无返回值的线程 159\n实例124 查看线程的运行状态 160\n实例125 查看JVM中的线程名 161\n实例126 查看和修改线程\u003Cem\u003E名称\u003C\u002Fem\u003E 163\n实例127 查看和修改线程优先级 165\n实例128 使用守护线程 166\n实例129 休眠当前线程 167\n实例130 终止指定线程 169\n实例131 线程的插队运行 170\n6.2 线程的同步 171\n实例132 非同步的数据读写 171\n实例133 使用方法实现线程同步 172\n实例134 使用代码块实现线程同步 174\n实例135 使用特殊域变量实现线程同步 175\n实例136 使用重入锁实现线程同步 176\n实例137 使用线程局部变量实现线程同步 177\n实例138 简单的线程通信 179\n实例139 简单的线程死锁 180\n实例140 解决线程的死锁问题 182\n6.3 线程的进阶 183\n实例141 使用阻塞队列实现线程同步 183\n实例142 新建有返回值的线程 184\n实例143 使用线程池优化多线程编程 186\n实例144 Object类中线程相关的方法 187\n实例145 哲学家就餐问题 189\n实例146 使用信号量实现线程同步 190\n实例147 使用原子变量实现线程同步 191\n实例148 使用事件分配线程更新Swing控件 193\n实例149 使用SwingWorker类完成耗时操作 194\n第7章 反射与异常处理 195\n7.1 反射的基础 196\n实例150 实例化Class类的5种方式 196\n实例151 获得Class对象\u003Cem\u003E表\u003C\u002Fem\u003E示实体的\u003Cem\u003E名称\u003C\u002Fem\u003E 197\n实例152 查看类的声明 198\n实例153 查看类的成员 199\n实例154 按继承层次对类排序 201\n实例155 查看内部类信息 202\n7.2 反射的进阶 203\n实例156 动态设置类的私有域 203\n实例157 动态调用类中的方法 204\n实例158 动态实例化类 205\n实例159 创建长度可变的数组 206\n实例160 利用反射重写toString()方法 208\n实例161 反射与动态代理 209\n7.3 常见的未检查型异常 210\n实例162 算数异常 210\n实例163 数组存值异常 211\n实例164 数组下标越界异常 212\n实例165 空指针异常 213\n7.4 常见的已检查型异常 214\n实例166 类未发现异常 214\n实例167 非法访问异常 215\n实例168 文件未发现异常 216\n实例169 \u003Cem\u003E数据库\u003C\u002Fem\u003E操作异常 217\n7.5 处理异常 218\n实例170 方法中抛\u003Cem\u003E出\u003C\u002Fem\u003E异常 218\n实例171 方法上抛\u003Cem\u003E出\u003C\u002Fem\u003E异常 219\n实例172 自定义异常类 220\n实例173 捕获单个异常 221\n实例174 捕获多个异常 222\n第8章 枚举与泛型的应用 223\n8.1 枚举使用的简介 224\n实例175 查看枚举类型的定义 224\n实例176 枚举类型的基本特性 225\n实例177 增加枚举元素的信息 226\n实例178 选择合适的枚举元素 227\n实例179 高效的枚举元素集合 228\n实例180 高效的枚举元素映射 229\n实例181 遍历枚举接口的元素 230\n实例182 简单的文件合并工具 231\n8.2 泛型使用的简介 233\n实例183 自定义非泛型栈结构 233\n实例184 使用泛型实现栈结构 234\n实例185 自定义泛型化数组类 235\n实例186 泛型方法与数据\u003Cem\u003E查询\u003C\u002Fem\u003E 236\n实例187 泛型化方法与最小值 238\n实例188 泛型化接口与最大值 239\n实例189 使用通配符增强泛型 240\n实例190 泛型化的折半查找法 241\n第9章 编程常用类 343\n9.1 Calendar类的使用 244\n实例191 简单的数字时钟 244\n实例192 简单的电子时钟 245\n实例193 简单的模拟时钟 246\n实例194 简单的公历万年历 248\n实例195 查看生日相关信息 249\n9.2 SimpleDateFormat与TimeZone\n类的使用 250\n实例196 日期格式有效性判断 250\n实例197 常见日期格式使用 252\n实例198 查看本地时区 253\n实例199 简单的时区转换工具 254\n9.3 System类的使用 255\n实例200 查看常用系统属性 255\n实例201 重定向标准输\u003Cem\u003E出\u003C\u002Fem\u003E 256\n实例202 计算程序运行时间 257\n实例203 从控制台输入密码 258\n9.4 Math类的使用 259\n实例204 角度和弧度的转换 259\n实例205 三角函数的使用 260\n实例206 反三角函数的使用 261\n实例207 双曲函数的使用 262\n实例208 指数与对数运算 263\n9.5 其他常用类的使用 264\n实例209 高精度整数运算 264\n实例210 高精度浮点运算 265\n实例211 七星彩号码生成器 266\n实例212 大乐透号码生成器 267\n实例213 监视JVM内存状态 268\n实例214 启动默认文本工具 269\n实例215 简单的截图软件 270\n第10章 Commons组件 272\n10.1 Commons Lang组件简介 273\n实例216 数组元素的增加 273\n实例217 数组元素的删除 274\n实例218 生成随机\u003Cem\u003E字符串\u003C\u002Fem\u003E 275\n实例219 序列化与反序列化 276\n实例220 分数的常见运算 277\n实例221 整数取值范围判断 279\n10.2 Commons Math组件简介 280\n实例222 描述统计学应用 280\n实例223 绘制简单直方图 281\n实例224 一元线性回归计算 282\n实例225 实数矩阵的运算 283\n实例226 复数的常见运算 284\n实例227 T分布常用计算 285\n10.3 Commons IO组件简介 286\n实例228 简化文件(夹)删除 286\n实例229 简化文件(夹)复制 287\n实例230 简化文件(夹)排序 288\n实例231 简化文件(夹)过滤 289\n实例232 简化文件的读写操作 290\n10.4 Commons BeanUtils组件简介 291\n实例233 设置JavaBean简单属性 291\n实例234 设置JavaBean级联属性 293\n实例235 动态生成JavaBean 295\n实例236 复制JavaBean属性 296\n实例237 动态排序JavaBean 298\n10.5 其他Commons组件简介 299\n实例238 优雅的JDBC代码 299\n实例239 结果集与Bean列\u003Cem\u003E表\u003C\u002Fem\u003E 301\n实例240 编写MD5查看器 302\n实例241 基于Base64编码 304\n实例242 基于Base64解码 305\n实例243 发送简单的Email 306\n实例244 发送带附件的Email 308\n实例245 读取XML文件属性 310\n第3篇 窗体与控件应用\n第11章 窗体设计 314\n11.1 设置窗体位置 315\n实例246 控制窗体加载时的位置 315\n实例247 设置窗体在屏幕中的位置 315\n实例248 从上次关闭位置启动窗体 316\n实例249 始终在桌面最顶层显示的窗体 317\n11.2 设置窗体大小 319\n实例250 设置窗体大小 319\n实例251 根据桌面大小调整窗体大小 320\n实例252 自定义最大化、最小化和关闭按钮 321\n实例253 禁止改变窗体的大小 323\n11.3 设置窗体的标题栏 324\n实例254 指定窗体标题栏图标 324\n实例255 拖动没有标题栏的窗体 325\n实例256 取消窗体标题栏与边框 326\n实例257 设置闪烁的标题栏 328\n11.4 设置窗体的背景 329\n实例258 设置窗体背景颜色为淡蓝色 329\n实例259 实现带背景图片的窗体 330\n实例260 使背景图片自动适应窗体的大小 331\n实例261 背景为渐变色的主界面 332\n实例262 随机更换窗体背景 334\n11.5 窗体形状及应用 335\n实例263 椭圆形窗体界面 335\n实例264 钻石形窗体 336\n实例265 创建透明窗体 337\n11.6 对话框 338\n实例266 模态对话框与非模态对话框 338\n实例267 信息提示对话框 340\n实例268 设置信息提示对话框的图标 341\n实例269 文件选择对话框指定\u003Cem\u003E数据库\u003C\u002Fem\u003E备份文件 342\n实例270 指定打开对话框的文件类型 343\n实例271 文件的保存对话框 344\n实例272 为保存对话框设置默认文件名 346\n实例273 支持图片预览的文件选择对话框 347\n实例274 颜色选择对话框 348\n实例275 信息输入对话框 350\n实例276 定制信息对话框 350\n11.7 MDI窗体的使用 352\n实例277 创建内部子窗体 352\n实例278 使子窗体最大化显示 353\n实例279 对子窗体进行平铺排列 354\n实例280 禁用MDI窗体控制栏中的“最大化”\n按钮 355\n第12章 窗体特效 357\n12.1 让窗体更有活力 358\n实例281 右下角弹\u003Cem\u003E出\u003C\u002Fem\u003E信息窗体 358\n实例282 淡入淡\u003Cem\u003E出\u003C\u002Fem\u003E的窗体 359\n实例283 窗体顶层的进度条 361\n实例284 设置窗体的鼠标光标 362\n实例285 窗体抖动 363\n实例286 窗体标题显示计时器 364\n实例287 动态展开窗体 365\n实例288 仿QQ隐藏窗体 366\n实例289 窗体百叶窗登场特效 367\n实例290 关闭窗体打开网址 368\n12.2 窗体与控件外观 369\n实例291 Nimbus外观 369\n实例292 本地系统外观 370\n实例293 分割的窗体界面 371\n实例294 圆周运动的窗体 373\n第13章 基本控件应用 375\n13.1 顶层容器的应用 376\n实例295 框架容器的背景图片 376\n实例296 更多选项的框架容器 377\n实例297 拦截事件的玻璃窗格 378\n实例298 简单的每日提示信息 379\n实例299 震动效果的提示信息 380\n13.2 布局管理器应用 382\n实例300 边框布局的简单应用 382\n实例301 流式布局的简单应用 383\n实例302 网格布局的简单应用 384\n实例303 制作圆形布局管理器 385\n实例304 制作阶梯布局管理器 386\n13.3 输入控件的应用 387\n实例305 可以打开网页的标签 387\n实例306 密码域控件的简单应用 389\n实例307 给文本域设置背景图片 390\n实例308 给文本区设置背景图片 391\n实例309 简单的字符统计工具 392\n13.4 选择控件的应用 393\n实例310 能预览图片的复选框 393\n实例311 简单的投票计数软件 394\n实例312 单选按钮的简单应用 395\n实例313 能显示图片的组合框 396\n实例314 使用滑块来选择日期 398\n13.5 菜单控件的应用 400\n实例315 模仿记事本的菜单栏 400\n实例316 自定义纵向的菜单栏 401\n实例317 复选框与单选按钮菜单 402\n实例318 包含图片的弹\u003Cem\u003E出\u003C\u002Fem\u003E菜单 404\n实例319 工具栏的实现与应用 405\n13.6 其他技术的应用 406\n实例320 自定义软件安装向导 406\n实例321 查看系统支持的外观 407\n实例322 制作软件的闪屏界面 408\n实例323 自定义系统托盘图标 410\n实例324 使用撤销与重做功能 412\n第14章 复合数据类型控件应用 414\n14.1 列\u003Cem\u003E表\u003C\u002Fem\u003E的简单应用 415\n实例325 修改列\u003Cem\u003E表\u003C\u002Fem\u003E项显示方式 415\n实例326 修改列\u003Cem\u003E表\u003C\u002Fem\u003E项选择模式 416\n实例327 列\u003Cem\u003E表\u003C\u002Fem\u003E项的全选与不选 417\n实例328 列\u003Cem\u003E表\u003C\u002Fem\u003E元素与提示信息 419\n实例329 监听列\u003Cem\u003E表\u003C\u002Fem\u003E项单击事件 420\n实例330 监听列\u003Cem\u003E表\u003C\u002Fem\u003E项双击事件 421\n14.2 列\u003Cem\u003E表\u003C\u002Fem\u003E的高级应用 422\n实例331 实现自动排序的列\u003Cem\u003E表\u003C\u002Fem\u003E 422\n实例332 列\u003Cem\u003E表\u003C\u002Fem\u003E项的增加与删除 423\n实例333 查找特定的列\u003Cem\u003E表\u003C\u002Fem\u003E元素 425\n实例334 包含边框的列\u003Cem\u003E表\u003C\u002Fem\u003E元素 426\n实例335 包含图片的列\u003Cem\u003E表\u003C\u002Fem\u003E元素 427\n实例336 可以预览字体的列\u003Cem\u003E表\u003C\u002Fem\u003E 428\n14.3 \u003Cem\u003E表\u003C\u002Fem\u003E格的简单应用 430\n实例337 \u003Cem\u003E表\u003C\u002Fem\u003E头与列的高度设置 430\n实例338 调整\u003Cem\u003E表\u003C\u002Fem\u003E格各列的宽度 431\n实例339 设置\u003Cem\u003E表\u003C\u002Fem\u003E格的选择模式 433\n实例340 为\u003Cem\u003E表\u003C\u002Fem\u003E头增添提示信息 434\n实例341 单元格的粗粒度排序 436\n实例342 实现\u003Cem\u003E表\u003C\u002Fem\u003E格的查找功能 437\n14.4 \u003Cem\u003E表\u003C\u002Fem\u003E格的高级应用 438\n实例343 在\u003Cem\u003E表\u003C\u002Fem\u003E格中应用组合框 438\n实例344 删除\u003Cem\u003E表\u003C\u002Fem\u003E格中选中的行 440\n实例345 实现\u003Cem\u003E表\u003C\u002Fem\u003E格的分页技术 442\n实例346 为单元格绘制背景色 444\n实例347 实现\u003Cem\u003E表\u003C\u002Fem\u003E格的栅栏效果 445\n实例348 单元格的细粒度排序 446\n14.5 树控件简单应用 448\n实例349 编写中国省市信息树 448\n实例350 树控件常用遍历方式 449\n实例351 自定义树节点的图标 451\n实例352 监听节点的选择事件 452\n实例353 设置树控件选择模式 453\n实例354 查看节点的各种状态 455\n14.6 树控件高级应用 456\n实例355 在树控件中增加节点 456\n实例356 在树控件中删除节点 458\n实例357 在树控件中查找节点 459\n实例358 自定义树节点的外观 460\n实例359 为树节点增加提示信息 463\n实例360 双击编辑树节点功能 464\n第15章 其他高级控件应用 466\n15.1 JTextPane控件的应用 467\n实例361 自定义文档标题的样式 467\n实例362 文档中显示自定义图片 468\n实例363 检查代码中的括号是否匹配 469\n实例364 描红显示100以内的质数 471\n15.2 JEditorPane控件的应用 472\n实例365 自定义RTF文件查看器 472\n实例366 编写简单的浏览器 474\n实例367 支持超链接的浏览器 474\n实例368 高亮用户指定的关键字 476\n15.3 其他文本控件的应用 477\n实例369 只能输入整数的文本域 477\n实例370 强制输入合法的整数 478\n实例371 使用微调控件调整时间 479\n实例372 使用微调控件浏览图片 480\n15.4 进度指示器的应用 481\n实例373 显示完成情况的进度条 481\n实例374 监听进度条的变化事件 482\n实例375 进度监视器控件的应用 484\n实例376 监视文件读入的进度 485\n15.5 控件组织器的应用 487\n实例377 分割面板的简单应用 487\n实例378 为选项卡增加快捷键 488\n实例379 为选项卡标题设置图标 489\n实例380 记录选项卡的访问状态 490\n第16章 控件特效与自定义控件 492\n16.1 控件边框效果 493\n实例381 实现标签控件的立体边框 493\n实例382 实现按钮控件边框留白 494\n实例383 实现文本域控件的浮雕化边框 495\n实例384 为文本框控件添加LineBorder\n线形边框 496\n实例385 控件的纯色边框与图标边框 498\n实例386 实现带标题边框的面板容器 499\n实例387 指定字体的标题边框 501\n实例388 嵌套的标题边框 502\n实例389 带图标边框的标题边框 503\n实例390 文本框的下划线边框 504\n16.2 控件渲染让界面UI更灵活 506\n实例391 支持图标的列\u003Cem\u003E表\u003C\u002Fem\u003E控件 506\n实例392 在列\u003Cem\u003E表\u003C\u002Fem\u003E控件中显示单选按钮 507\n实例393 列\u003Cem\u003E表\u003C\u002Fem\u003E控件折行显示列\u003Cem\u003E表\u003C\u002Fem\u003E项 508\n实例394 使用图片制作绚丽按钮 510\n实例395 实现按钮关键字描红 511\n实例396 忙碌的按钮控件 512\n实例397 实现透明效果的\u003Cem\u003E表\u003C\u002Fem\u003E格控件 513\n实例398 在\u003Cem\u003E表\u003C\u002Fem\u003E格中显示工作进度百分比 515\n实例399 在\u003Cem\u003E表\u003C\u002Fem\u003E格中显示图片 517\n16.3 让控件活起来 518\n实例400 鼠标经过时按钮放大效果 518\n实例401 迟到的登录按钮 520\n实例402 焦点按钮的缩放 521\n实例403 标签文本的跑马灯特效 522\n实例404 延迟生效的按钮 524\n实例405 动态加载\u003Cem\u003E表\u003C\u002Fem\u003E格数据 525\n16.4 自定义控件 526\n实例406 石英钟控件 526\n实例407 IP输入文本框控件 527\n实例408 日历控件 530\n实例409 平移面板控件 531\n实例410 背景图面板控件 533\n第4篇 文件操作典型应用\n第17章 文件与文件夹操作 536\n17.1 文件操作 537\n实例411 修改文件属性 537\n实例412 显示指定类型的文件 538\n实例413 以树结构显示文件路径 540\n实例414 查找\u003Cem\u003E替换\u003C\u002Fem\u003E文本文件内容 541\n实例415 支持图片预览的文件选择对话框 543\n实例416 设置Windows的文件属性 545\n实例417 文件批量重命名 547\n实例418 快速批量移动文件 549\n实例419 删除磁盘中所有的.tmp临时文件 551\n17.2 文件与\u003Cem\u003E数据库\u003C\u002Fem\u003E 553\n实例420 提取\u003Cem\u003E数据库\u003C\u002Fem\u003E内容到文件 553\n实例421 提取文本文件的内容到MySQL\u003Cem\u003E数据库\u003C\u002Fem\u003E 555\n实例422 将图片文件保存到SQL Server\u003Cem\u003E数据库\u003C\u002Fem\u003E 556\n实例423 显示\u003Cem\u003E数据库\u003C\u002Fem\u003E中的图片信息 558\n实例424 提取技术网站数据到文件夹 559\n实例425 读取文件路径到\u003Cem\u003E数据库\u003C\u002Fem\u003E 561\n实例426 在\u003Cem\u003E数据库\u003C\u002Fem\u003E中建立磁盘文件索引 562\n17.3 操作磁盘文件夹 564\n实例427 窗体动态加载磁盘文件 564\n实例428 删除文件夹中所有文件 565\n实例429 创建磁盘索引文件 567\n实例430 快速全盘查找文件 568\n实例431 获取磁盘所有文本文件 570\n实例432 网络文件夹备份 571\n第18章 文件的读取、写入、整理和控制 573\n18.1 文件的读取与写入 574\n实例433 键盘录入内容保存到文本文件 574\n实例434 将数组写入到文件中并逆序输\u003Cem\u003E出\u003C\u002Fem\u003E 575\n实例435 利用StringBuffer避免文件的多次写入 576\n实例436 合并多个txt文件 577\n实例437 实现文件简单加密与解密 579\n实例438 对大文件实现分割处理 581\n实例439 将分割后的文件重新合并 583\n实例440 读取属性文件的单个属性值 584\n实例441 向属性文件中添加信息 585\n实例442 在复制文件时使用进度条 586\n实例443 从XML文件中读取数据 587\n实例444 读取Jar文件属性 589\n实例445 电子通讯录 590\n18.2 实现文件整理 592\n实例446 批量复制指定扩展名的文件 592\n实例447 计数器小程序 594\n实例448 将某文件夹中的文件进行分类存储 595\n18.3 文件控制 597\n实例449 利用StreamTokenizer统计文件的\n字符数 597\n实例450 在指定目录下搜索文件 598\n实例451 序列化和反序列化对象 600\n实例452 文件锁定 602\n实例453 投票统计 603\n第19章 文件压缩 605\n19.1 Java实现文件压缩 606\n实例454 压缩所有文本文件 606\n实例455 压缩包解压到指定文件夹 607\n实例456 压缩所有子文件夹 608\n实例457 深层文件夹压缩包的释放 610\n实例458 解决压缩包中文乱码 611\n实例459 Apache实现文件解压缩 612\n实例460 把窗体压缩成ZIP文件 613\n实例461 解压缩Java对象 615\n19.2 RAR文件压缩 616\n实例462 文件压缩为RAR文档 616\n实例463 解压缩RAR压缩包 619\n实例464 文件分卷压缩 621\n实例465 为RAR压缩包添加注释 623\n实例466 获取压缩包详细文件列\u003Cem\u003E表\u003C\u002Fem\u003E 625\n实例467 从RAR压缩包中删除文件 627\n实例468 在压缩文件中查找\u003Cem\u003E字符串\u003C\u002Fem\u003E 628\n实例469 重命名RAR压缩包中的文件 629\n实例470 创建自解压RAR压缩包 631\n实例471 设置RAR压缩包密码 632\n19.3 数据压缩的网络应用 634\n实例472 以压缩格式传输网络数据 634\n实例473 压缩远程文件夹 637\n实例474 压缩存储网页 638\n第20章 操作办公文档 640\n20.1 操作Word 641\n实例475 把文本文件导入到Word中 641\n实例476 浏览本地Word文件 642\n实例477 将员工\u003Cem\u003E表\u003C\u002Fem\u003E插入到Word文档中 644\n实例478 将员工照片插入到Word简历 645\n实例479 将Word文档保存为HTML格式 646\n20.2 操作Excel 647\n实例480 将员工信息保存到Excel\u003Cem\u003E表\u003C\u002Fem\u003E中 647\n实例481 通过Excel公式计算\u003Cem\u003E出\u003C\u002Fem\u003E商品\u003Cem\u003E表\u003C\u002Fem\u003E中的\n总售价 649\n实例482 将\u003Cem\u003E数据库\u003C\u002Fem\u003E\u003Cem\u003E表\u003C\u002Fem\u003E中的内容写入到Excel 651\n实例483 将Excel\u003Cem\u003E表\u003C\u002Fem\u003E中的内容保存到\u003Cem\u003E数据库\u003C\u002Fem\u003E 653\n实例484 将Excel文件转换为HTML格式 654\n20.3 操作PDF 655\n实例485 应用iText组件生成PDF 655\n实例486 在窗体中显示PDF文件 657\n实例487 应用PDF Renderer组件实现放大\nPDF文件 658\n实例488 应用PDF Renderer组件实现缩小\nPDF文件 660\n实例489 应用PDF Renderer组件实现抓手功能 661\n实例490 全屏显示PDF文件 662\n第5篇 \u003Cem\u003E数据库\u003C\u002Fem\u003E应用\n第21章 SQL应用 666\n21.1 排序和分组函数应用 667\n实例491 对数据进行降序\u003Cem\u003E查询\u003C\u002Fem\u003E 667\n实例492 对数据进行多条件排序\u003Cem\u003E查询\u003C\u002Fem\u003E 669\n实例493 对统计结果进行排序 670\n实例494 \u003Cem\u003E查询\u003C\u002Fem\u003ESQL Server\u003Cem\u003E数据库\u003C\u002Fem\u003E中的前3条\n数据 671\n实例495 \u003Cem\u003E查询\u003C\u002Fem\u003ESQL Server\u003Cem\u003E数据库\u003C\u002Fem\u003E中的后3\n条数据 672\n实例496 \u003Cem\u003E查询\u003C\u002Fem\u003EMySQL\u003Cem\u003E数据库\u003C\u002Fem\u003E中的前3条数据 673\n实例497 \u003Cem\u003E查询\u003C\u002Fem\u003EMySQL\u003Cem\u003E数据库\u003C\u002Fem\u003E中的后3条数据 674\n实例498 按照字母顺序对留学生\u003Cem\u003E表\u003C\u002Fem\u003E进行排序 675\n实例499 按姓氏笔画排序 677\n实例500 将汉字按音序排序 678\n实例501 按列的编号排序 679\n实例502 从\u003Cem\u003E表\u003C\u002Fem\u003E中随机返回记录 680\n实例503 使用GROUP BY子句实现对数据的\n分组统计 681\n实例504 使用GROUP BY子句实现多\u003Cem\u003E表\u003C\u002Fem\u003E\n分组统计 682\n21.2 聚集函数与日期\u003Cem\u003E查询\u003C\u002Fem\u003E 683\n实例505 利用SUM函数实现数据汇总 683\n实例506 利用AVG函数实现计算平均值 684\n实例507 利用MIN函数求数据\u003Cem\u003E表\u003C\u002Fem\u003E中的最小值 685\n实例508 利用MAX函数求数据\u003Cem\u003E表\u003C\u002Fem\u003E中的最大值 686\n实例509 利用COUNT函数求销售额大于某值的\n图书种类 688\n实例510 \u003Cem\u003E查询\u003C\u002Fem\u003E编程词典6月的销售量 689\n实例511 \u003Cem\u003E查询\u003C\u002Fem\u003E与张静同一天入司的员工信息 690\n实例512 使用IN谓词\u003Cem\u003E查询\u003C\u002Fem\u003E某几个时间的数据 692\n实例513 日期\u003Cem\u003E查询\u003C\u002Fem\u003E中避免千年虫问题 693\n21.3 大小比较与逻辑应用 694\n实例514 在\u003Cem\u003E查询\u003C\u002Fem\u003E结果中不显示重复记录 694\n实例515 使用NOT\u003Cem\u003E查询\u003C\u002Fem\u003E不满足条件的记录 695\n实例516 使用between进行区间\u003Cem\u003E查询\u003C\u002Fem\u003E 697\n实例517 列\u003Cem\u003E出\u003C\u002Fem\u003E销量\u003Cem\u003E表\u003C\u002Fem\u003E中的重复记录和记录条数 698\n实例518 使用关系运算符\u003Cem\u003E查询\u003C\u002Fem\u003E某一时间段数据 699\n实例519 计算两个日期之间的月份数 700\n实例520 格式化金额 702\n实例521 在\u003Cem\u003E查询\u003C\u002Fem\u003E语句中过滤掉\u003Cem\u003E字符串\u003C\u002Fem\u003E中的空格 703\n第22章 \u003Cem\u003E数据库\u003C\u002Fem\u003E操作 705\n22.1 通过JDBC-ODBC桥连接\u003Cem\u003E数据库\u003C\u002Fem\u003E 706\n实例522 通过JDBC-ODBC桥连接SQL Server\n2000\u003Cem\u003E数据库\u003C\u002Fem\u003E 706\n实例523 JDBC-ODBC桥连接Access\u003Cem\u003E数据库\u003C\u002Fem\u003E 708\n实例524 JDBC-ODBC桥与Oracle\u003Cem\u003E数据库\u003C\u002Fem\u003E\n建立连接 710\n22.2 JDBC技术连接\u003Cem\u003E数据库\u003C\u002Fem\u003E 711\n实例525 通过JDBC连接SQL Server 2000\n\u003Cem\u003E数据库\u003C\u002Fem\u003E 711\n实例526 JDBC连接MySQL\u003Cem\u003E数据库\u003C\u002Fem\u003E 713\n实例527 JDBC连接SQL Server 2005\u003Cem\u003E数据库\u003C\u002Fem\u003E 714\n实例528 JDBC技术连接Oracle\u003Cem\u003E数据库\u003C\u002Fem\u003E 715\n实例529 JDBC连接JavaDB\u003Cem\u003E数据库\u003C\u002Fem\u003E 716\n22.3 \u003Cem\u003E数据库\u003C\u002Fem\u003E与数据\u003Cem\u003E表\u003C\u002Fem\u003E 717\n实例530 列举SQL Server\u003Cem\u003E数据库\u003C\u002Fem\u003E下的数据\u003Cem\u003E表\u003C\u002Fem\u003E 717\n实例531 列举MySQL\u003Cem\u003E数据库\u003C\u002Fem\u003E下的数据\u003Cem\u003E表\u003C\u002Fem\u003E 718\n实例532 查看数据\u003Cem\u003E表\u003C\u002Fem\u003E结构 719\n实例533 动态维护投票\u003Cem\u003E数据库\u003C\u002Fem\u003E 721\n实例534 SQL Server数据备份 722\n实例535 SQL Server数据恢复 725\n实例536 MySQL数据备份 728\n实例537 MySQL数据恢复 730\n实例538 动态附加\u003Cem\u003E数据库\u003C\u002Fem\u003E 731\n实例539 生成SQL\u003Cem\u003E数据库\u003C\u002Fem\u003E脚本 733\n实例540 获取SQL Server数据\u003Cem\u003E表\u003C\u002Fem\u003E字段的描述信息 734\n22.4 数据增加、更新与删除操作 736\n实例541 将员工信息添加到数据\u003Cem\u003E表\u003C\u002Fem\u003E 736\n实例542 添加数据时使用数据验证 737\n实例543 插入用户登录日志信息 739\n实例544 生成有规律的编号 740\n实例545 生成无规律的编号 742\n实例546 在插入数据时过滤掉危险字符 743\n实例547 将用户选择的爱好以\u003Cem\u003E字符串\u003C\u002Fem\u003E形式保存\n到\u003Cem\u003E数据库\u003C\u002Fem\u003E 744\n实例548 将数据从一张\u003Cem\u003E表\u003C\u002Fem\u003E复制到另一张\u003Cem\u003E表\u003C\u002Fem\u003E 745\n实例549 使用UNION ALL语句批量插入数据 746\n实例550 更新指定记录 747\n实例551 在删除数据时给\u003Cem\u003E出\u003C\u002Fem\u003E提示信息 748\n实例552 将数据\u003Cem\u003E表\u003C\u002Fem\u003E清空 749\n实例553 \u003Cem\u003E字符串\u003C\u002Fem\u003E大小写转换 750\n第23章 数据\u003Cem\u003E查询\u003C\u002Fem\u003E 752\n23.1 使用子\u003Cem\u003E查询\u003C\u002Fem\u003E 753\n实例554 将子\u003Cem\u003E查询\u003C\u002Fem\u003E作为\u003Cem\u003E表\u003C\u002Fem\u003E达式 753\n实例555 用子\u003Cem\u003E查询\u003C\u002Fem\u003E作为派生\u003Cem\u003E表\u003C\u002Fem\u003E 754\n实例556 通过子\u003Cem\u003E查询\u003C\u002Fem\u003E关联数据 755\n实例557 使用IN谓词限定\u003Cem\u003E查询\u003C\u002Fem\u003E范围 756\n实例558 使用NOT IN子\u003Cem\u003E查询\u003C\u002Fem\u003E实现差集运算 758\n实例559 使用NOT IN子\u003Cem\u003E查询\u003C\u002Fem\u003E实现反向\u003Cem\u003E查询\u003C\u002Fem\u003E 759\n实例560 返回笛卡尔乘积 760\n实例561 比较运算符引入子\u003Cem\u003E查询\u003C\u002Fem\u003E 761\n实例562 在子\u003Cem\u003E查询\u003C\u002Fem\u003E中使用聚集函数 762\n实例563 在删除数据时使用子\u003Cem\u003E查询\u003C\u002Fem\u003E 763\n23.2 嵌套\u003Cem\u003E查询\u003C\u002Fem\u003E 764\n实例564 \u003Cem\u003E查询\u003C\u002Fem\u003E平均成绩在85分以上的学生信息 764\n实例565 \u003Cem\u003E查询\u003C\u002Fem\u003E本科部门经理月收入情况 766\n实例566 在嵌套中使用EXISTS关键字 767\n实例567 动态指定\u003Cem\u003E查询\u003C\u002Fem\u003E条件 768\n23.3 连接\u003Cem\u003E查询\u003C\u002Fem\u003E 769\n实例568 使用UNION运算符使学生档案归档 769\n实例569 内连接获取指定课程的教师信息 771\n实例570 左外连接\u003Cem\u003E查询\u003C\u002Fem\u003E员工信息 772\n实例571 右外连接\u003Cem\u003E查询\u003C\u002Fem\u003E员工信息 773\n实例572 多\u003Cem\u003E表\u003C\u002Fem\u003E外连接\u003Cem\u003E查询\u003C\u002Fem\u003E 774\n实例573 完全连接\u003Cem\u003E查询\u003C\u002Fem\u003E 775\n23.4 函数\u003Cem\u003E查询\u003C\u002Fem\u003E 777\n实例574 在\u003Cem\u003E查询\u003C\u002Fem\u003E中使用patindex()函数进行\n模糊\u003Cem\u003E查询\u003C\u002Fem\u003E 777\n实例575 对\u003Cem\u003E查询\u003C\u002Fem\u003E结果进行格式化 778\n实例576 在\u003Cem\u003E查询\u003C\u002Fem\u003E中使用\u003Cem\u003E字符串\u003C\u002Fem\u003E函数 780\n实例577 在\u003Cem\u003E查询\u003C\u002Fem\u003E中使用ALL谓词 781\n实例578 在\u003Cem\u003E查询\u003C\u002Fem\u003E中使用ANY谓词 782\n实例579 使用UNION运算符消除重复的行 784\n实例580 使用UNION ALL运算符保留重复的行 785\n实例581 计算商品销售额所占的百分比 786\n第24章 \u003Cem\u003E数据库\u003C\u002Fem\u003E高级应用 787\n24.1 在Java程序中使用存储过程 788\n实例582 调用存储过程实现用户身份验证 788\n实例583 应用存储过程添加数据 789\n实例584 调用加密存储过程 791\n实例585 获取\u003Cem\u003E数据库\u003C\u002Fem\u003E中所有存储过程 792\n实例586 修改存储过程 793\n实例587 删除存储过程 795\n24.2 使用触发器 796\n实例588 应用触发器添加日志信息 796\n实例589 在删除成绩\u003Cem\u003E表\u003C\u002Fem\u003E时将学生\u003Cem\u003E表\u003C\u002Fem\u003E中的数据删除 798\n实例590 在程序中调用UPDATE触发器 799\n实例591 获取\u003Cem\u003E数据库\u003C\u002Fem\u003E中的触发器\u003Cem\u003E名称\u003C\u002Fem\u003E 801\n实例592 创建带有触发条件的触发器 802\n24.3 使用批处理 803\n实例593 使用批处理删除数据 803\n实例594 使用批处理提升部门员工工资 805\n实例595 将教师\u003Cem\u003E表\u003C\u002Fem\u003E中的数据全部添加到选课\u003Cem\u003E表\u003C\u002Fem\u003E 806\n实例596 在批处理中使用事务 807\n24.4 使用视图 809\n实例597 创建视图 809\n实例598 使用视图过滤不想要的数据 810\n实例599 使用视图与计算数据 812\n实例600 使用视图重新格式化检索\u003Cem\u003E出\u003C\u002Fem\u003E来的数据 813\n实例601 获取\u003Cem\u003E数据库\u003C\u002Fem\u003E中的全部用户视图 814\n实例602 修改视图 815\n实例603 删除视图 816","createTime":"2016-06-12 11:39:31","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-9546866-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-9546866-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"1\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fpczlang\u002F9546866\",\"strategy\":\"2~default~OPENSEARCH~Paid\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-9546866-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1715086686466_68342\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"1\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fpczlang\u002F9546866\",\"strategy\":\"2~default~OPENSEARCH~Paid\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-9546866-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1715086686466_68342\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fhsttmht\u002F4998764","title":"Oracle 10g 开发与管理","desc":"本文是由笔者2012年学习oracle\u003Cem\u003E数据库\u003C\u002Fem\u003E时编写的学习札记,其中的题目\n多数为老师留下的思考题目。 \n \n我相信本文会对初学者使用oracle有\u003Cem\u003E一个\u003C\u002Fem\u003E初步的使用印象。右图为我所参\n考的书籍。\n\n\n目录\n\n第一讲 Oacle关系\u003Cem\u003E数据库\u003C\u002Fem\u003E 9\n一. Oracle的安装 9\n二. 用浏览器进入em 企业管理器 11\n三.启动DBCA的方法 11\n四.服务设置 11\n五. Oracle的卸载 11\n六. Oracle\u003Cem\u003E数据库\u003C\u002Fem\u003E的应用系统结构 11\n七. 补充资料——oracle安装时\u003Cem\u003E出\u003C\u002Fem\u003E现的问题 12\n第二讲 Oacle\u003Cem\u003E数据库\u003C\u002Fem\u003E体系结构 14\n一. 物理存储结构——(\u003Cem\u003E数据库\u003C\u002Fem\u003E载体) 14\n1.数据文件(.DBF) 14\n2.日志文件 (.Log) 14\n1) 日志文件 15\n2) \u003Cem\u003E数据库\u003C\u002Fem\u003E工作模式 15\n3.控制文件(.ctl) 15\n4.\u003Cem\u003E参数\u003C\u002Fem\u003E文件 (.ora) 16\n二. 逻辑存储结构 17\n1.数据块 (Data Blocks) 17\n2.盘区(Extent) 18\n3.段 (Segment) 18\n4.\u003Cem\u003E表\u003C\u002Fem\u003E空间(Table Spaces) P34 18\n三. 内存结构 19\n1.数据缓冲区: 内存的40% 19\n2.日志缓冲区: 19\n3.数据字典缓冲区: 19\n4.共享池 内存的10% 19\n5.大池 5-10M 20\n6.JAVA池 不小于20M 20\n7.Streams池 20\n8.软件代码区: 20\n9.程序全局区(PGA) 20\n四. 实例的进程结构(实例=SGA + 后台进程) 20\n1.DBWR (\u003Cem\u003E数据库\u003C\u002Fem\u003E写入进程) 21\n2.LGWR(日志写入进程) 22\n3.ARCH(归档进程)-可选进程 22\n4.CKPT(检查点进程)-可选进程 22\n5.SMON (系统监控进程) 22\n6.PMON (进程监控进程) 22\n7.RECO (恢复进程) 22\n8. Dnnn (调度进程)-可选进程(略) 22\n五. 数据字典 22\n第三讲 用户、模式和\u003Cem\u003E表\u003C\u002Fem\u003E 24\n一. 用户和模式 24\n1.模式 24\n2.模式对象 24\n3.用户 24\n(1)创建用户 24\n(2)授权 24\n(3)删除用户及该模式下对象 26\n二. \u003Cem\u003E表\u003C\u002Fem\u003E 26\n1. 数据类型 26\n(1)字符型 26\n(2)数值型 26\n(3)日期时间型 26\n(4)LOB (大型对象) 26\n(5)RowID (伪列类型) 27\n2. 创建\u003Cem\u003E表\u003C\u002Fem\u003E 27\n(1)Create Table \u003Cem\u003E表\u003C\u002Fem\u003E名 27\n(2)在原来已有\u003Cem\u003E表\u003C\u002Fem\u003E上建\u003Cem\u003E一个\u003C\u002Fem\u003E新\u003Cem\u003E表\u003C\u002Fem\u003E(结构和数据) 27\n(3)使用OEM建\u003Cem\u003E表\u003C\u002Fem\u003E 27\n3.默认值和NULL值 27\n三. 修改\u003Cem\u003E表\u003C\u002Fem\u003E 28\n四. 删除\u003Cem\u003E表\u003C\u002Fem\u003E 28\n五. 数据完整性 28\n1.Primary Key 约束 28\n2.NOT NULL约束 29\n3.Unique 约束 29\n4.Foreign Key 约束 29\n5.Check约束 (最复杂)列级 | \u003Cem\u003E表\u003C\u002Fem\u003E级 29\n第四讲 SQL基本\u003Cem\u003E查询\u003C\u002Fem\u003E 31\n一. SQL语句概述 31\n1. SQL简介 31\n2. SQL分类 31\n3. PL\u002FSQL (Procedure Language) 31\n二. SQL*Plus 31\n1.启动 SQL*Plus 单行编辑 31\n2.启动iSQL*Plus 多行编辑 31\n3.退\u003Cem\u003E出\u003C\u002Fem\u003E 32\n 直接关闭 32\n 输入:Exit 或 quit 32\n三. 本书所使用的示例模式 32\n1.Vendition:销售管理系统(11个\u003Cem\u003E表\u003C\u002Fem\u003E)(略) 32\n2. School:学生成绩管理系统(6个\u003Cem\u003E表\u003C\u002Fem\u003E) 32\n四. SQL SELECT语句 34\n1.Select语句的格式 34\n2.Select … From … ——选择列(投影) 35\n3.Where子句——选择行(选择)数据过滤 35\n4.Order By子句 35\n5.统计函数——\u003Cem\u003E列名\u003C\u002Fem\u003E应指定别名 35\n6. Group By分组 36\n7.Having子句 36\n8.练习:\u003Cem\u003E表\u003C\u002Fem\u003E的\u003Cem\u003E查询\u003C\u002Fem\u003E 36\n五. 在SQL *Plus中使用函数 37\n1.\u003Cem\u003E字符串\u003C\u002Fem\u003E函数 37\n2.数字函数 37\n3.日期时间函数 38\n4.转换函数 38\n第五讲 修改SQL数据与SQL*Plus命令 40\n一.添加数据 40\n1.Insert Into \u003Cem\u003E表\u003C\u002Fem\u003E名 [ 字段列\u003Cem\u003E表\u003C\u002Fem\u003E ] Values (值) 40\n2.向\u003Cem\u003E表\u003C\u002Fem\u003E中插入空值 40\n3.从其它\u003Cem\u003E表\u003C\u002Fem\u003E中拷贝数据 40\n二. 更新数据 41\n三. 删除数据 42\n1.Delete 语句 42\n2.Truncate 语句 42\n四. SQL*Plus命令 42\n1.设置环境变量命令 42\n(1)Pause 43\n(2)pagesize 和 newpage 43\n(3)linesize 43\n(4)numformat 选项 43\n(5)timing 选项 44\n2.格式化\u003Cem\u003E查询\u003C\u002Fem\u003E结果命令 44\n(1)column : 44\n(2)Ttitle 和 Btitle 命令 44\n3.文件操作命令 45\n(1)保存命令到文件 45\n(2)检索命令文件到缓冲区 45\n(3)运行命令文件 45\n(4)保存\u003Cem\u003E查询\u003C\u002Fem\u003E结果到文件 46\n4.交互命令:动态\u003Cem\u003E查询\u003C\u002Fem\u003E 46\n(1)定义命令 46\n(2)\u003Cem\u003E替换\u003C\u002Fem\u003E符 (用来临时存储有关的数据) 46\n5.帮助命令 46\n(1)help index 将显示SQL*Plus的所有命令 47\n(2)help 命令\u003Cem\u003E名称\u003C\u002Fem\u003E 显示该命令的功能和选项 47\n6.其他的SQL*Plus命令 47\n(1)退\u003Cem\u003E出\u003C\u002Fem\u003E SQL\u003E Exit | Quit; 47\n(2)清除命令 47\n(3)查看\u003Cem\u003E表\u003C\u002Fem\u003E结构信息 47\n(4)执行操作系统命令 47\n第六讲 高级\u003Cem\u003E查询\u003C\u002Fem\u003E 50\n一.简单连接 50\n1.简单连接 50\n2.\u003Cem\u003E表\u003C\u002Fem\u003E别名 P136 50\n3.各个\u003Cem\u003E表\u003C\u002Fem\u003E之间的连接 50\n二. 使用Join连接 50\n1.内连接 50\n(1)等值连接(有相同的,逐个匹配) 50\n(2)不等连接 51\n(3)自然连接 51\n2.外连接 (左、右、完全) 51\n3.交叉连接 52\n三.集合操作 52\n1.Union(并)——结果集相加 “Or” 52\n2.Intersect(交) “And” 52\n3. Minus(差) 52\n四.子\u003Cem\u003E查询\u003C\u002Fem\u003E 53\n1.使用的是\u003Cem\u003E表\u003C\u002Fem\u003E中的列 53\n(1) IN 53\n(2)Exist 53\n(3)Some、Any和All 53\n五.\u003Cem\u003E表\u003C\u002Fem\u003E的\u003Cem\u003E查询\u003C\u002Fem\u003E练习 54\n第七讲 PL\u002FSQL编程基础 56\n7.1 PL\u002FSQL 程序结构 56\n1.PL\u002FSQL块结构 56\n2.PL\u002FSQL块的分类(按照特性划分) 56\n7.2变量与常量 56\n(一)PL\u002FSQL标识符 (给变量命名) 56\n(二)标量变量 56\n1.PL\u002FSQL标识符 56\n2.变量声明(\u003Cem\u003E名称\u003C\u002Fem\u003E、类型、值) 57\n3.常量声明 57\n(三)为变量和常量赋值 57\n1.赋值的位置 57\n2.赋值方式 57\n(四)作用域:可以访问该变量的程序部分 58\n7.3 PL\u002FSQL 块中的SQL 语句 58\n7.4 使用%TYPE和%ROWTYPE类型的变量 58\n1.%Type 59\n2.%RowType 59\n7.5 复合变量 60\n1.记录类型(“行”) 60\n2.记录\u003Cem\u003E表\u003C\u002Fem\u003E类型(“\u003Cem\u003E表\u003C\u002Fem\u003E” ) 60\n(1)使用的原因: 60\n(2)定义记录\u003Cem\u003E表\u003C\u002Fem\u003E类型(联合数组) 60\n7.6 条件判断语句 61\n(一)If语句 61\n(二)Case语句 62\n7.7循环语句 63\n1.“直到”循环 63\n2.当型循环(While) 63\n3.计数型循环(For) 63\n7.8游标 64\n(一)隐式游标 64\n1.含义: 64\n2.游标的属性:(获取游标的状态) 64\n3.另一种隐式游标 64\n(二)显示游标 64\n1.声明 64\n2.打开和关闭 65\n3.检索数据 65\n(三)游标For循环 65\n(四)游标变量 (动态游标) 66\n1.定义 66\n2.声明游标变量 66\n3.打开游标变量 66\n(五) 使用游标更新\u003Cem\u003E数据库\u003C\u002Fem\u003E 66\n7.9 异常处理 66\n(一)预定义异常 66\n(二)非预定义异常 67\n1.声明异常名 67\n2.将异常名与标准的Oracle错误号联系起来 67\n3.在Exception中对异常做处理 67\n(三) 用户自定义异常 68\n3.处理异常 68\nException 68\n(四)异常传播 68\n1.自定义异常的传播 68\n2.声明中的异常 68\n(五)使用SQLCODE和SQLERRM 68\n第八讲 过程、函数和程序包 72\n8.1存储过程(procedure) 72\n1.创建 72\n2.调用存储过程 72\n3.修改(\u003Cem\u003E替换\u003C\u002Fem\u003E同名的存储过程) 73\n4.\u003Cem\u003E参数\u003C\u002Fem\u003E 73\n(1)In \u003Cem\u003E参数\u003C\u002Fem\u003E:向过程传入\u003Cem\u003E一个\u003C\u002Fem\u003E值 73\n(2)Out\u003Cem\u003E参数\u003C\u002Fem\u003E: 73\n(3)In Out\u003Cem\u003E参数\u003C\u002Fem\u003E: 74\n(4)默认值 74\n5.局部变量和子过程 74\n8.2函数(function) 75\n1.创建 75\n2.调用函数 75\n8.3程序包(package) 76\n1.规范 76\n2.主体 76\n3.私有成员 77\n4.实例化 77\n5.重载 77\n6.管理程序包和执行权限 77\n8.4依赖性 78\n练习 78\n第九讲 索 引 80\n一.了解索引 80\n1.B树索引(Balanced) 80\n2.位图索引 80\n3.反向索引 81\n4.基于函数的索引 81\n二. 创建索引 81\n1.B树索引 81\n2.位图索引 81\n3.反向索引 81\n4.基于函数的索引 81\n三. 索引与约束 82\n第十讲 视图、序列和同义词 83\n一. 视图 83\n1.先关概念 83\n2.创建 83\n3.修改视图 84\n4.检索视图定义 84\n5.视图的编译 84\n6.视图的删除 84\n二. 可更新的视图 84\n三. 管理序列 84\n1.创建 85\n2.伪列 85\n3.修改序列 85\n4.\u003Cem\u003E查询\u003C\u002Fem\u003E序列 85\n5.删除序列 85\n四. 管理同义词 85\n1.同义词 86\n3.分类 86\n4.创建 86\n5.删除 86\n第11讲 触发器 88\n一. 触发器的组成 88\n1.组成 88\n2.事件 89\n二.触发器的类型 89\n1.DML触发器 89\n(1)格式 90\n(2)语句级触发器 90\n(3)多条件触发的条件谓词 91\n(4)行级触发器 92\n2.替代触发器(instead of) 92\n3.系统事件触发器 93\n三.Alter Trigger语句 94\n四.与触发器有关的数据字典 95\n第12讲 安 全 98\n一. 用户账号 98\n1.用户配置文件(概要文件) 98\n2.监视用户 98\n二. 权限管理 99\n(一)系统权限 99\n(二) 对象权限 ---9种 100\n三. 角色管理 101\n1.系统预定义角色 101\n2.自定义角色 101\n3.启用和禁用角色 102\n4.修改用户设置的角色 102\n5.删除角色 102\n四. 练习 102\n五. 练习 103\n六. 练习 104\n七. 练习 105\n第13讲 备份与恢复 106\n一.\u003Cem\u003E数据库\u003C\u002Fem\u003E备份概述 106\n1.备份和恢复 106\n2.备份的类型 106\n二. \u003Cem\u003E数据库\u003C\u002Fem\u003E备份模式 106\n三. 备份\u003Cem\u003E数据库\u003C\u002Fem\u003E 107\n(一)物理备份 107\n1.脱机备份 (无成本复制 copy paste) 107\n2.联机备份 24*7模式 108\n(二)逻辑备份 108\n1.Export 导\u003Cem\u003E出\u003C\u002Fem\u003E 108\n2.Import 导入 109\n四. \u003Cem\u003E数据库\u003C\u002Fem\u003E手动恢复 109\n1. 完全恢复 109","createTime":"2013-01-15 20:47:53","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-4998764-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-4998764-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"2\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fhsttmht\u002F4998764\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-4998764-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1715086686466_68342\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"2\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fhsttmht\u002F4998764\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-4998764-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1715086686466_68342\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fsuper_zhaowenke\u002F2190657","title":"ExtAspNet v2.2.1 (2009-4-1) 值得一看","desc":"ExtAspNet v2.2.1\n\t\nExtAspNet是一组专业的Asp.net控件库,拥有原生的AJAX支持和丰富的UI效果,\n目标是创建没有JavaScript,没有CSS,没有UpdatePanel,没有WebServices的Web应用程序。\n\n支持的浏览器: IE 7.0+, Firefox 3.0+, Chrome 2.0+, Opera 9.5+, Safari 3.0+\n\n注:ExtAspNet基于一些开源的程序ExtJS, HtmlAgilityPack, Nii.JSON, YUICompressor。\n\n示例: http:\u002F\u002Fextasp.net\u002F\n开源: http:\u002F\u002Fextaspnet.codeplex.com\u002F\n博客: http:\u002F\u002Fsanshi.cnblogs.com\u002F\n邮箱: sanshi.ustc@gmail.com\n\n\n发布历史:\n\n+2010-03-28 v2.2.1\n\t+为TabStrip的GetAddTabReference函数增加重载方法,以便指定Tab的图标(feedback:mmdcup)。 \n\t\t-修正此函数通过PageContext.RegisterStartupScript调用时不能正确显示Icon的BUG(feedback:zhaowenke)。\n\t-修正basic\u002Fhello.aspx示例在单独浏览器打开后,不能弹\u003Cem\u003E出\u003C\u002Fem\u003E对话框的BUG。\n\t-隐藏示例首页最外层RegionPanel的边框ShowBorder=\"false\"。\n\t+集成Extjs最新版本v3.1.1。\n\t\t-增加\u003Cem\u003E一个\u003C\u002Fem\u003E新的Theme - Access。\n\t\t-修正了Firefox下Zoom In\u002FOut时页面消失的BUG。\n\t\t-删除Panel的EnableLightBackgroundColor属性,同时EnableBackgroundColor只支持Blue和Gray两种Theme。\n\n\n\n+2010-01-31 v2.2.0\n\t-使得Asp.net的控件ImageButton具有和Asp.net的Button控件类似的行为(Ajax提交)(feedback:261629698)。\n\t+TabStrip增加GetAddTabReference和GetRemoveTabReference两个函数,用来向TabStrip控件动态增加删除Tab。\n\t\t-增加示例tabstrip\u002Ftabstrip_addtab.aspx。\n\t-重构了示例网站的架构,目前只有一层IFrame结构。\n\t-为TabStrip增加EnableTabCloseMenu属性,是否启用右键菜单,可用来关闭当前Tab和所有其他Tab。\n\t-为NumberBox增加DecimalPrecision属性,用来控制小数点后的位数(需要设置NoDecimal=\"false\")(feedback:zqmars)。\n\t-Window控件更新。\n\t\t-关闭按钮默认直接关闭,不会弹\u003Cem\u003E出\u003C\u002Fem\u003E确认对话框。\n\t\t-GetConfirmFormModifiedHideReference的函数中的ConfirmFormModified简化为Confirm,所以此函数更名为GetConfirmHideReference。\n\t\t-增加两个属性EnableConfirmOnClose(默认false),CloseAction(Hide, HideRefresh, HidePostBack)。\n\t\t-修正EnableMaximize属性不能使Window最大化的BUG,修正了双击标题栏不能最大化的BUG。\n\t-删除Button控件的SystemIcon属性,比如以前这样定义SystemIcon=\"Close\",现在需要这样定义Icon=\"SystemClose\"。\n\t-WindowPosition默认居中,而不是黄金分割位置。\n\t+Button, Window等控件弹\u003Cem\u003E出\u003C\u002Fem\u003E位置属性的变化。\n\t\t-Window的Target属性由\u003Cem\u003E字符串\u003C\u002Fem\u003E类型变为枚举类型,注意更新以前的代码:Target=\"_self\" -\u003E Target=\"Self\", Target=\"_parent\" -\u003E Target=\"Parent\"。\n\t\t-MenuButton, LinkButton, Button, LinkButtonField的ConfirmTarget属性由\u003Cem\u003E字符串\u003C\u002Fem\u003E变为枚举类型,可以取三个枚举值Self, Parent, Top。\n\t\t-Confirm.GetShowReference的最后\u003Cem\u003E一个\u003C\u002Fem\u003E\u003Cem\u003E参数\u003C\u002Fem\u003Etarget变为枚举类型。\n\t\t-Alert.GetShowReference中的showInParent\u003Cem\u003E参数\u003C\u002Fem\u003E也变为Target枚举类型。\n\t\t-MenuButton, LinkButton, Button, LinkButtonField增加ValidateTarget用来控制\u003Cem\u003E表\u003C\u002Fem\u003E单验证失败时提示对话框的显示位置。\n\n\n\n+2010-01-06 v2.1.9\n\t-集成Extjs最新版本v3.1.0。\n\t-修正灰色皮肤的CSS问题。\n\t-修正Grid的\u003Cem\u003E列名\u003C\u002Fem\u003E中不能包含中文字符的BUG(feedback:davidwen)。\n\t-为Web.config和PageManager增加属性AjaxTimeout(单位秒,默认30秒)。\n\t-修正了在Grid的PageIndexChange事件中不能获取SelectedRowIndexArray属性的BUG(feedback:Violet)。\n\t-Button控件将不再自动拥有display:inline属性,如果希望两个按钮在一行显示,请为第\u003Cem\u003E一个\u003C\u002Fem\u003E按钮设置CssStyle=\"float:left;\"属性。\n\t-修正了弹\u003Cem\u003E出\u003C\u002Fem\u003E菜单的位置在Firefox下不正确的BUG(feedback:eroach)。\n\t-为TriggerBox和TwinTriggerBox增加EnableEdit属性。\n\t-使用Hidden来显示隐藏ExtAspNet控件,而不是使用Visible属性(Visible目前设置为只读属性)。\n\t-使用Hidden控制Window控件的显示隐藏,Popup已经标记为Obsolete属性。\n\t-Window的实例方法GetCloseReference等以及ActiveWindow的静态方法GetCloseReference等,其中的Close全部改为Hide。\n\t-增加TabStrip中Tab控件可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。\n\t-修正绑定到Tree的XMLDocument中Icon属性映射错误(feedback:nopnop9)。\n\t-修正HtmlEditor不能编辑的BUG(feedback:TheBox)。\n\t-修正IE下有时会\u003Cem\u003E出\u003C\u002Fem\u003E现空白页面的情况(feedback:olivia919)。\n\t\n\t\n\n+2009-12-06 v2.1.8\n\t-修正了使用IFrame的Window关闭后不能再次打开的BUG(feedback:alexa99)。\n\t-修正了IE下Grid中的\u003Cem\u003E一个\u003C\u002Fem\u003EJS问题(feedback:lqm4108)。\n\t-修正Alert消息中引号未编码导致的JS错误(feedback:sun1299shine)。\n\t+集成extjs3.0.3。\n\t\t-修正弹\u003Cem\u003E出\u003C\u002Fem\u003E对话框的宽度计算错误(会保持最小的状态)。\n\t\t-增加新的皮肤Gray。\n\t-为示例工程添加改变语言和皮肤的下拉列\u003Cem\u003E表\u003C\u002Fem\u003E。\n\t-为PageContext增加静态函数Refresh,在切换语言和皮肤时使用。\t\n\n\n\n+2009-12-01 v2.1.7\n\t-增加示例(iframe\u002Fparent_postback_run3.aspx),如何通过简单的Javascript代码回发父页面(feedback:eroach)。\n\t-修正一些书写错误(feedback:bmck)。\n\t-从Region控件中删除SplitColor属性,增加CollapseMode, EnableSplitTip, SplitTip, CollapsibleSplitTip属性(feedback:bmck)。\n\t-BorderPanel更名为RegionPanel。\n\t-DropDownList拥有MarkInvalid方法(feedback:sun1299shine)。\n\t-增加中国的省市县三级联动示例(data\u002Fshengshixian.aspx)(feedback:Blues T)。\n\t-修正了使用IFrameUrl的Tab在切换过程中会重复加载的问题,这是\u003Cem\u003E一个\u003C\u002Fem\u003E在v2.1.6引入的问题(feedback:eroach)。\n\t-修正了启用AutoPostBack的Grid,其RowClick会覆盖LinkButtonField, HyperLinkField, CheckBoxField的点击事件(feedback:yymaoji)。\n\t\n\t\n\t\n+2009-11-26 v2.1.6\n\t+修正动态创建Grid列的BUG(feedback:gxpan)。\n\t\t-增加示例(data\u002Fgrid_dynamic_columns.aspx)。\n\t-修正Form不能自适应浏览器大小的改变(feedback:kaywood)(WorkItem#6309)。\n\t-增加重载方法Alert.Show(message, title, icon)(feedback:TheBox)(WorkItem#6353)。\n\t-为容器控件(比如Panel,Region,Tab等)增加AJAX属性IFrameUrl(feedback:BluesT)。\n\t-重新设计模拟树的下拉列\u003Cem\u003E表\u003C\u002Fem\u003E的实现,避免选中某项后的闪烁。\n\t\t\t\n\n\n+2009-11-21 v2.1.5\n\t+Tree优化。\n\t\t-修正Expanded项和Checked项的状态在回发改变后不能保持的BUG。\n\t\t-GetNodeById更名为FindNode,保持和FindControl一致命名。\n\t\t-删除CheckedNodeIDArray属性,增加GetCheckedNodes和GetCheckedNodeIDs函数。\n\t\t-删除ExpandedNodeIDArray属性,增加GetExpandedNodes和GetExpandedNodeIDs函数。\n\t\t-增加示例(data\u002Ftree_select_run.aspx),如何选中当前节点的所有子节点(feedback:wjl_wjl520)。\n\t\t+TreeNode的属性NodeId被重命名为NodeID,这是ExtAspNet中的\u003Cem\u003E一个\u003C\u002Fem\u003E命名约定。\n\t\t\t-同时更名的还有GridColumn的ColumnId-\u003EColumnID,GetColumnId-\u003EGetColumnID。\n\t\t\t-Grid1.Columns.FindColumnById函数被Grid1.FindColumn所替代。\n\t\t-为TreeCheckEventArgs,TreeExpandEventArgs,TreeCommandEventArgs增加Node属性。\n\t-为所有控件增加Focus(覆盖Control默认的Focus函数)和GetFocusReference函数。\n\t-增加示例(other\u002Fcustom_postback.aspx)(feedback:thebox)。\n\t\t-如何自定义Javascript脚本和C#处理函数来响应键盘事件。\n\t-为Tree增加AutoLeafIdentification属性。\n\t\t-增加示例(tree_auto_leaf_identification.aspx)(feedback:wdrabbit)。\n\t\n\t\n\n+2009-11-17 v2.1.4\n\t-修正Window的关闭按钮提示信息一直是中文的BUG(feedback:thebox)。\n\t-部分ExtAspNet控件的设计时支持(会在后续版本中逐步完善)。\n\t-v0.2beta2版本中关于PersistChildren(true)的描述有误,这个是设计时属性,和运行时是否保持状态没有关系。\n\t-修正CheckBox控件的CheckedChanged事件会被触发两次的BUG(Data PostBack-\u003EAutoPostBack, Event PostBack-\u003EEnablePostBack)。\n\t-为TextBox,TextArea,DatePicker,NumberBox,TriggerBox等控件增加AutoPostBack属性(feedback:dk3214)。\n\t+为\u003Cem\u003E表\u003C\u002Fem\u003E单字段增加RequiredMessage,MaxLengthMessage,MinLengthMessage属性,用于指定验证失败时提示信息。\n\t\t-为空则使用默认的提示信息,默认的提示信息支持多语言,建议一般情况下使用默认信息。\n\t+为\u003Cem\u003E表\u003C\u002Fem\u003E单字段增加MarkInvalid和GetMarkInvalidReference函数(feedback:sun1299shine)。\n\t\t-增加示例:form\u002Fform_validate.aspx\n\t\n\t\n\n+2009-10-19 v2.1.3\n\t+增加支持在AJAX时改变的控件属性列\u003Cem\u003E表\u003C\u002Fem\u003E(\u002Fajax.aspx)。\n\t\t-ExtAspNet支持原生的AJAX,也就是说控件的属性改变在AJAX过程中会反映到页面中,但并不是所有的控件属性都支持AJAX改变。\n\t-加载s.gif图片在本机进行,不会请求extjs.com远程资源(feedback:efrigate43,abaocoole)。\n\t-在AJAX回发后确保Asp.net的按钮控件仍然具有AJAX的特性。\n\t-更新\u002Fbasic\u002Flogin.aspx示例,使用验证图片(feedback:kedee)。\n\t-为Grid增加AutoPostBack属性和RowClick事件,示例在\u002Fdata\u002Fgrid_autopostback.aspx(feedback:chenguizhu2006)。\n\t-为所有的\u003Cem\u003E表\u003C\u002Fem\u003E单字段增加AJAX属性ReadOnly(feedback:skydb)。\n\t-Grid中TemplateField生成到页面中控件具有唯一ID,例如Grid1_ct5_Label2,Grid1_ct6_Label2(feedback:geruger)。\n\t\n\t\n\n+2009-09-27 v2.1.2\n\t-为Tree控件增加GetExpandAllNodesReference和GetCollapseAllNodesReference两个函数。\n\t-修正RELEASE版本下多语言加载的BUG(feedback:yigehaoren)。\n\t-增加pt_BR语言,由Ujvari提供。\n\t+为所有Panel(包括Grid,Tree,Form等)增加枚举类型Icon,其中包含1700多个小图标。\n\t\t-如果Panel具有IconUrl属性,则IconUrl优先于Icon。\n\t\t-所有Icon的列\u003Cem\u003E表\u003C\u002Fem\u003E在icon.aspx。\n\t-为Button,MenuItem(MenuButton,MenuHyperLink),AccordionLink,TreeNode,Image(如果ImageUrl为空,则取Icon的值)增加Icon属性。\n\t\n\t\n\n+2009-09-15 v2.1.1\n\t-修正不能动态修改AccordionPane属性Items的BUG。\n\t+为Button, MenuButton, LinkButton, LinkButtonField增加ConfirmTarget。\n\t\t-如果需要在父页面弹\u003Cem\u003E出\u003C\u002Fem\u003E确认对话框,需要设置ConfirmTarget=\"_parent\"(类似Window控件的Target=\"_parent\")。\n\t+为ExtAspNet.Alert.Show增加点击确定的JavaScript回调函数。\n\t\t-\u003Cem\u003E一个\u003C\u002Fem\u003E典型应用,在Window控件中打开新页面,如果传递的\u003Cem\u003E参数\u003C\u002Fem\u003E不正确,则首先提示\u003Cem\u003E参数\u003C\u002Fem\u003E不对然后关闭此弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口。\n\t\t-ExtAspNet.Alert.Show(\"\u003Cem\u003E参数\u003C\u002Fem\u003E错误!\", String.Empty, ExtAspNet.ActiveWindow.GetCloseReference());\n\t+TreeNode的前面的多选框可以自动回发了。\n\t\t-为TreeNode增加AutoPostBack属性,增加事件数据类TreeCheckEventArgs,为Tree增加事件NodeCheck。\n\t\t-示例在:http:\u002F\u002Fextasp.net\u002Fdata\u002Ftree_run.aspx\n\t-Grid增加GetNoSelectionAlertInParentReference函数,用来\u003Cem\u003E表\u003C\u002Fem\u003E示没有选中任何一项时在父页面弹\u003Cem\u003E出\u003C\u002Fem\u003E对话框的JS代码。\n\t-修正IE7下不能以下划线作为CSS中类名的前缀的BUG(feedback:Steve.Wei)。\n\t-添加定时器控件Timer,用来定时发起AJAX请求。\n\t\n\t\n\n+2009-09-06 v2.1.0\n\t-Button的Pressed属性值能够正确的反映客户端的变化。\n\t-优化Tree控件的AJAX实现。\n\t+为页面的Form添加autocomplete=\"off\"属性。\n\t\t-参考http:\u002F\u002Fwww.cnblogs.com\u002Fsanshi\u002Farchive\u002F2009\u002F09\u002F04\u002F1560146.html#1635830\n\t+添加对extjs3.0中所有语言的支持。\n\t\t-ExtAspNet扩展的多语言包在js\\languages\\extaspnet目录下,目前只有en,zh_CN,zh_TW三种实现\n\t\t-你可以向其中添加自己的语言版本,并执行js\\languages下的pack.bat打包,最后编译工程。\n\t\n\t\n\t\n+2009-09-01 v2.0.9\n\t-为ExtAspNet.Alert添加两个静态方法ShowInParent和GetShowInParentReference,用于在父页面弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口。\n\t+在aspx页面中必须显示的声明控件的集合属性(比如Tabs(TabStrip), Items(PanelBase), Nodes(TreeNode))。\n\t\t-这将会影响所有的aspx页面,所以要特别关注。\n\t-重命名AccordionPanel为AccordionPane (这也是在Asp.net AJAX中使用的\u003Cem\u003E名称\u003C\u002Fem\u003E).\n\t+所有的面板默认有两个集合属性(Toolbars和Items).\n\t\t-尽管TabStrip, From, Tree, Accordion继承了Items属性,但是你并不能对其设置(此时Items是只读的).\n\t\t-这将会影响所有的aspx页面,一定要将工具条(Toolbars)和Items区分开来。\n\t-祝你生日快乐 - 小师妹妹。\n\n\n\n+2009-08-29 v2.0.8\n\t-ExtAspNet支持多语言(en,zh_CN,zh_TW),可以在Web.config中修改。\n\t-将所有的示例转化为英语版本。\n\t-修正Tree控件的\u003Cem\u003E一个\u003C\u002Fem\u003EBUG(定义Mappings属性时)。\n\t+PageManager.Instance应该存在于HttpContext.Current,而不是\u003Cem\u003E一个\u003C\u002Fem\u003E全局变量。\n\t -这个BUG导致Asp.net compatibility中的示例无法完成,现在已经修正。\n\t+去除PageManager中方法AddAjaxAspnetControls,增加属性AjaxAspnetControls。\n\t -这个属性和Button得ValidateForms属性类似,可以查看Asp.net compatibility中的示例。\n\t\n\t\n\n+2009-08-25 v2.0.7\n -为按钮增加DisableControlBeforePostBack属性 - 回发之前是否禁用按钮,防止重复提交 - 默认为true。\n -Grid的Values属性访问限制由internal改为public,这就意味这可以自由改变Grid中每个单元格的值了。\n -增加示例-如何将Grid控件导\u003Cem\u003E出\u003C\u002Fem\u003E为Excel(data\\grid_excel_run.aspx)(feedback:503684912)。\n -如果TreeNode的属性Enabled=\"false\",则此项变灰并且不会被选中(feedback:your568)。\n -修正TreeNode的属性NavigateUrl不接受服务器端URL(以~\u002F开头)的BUG。\n -增加Accordion和Tree配合使用的示例(other\\accordion_tree_run.aspx)。\n -修正Panel图标不能显示的BUG(CSS中class名不能有$字符)。\n +去除PageLayout控件,此控件可以使用BorderLayout和指定PageManager的AutoSizePanelID属性来代替。\n\t\t-这样所有需要占据全屏的Panel(不管你是Accordion,Panel,ContentPanel,Form,GroupPanel,SimpleForm,Tree还是Grid,TabStrip)都可以通过这种方式全屏。\n\t\t-简单方便,示例可以参考 default.aspx 或者 other\\accordion_tree_run.aspx。\n \n \n\n+2009-08-14 v2.0.6\n\t-动态生成菜单实例(other\\menu_dynamic_run.aspx和other\\menu_dynamic2_run.aspx)(feedback:shguo)。\n\t-优化AJAX的内部实现,每个页面保存的ViewState现在减少1\u002F3左右(重要更新)。\n\t-优化Tree节点的NodeId自动生成,减少ViewState占用。\n\t\n\n\n+2009-08-09 v2.0 beta5\n\t+ExtAspNet和Asp.net的提交按钮兼容问题(feedback:千帆)。\n\t\t-在2009-03-03 v1.3.0曾经提到这个兼容问题,并有这样的规则,如果Asp.net的按钮AJAX提交,必须设置UseSubmitBehavior=\"false\"\n\t\t--也就是说生成的input的type不能是\"submit\",而这个限制在有些情况下是不可原谅的。\n\t\t--我们做了优化,现在要使\u003Cem\u003E一个\u003C\u002Fem\u003EAsp.net的按钮能够AJAX提交,你不需要做任何设置(PageManager的属性EnableAjax为true即可,这是默认属性)。\n\t+PageManager的实例方法AddAjaxUpdateControl改名为AddAjaxAspnetControls,现在可以在Page_Load中设置需要在AJAX中需要更新的Asp.net控件了。\n\t\t-在Page_Load中设置了哪些需要在AJAX中更新的Asp.net控件会在回发时保持状态,可以通过RemoveAjaxAspnetControls来去除不需要更新的控件。\n\t\t-示例在aspnet\\fckeditor_run.aspx和aspnet\\aspnet_run.aspx。\n\t\t-FCKEditor和上传控件兼容。示例在aspnet\\fileupload_run.aspx。\n\t-修正ToolbarText的文本在AJAX下更新的BUG。\n\t-Button的Pressed属性在AJAX可更新(feedback:mgzhenhong)。\n\t-更新所有示例。在IE7.0,IE8.0,Firefox3.5,Chrome2.0下测试通过。\n\t\n\n\n+2009-08-02 v2.0 beta4\n\t+和Asp.Net的Forms Authentication兼容[feedback:mgzhenhong]。\n\t\t-采用和Asp.Net Ajax类似的处理方式,需要在配置文件Web.config增加\u003Cem\u003E一个\u003C\u002Fem\u003EhttpModules。\n\t\t-现在支持Response.Redirect,你可以选择Response.Redirect或者ExtAspNet.PageContext.Redirect重定向页面,两者效果一样。\n\t\t-支持FormsAuthentication.RedirectFromLoginPage(accountID, false);这样的方法。\n\t-Button增加Type属性(button,reset,submit)[feedback:mgzhenhong]。\n\t-修正Alert.Show方法不能指定文本前图片的BUG[feedback:xmq&mgzhenhong]。\n\t-修正IE下某些弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口的IFrame第一次不能加载的BUG。\n\t-增加Menu和Accordion的示例。\n\t-修正Window控件的IconUrl有时不显示(Target=\"_parent\")的BUG[feedback:xmq&mgzhenhong]。\n\t\n\n\n+2009-07-22 v2.0 beta3\n\t-兼容FCKEditor。\n\t-在IE8.0,Firefox3.5下测试通过。以后ExtAspNet将不会对IE6.0提供支持。\n\t\n\n\n+2009-07-13 v2.0 beta2\n\t-集成extjs最新版本v3.0。\n\t+兼容IE6.0-7.0-8.0。\n\t\t-这应该是Extjs3.0的\u003Cem\u003E一个\u003C\u002Fem\u003EBUG,在IE6.0-7.0下面设置Ext.QuickTips.init();会导致button的click事件无法响应(IE8下无此问题)。\n\t\t-目前先禁用IE6.0-7.0的QuickTips。\n\t-优化底层JavaScript。\n\t\n\t\n\t\n+2009-07-05 v2.0 beta1\n\t-更新extjs库到最新版本v3.0 RC2; 目前只有\u003Cem\u003E一个\u003C\u002Fem\u003E缺省皮肤(Theme)。\n\t-使用YUI Compressor压缩JavaScript和CSS文件。\n\t-Release版本每个页面只包含\u003Cem\u003E一个\u003C\u002Fem\u003EJavaScript文件(语言文件除外)和\u003Cem\u003E一个\u003C\u002Fem\u003ECSS文件。\n\t-ExtAspNet自身的CSS会紧挨着页面\u003Ctitle\u003E标签引入,这样在\u003Chead\u003E中自定义的样式可以覆盖ExtAspNet缺省样式。\n\t+Alert对话框会遮挡所有的Window窗口。\n\t\t-使用\u003Cem\u003E一个\u003C\u002Fem\u003E变通的方法解决,因为无法改变Ext.Message的默认z-index(9000)所以将box.window_default_group的zseed调整为6000。\t\n\t-为所有按钮的左右增加5px的空白边距:.x-btn button { margin: 0 5px !important; }。\n\t-因为下拉列\u003Cem\u003E表\u003C\u002Fem\u003E不可编辑,所以不能为空,如果不设置SelectedIndex或SelectedValue,则默认选中第一项。\n\t-重新绑定模拟树的下拉列\u003Cem\u003E表\u003C\u002Fem\u003E后,选中项的前面有图片的HTML标签的BUG。\n\t-更新自定义JavaScript组件Ext.ux.SimplePagingToolbar。\n\t-更新示例工程。\n\t\n\t\n\n+2009-03-25 v1.3.1\n\t-Tree在AJAX回发展开节点时JS错误[feedback:xlli]。[fixed]\n\t-Window中的EnableIFrame==false,则点击关闭按钮时报JS错误。[fixed]\n\t-页面包含FileUpload控件,需要点击按钮回发并上传文件,则不能采用原生AJAX方式。(参见示例aspnet\u002Ffileupload.aspx)[fixed]\n\t-HtmlEditor显示隐藏工具栏按钮不起作用,HtmlEditor目前不支持Enabled和Readonly两个属性。[fixed]\n\t\n\t\n\n+2009-03-03 v1.3.0\n\t-如果弹\u003Cem\u003E出\u003C\u002Fem\u003E的窗口(Ext-Window)含有ASP.NET控件FileUpload,则此弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口在关闭时\u003Cem\u003E出\u003C\u002Fem\u003E现JS错误(http:\u002F\u002Fextjs.com\u002Fforum\u002Fshowthread.php?t=8129)[feedback:xlli]。[fixed]\n\t-如果页面中存在ASP.NET控件(TextBox),则第二次提交\u003Cem\u003E表\u003C\u002Fem\u003E单就会报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的问题)。[fixed]\n\t-页面上放置ExtAspNet-Button和ASP.NET-Button,则点击ExtAspNet-Button时激发的是ASP.NET-Button的事件,这个BUG和Extjs2.2.1中Ext.Ajax.serializeForm的实现有关。[fixed]\n\t-ExtAspNet内部包含HtmlAgilityPack和Nii.JSON两个开源的第三方类库。[added]\n\t+如果以前你听过不要在ExtAspNet工程中使用ASP.NET标准控件的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在ExtAspNet控件和ASP.NET标准控件和平共处了。[fixed]\n\t\t-如果\u003Cem\u003E一个\u003C\u002Fem\u003EASP.NET按钮控件要使用ExtAspNet的原生AJAX,只需要设置属性 UseSubmitBehavior=\"false\" 即可。\n\t\t-如果要在一次ExtAspNet的原生AJAX回发时更新ASP.NET控件的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:aspnet\u002Faspnet.aspx)。\n\n\n\n+2009-02-27 v1.2 beta9\n\t-网络连接\u003Cem\u003E出\u003C\u002Fem\u003E错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接\u003Cem\u003E出\u003C\u002Fem\u003E错,请刷新页面重试。”。[fixed]\n\t-自动测试功能会在以后版本中逐步完善。这个版本完成测试框架,采用Extjs中JS函数进行大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed]\n\t+系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed]\n\t\t-底层使用Javascript创建\u003Cem\u003E一个\u003C\u002Fem\u003EWindow控件的代码由原来的2000字符减少为500个字符。\t\n\t\t-PageContext静态类中的GetPageStateChangedFunction改名为GetConfirmFormModifiedReference,底层代码优化。\u003Cem\u003E表\u003C\u002Fem\u003E示“获取当前页面中\u003Cem\u003E表\u003C\u002Fem\u003E单修改的确认提示框的脚本”。\n\t\t---[updated]删除PageContext中的GetConfirmFormModifiedReference,使用CurrentActiveWindow中的GetConfirmFormModifiedCloseReference\u002FGetConfirmFormModifiedCloseRefreshReference\u002FGetConfirmFormModifiedClosePostBackReference三个方法代替。\n\t\t-不会修改弹\u003Cem\u003E出\u003C\u002Fem\u003E页面的URL(Ext-Window中的IFrame),以前为了实现功能为每个弹\u003Cem\u003E出\u003C\u002Fem\u003E页面添加box_parent_client_id\u003Cem\u003E查询\u003C\u002Fem\u003E\u003Cem\u003E字符串\u003C\u002Fem\u003E\n\t\t-去除PageManager的RegisterPageStateChangedScript属性,现在已经将这个功能实现为静态的JS方法。可以通过PageContext.GetFormModifiedConfirmReference获取此方法的客户端脚本。\n\t\t---注意:以前的项目需要在所有的ASPX页面中查找RegisterPageStateChangedScript属性,并删除,否则会运行错误!\n\t\t-A页面有Ext-Window控件弹\u003Cem\u003E出\u003C\u002Fem\u003EB页面,B页面有Ext-Window控件弹\u003Cem\u003E出\u003C\u002Fem\u003EC页面,B页面的Ext-Window控件设置Target='_parent',则弹\u003Cem\u003E出\u003C\u002Fem\u003E的Ext-Window(C页面)会覆盖整个A页面,这是正确的。\n\t\t---当时如果用户直接访问B页面,就会报JS错误,因为此时找不到B页面的父页面A了。现在的版本修正为如果找不到父页面,则就在当前页面弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口,这样用户直接访问B页面也不会\u003Cem\u003E出\u003C\u002Fem\u003E错了。\n\t\t-Window控件的GetIFramePageStateChangedFunction函数改名为GetConfirmFormModifiedCloseReference,\u003Cem\u003E表\u003C\u002Fem\u003E示“获取先确认IFrame的页面中\u003Cem\u003E表\u003C\u002Fem\u003E单改变,然后关闭弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口的客户端脚本”。\n\t\t---为Window控件增加如下两个方法GetConfirmFormModifiedCloseRefreshReference和GetConfirmFormModifiedClosePostBackReference,\u003Cem\u003E表\u003C\u002Fem\u003E示“先确认\u003Cem\u003E表\u003C\u002Fem\u003E单改变,然后关闭弹\u003Cem\u003E出\u003C\u002Fem\u003EExt-Window,再然后刷新父页面或回发父页面”。\n\t\t---Window控件的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirmFormModifiedCloseReference,也即是先判断\u003Cem\u003E表\u003C\u002Fem\u003E单是否更新,然后在关闭窗口。\n\t\t---现在可以很方便的为Window控件的关闭按钮添加关闭后刷新父页面或者关闭后回发父页面的行为。\n\t\t-如果弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口(Window控件)中IFrame的页面不能正常加载(网络暂时\u003Cem\u003E出\u003C\u002Fem\u003E错或页面抛\u003Cem\u003E出\u003C\u002Fem\u003E异常),则此时点击右上角的关闭按钮会报JS错误,因为此时页面尚未加载完毕。\n\t\t---此版本修正了这个BUG,即时页面不能加载完全,也能通过右上角的关闭按钮关闭弹\u003Cem\u003E出\u003C\u002Fem\u003E含IFrame的窗体。\n\t\t-Window控件的IFrameName属性是自动生成的,只读属性。(因为有可能所有的Ext-Window最终都渲染到最外层的页面,为了保证这些IFrame的name不同,IFrameName使用的是GUID,内部处理)。\n\t\t-CurrentActiveWindow改名为ActiveWindow。\n\t\t-[特别注意]GetWriteBackValueReference(string controlClientIds, string value, params string[] values)函数现在的定义是GetWriteBackValueReference(params string[] values)\n\t\t---所有调用GetWriteBackValueReference的地方,需要删除第\u003Cem\u003E一个\u003C\u002Fem\u003E\u003Cem\u003E参数\u003C\u002Fem\u003E(一般是ActiveWindow.GetLoadStateReference())。\n\t\t\n\t\n\n+2009-02-23 v1.2 beta8\n\t-ContentPanel中内容不能自动扩展高度的BUG[feedback:huihuang]。[fixed]\n\t-DropDownList在Ajax回发时不能计算模拟树的数据[feedback:huihuang]。[fixed]\n\t-DropDownList在页面第一次加载时没有不可选择项,则回发时也不会有不可选择项的BUG。[fixed]\n\t-升级底层ExtJS类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏问题的修正)。[fixed]\n\t-页面加载过程中的时间信息保存在Javascript变量window.box.timeInfo中。[added]\n\t+增加部分自动测试支持(使用WatiN和NUnit),下个版本将会提供完整的自动测试支持。[fixed]\n\t\n\t\n\n+2008-10-28 v1.2 beta7\n\t-DropDownList没有选中任何一项,回发时报错[feedback:huihuang]。[fixed]\n\t-Window显示位置不对,以及不能拖动的BUG[feedback:huihuang]。[fixed]\n\t+PageContext优化。[fixed]\n\t\t-去除RegisterExclusiveScript静态函数(这是没有原生ajax之前的产物),使用RegisterStartupScript替代。\n\t\t-去除RegisterStartupScript的重载函数,只保留最简单的PageContext.RegisterStartupScript(string script)函数。\n\t\t-Resirect增加重载函数Redirect(string url, string target),其中target可能的取值为_self,_parent,_top,分别\u003Cem\u003E表\u003C\u002Fem\u003E示在当前窗口,父窗口,顶级窗口重定向[feedback:jqpeng]。\n\t-Image控件增加ImageWidth\u002FImageHeight\u002FImageCssStyle\u002FImageCssClass\u002FImageAlt属性[feedback:jqpeng]。[fixed]\n\t-发布包中增加\u003Cem\u003E一个\u003C\u002Fem\u003EWeb.config.txt,这是\u003Cem\u003E一个\u003C\u002Fem\u003E空的Web.config文件,包含BOX基本的配置信息。[fixed]\n\t-ContentPanel的ShowHeader和ShowBorder属性默认也是true(注意更新以前的应用)。[fixed]\n\t-Row和Column布局时,修正IE下设置RowHeight=\"100%\"时显示不正确的BUG。[fixed]\n\t-AccordionLink当鼠标移上和移开时,有背景色的变化效果[feedback:huihuang]。[fixed]\n\t+TabStrip的Tab控件的EnablePostBack属性会在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此Tab都会回发)。[fixed]\n\t\t-有这样\u003Cem\u003E一个\u003C\u002Fem\u003E效果,如果Tab1默认显示,Tab1的EnablePostBack=true,则页面加载完毕后会回发Tab1一次。\n\t\n\t\n\n+2008-10-20 v1.2 beta6\n\t+使用控件的站点必须建立虚拟目录,否则会报JS错误(即是脚本资源没有加载),却原来是HTTPCompress组件的问题。[fixed]\n\t\t-需要\u003Cem\u003E替换\u003C\u002Fem\u003E新的blowery.Web.HttpCompress.dll,解决方案见http:\u002F\u002Fpohee.com\u002Fit\u002Fhttp-compression-in-aspnet-20\u002F。\n\t+DropDownList优化。[fixed]\n\t\t-去除EnableFirstItem\u002FFirstItemText\u002FFirstItemValue,这个并不能带来很大的好处,反而容易让开发人员困惑。\n\t\t 现在可以方便的在后台DropDownList1.Items.Insert(0, new ExtAspNet.ListItem(\"全部\", \"-1\"));来达到同样的效果。\n\t\t+如果某项(ListItem)的Value为空\u003Cem\u003E字符串\u003C\u002Fem\u003E,则通过SelectedIndex和SelectedValue不能选中[feedback:jqpeng]。\n\t\t\t-和Asp.net中的保持一致,ListItem的Value值可以为空\u003Cem\u003E字符串\u003C\u002Fem\u003E。 也就是可以这样写DropDownList1.SelectedValue = \"\";\n\t\t-ListItemCollection增加重载函数Add(string text, string value),这样方便后台添加列\u003Cem\u003E表\u003C\u002Fem\u003E项。\n\t-处于布局内的容器控件(Layout!=LayoutType.Container),AutoHeight会自动设置为false(避免开发人员发生此类错误)。[fixed]\n\t-注意,控件的高度指的是整个控件的高度,包含BodyPadding(这和CSS中的height不同,CSS中的height是指内容的高度,除去padding\u002Fborder-width\u002Fmargin)。[fixed]\n\t+为所有控件属性增加在VS中的智能提示。[fixed]\n\t\t-需要将ExtAspNet.XML和ExtAspNet.dll放在一起,这样引用dll时xml会被拷贝到bin目录下,提供VS的智能提示。\n\t+控件的属性如果是枚举类型,如果此属性可以不取值,则默认为None。[fixed]\n\t\t-TriggerIconType.Default -\u003E TriggerIconType.None\n\t\t-SystemIconType.Empty -\u003E SystemIconType.None\n\t\t-RegexPattern.USER_DEFINED -\u003E RegexPattern.None\n\t-\u003Cem\u003E表\u003C\u002Fem\u003E单验证属性\u003Cem\u003E名称\u003C\u002Fem\u003E变化(ValueToCompare-\u003ECompareValue,ControlToCompare-\u003ECompareControl)。[fixed]\n\t+注意:\u003Cem\u003E一个\u003C\u002Fem\u003E属性可以拥有多个值的情况。[fixed]\n\t\t-属性和CSS相关则用空格分隔(比如ColumnWidths,BodyPadding)。\n\t\t-其他的都是逗号分隔(比如ValidateForms,DataKeyNames,DataNavigateUrlFields)。\n\t+AccordionLink实现为控件。[fixed]\n\t\t-可以方便的在子页面(iframe)中通过js切换父页面中选中的菜单项(Accordion-\u003EAccordionLink)(示例在other\u002Faccordion_links_run.aspx,other\u002Faccordion_links_run_iframe_htm)[feedback:jima]。\n\t+确认:可以方便的动态添加控件,并且可以给控件添加服务器端事件(示例在form\u002Fform_dynamic_run.aspx)。[fixed]\n\t\n\t\n\t\n+2008-10-15 v1.2 beta5\n\t-验证\u003Cem\u003E表\u003C\u002Fem\u003E单字段的ValueToCompare属性,为\u003Cem\u003E字符串\u003C\u002Fem\u003E时会\u003Cem\u003E出\u003C\u002Fem\u003E错的BUG。[fixed]\n\t+优化下拉列\u003Cem\u003E表\u003C\u002Fem\u003E。[fixed]\n\t\t-验证下拉列\u003Cem\u003E表\u003C\u002Fem\u003E时,应该取ListItem的Value属性进行验证,而不是Text属性。\n\t\t-DropDownList的Items增加Insert方法(可方便的下拉列\u003Cem\u003E表\u003C\u002Fem\u003E选项添加“全部”)。\n\t\t-DropDownList不支持EmptyText属性。\n\t\t-ListItem启用EnableSelect和SimulateTreeLevel属性,这样就可以直接在前台(ASPX)中设置哪些项不可选择,以及创建模拟下拉树。\n\t\t-DropDownList增加EnableSimulateTree属性(默认为false),如果设置了DataSimulateTreeLevelField,则自动将EnableSimulateTree设置为true。\n\t\n\t\n\n+2008-09-27 v1.2 beta4\n\t+EnableLargeHeader属性对所有容器的效果一样,Accordion的属性EnableLargeHeader只会改变Accordion的标题大小,而不会对AccordionPanel起作用(示例见other\u002Faccordion_run.aspx)。[fixed]\n\t\t-Accordion去除EnableHightlight属性,AccordionPanel增加EnableHightlight属性。\n\t\t-影响以前使用Box的应用,需要将Accordion的属性去掉,然后为每个AccordionPanel增加EnableLargeHeader和EnableHightlight属性。\n\t-AccordionPanel鼠标移上去的样式调整(现在没有下面的一条白线了)。[fixed]\n\t+AccordionPanel增加Links属性,可以绑定列\u003Cem\u003E表\u003C\u002Fem\u003E数据到AccordionPanel,呈现的是链接的列\u003Cem\u003E表\u003C\u002Fem\u003E(示例在other\u002Faccordion_links_run.aspx)。[fixed]\n\t\t-原来放置在AccordionPanel中的容器,比如ContentPanel需要在外层加上\u003CItems\u003E标签。\n\t\t-适当增大AccordionPanel中链接的高度20px-\u003E22px,同时对链接的样式也做了微调。\n\t\t-通过BodyPadding控制链接列\u003Cem\u003E表\u003C\u002Fem\u003E的边距。\n\t\t-这样能大大减少ASPX中HTML代码和Javascript代码的书写,可以在后台动态添加链接,效果很赞,此需求由马季提\u003Cem\u003E出\u003C\u002Fem\u003E。\n\t\n\t\n\t\n+2008-09-25 v1.2 beta3\n\t+代码优化与设计时支持(尚需要不断完善,目前可以在ASPX页切换到“设计时”,方便属性的更改和事件处理函数的添加)。[fixed]\n\t\t-Panel\u002FGroupPanel\u002FContentPanel\u002FTree\u002FHiddenField\u002FPageLoading\n\t\t-TabStrip\u002FToolbar\n\t-TabStrip去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed]\n\t-向Form中动态添加控件的BUG,现在form\u002Fform_dynamic_run.aspx示例已经能正确运行。[fixed]\n\t+大部分容器的子控件集合更正为Items(以前有些是Rows)。[fixed]\n\t\t-影响的控件包括Toolbar\u002FAccordion\u002FAccordionPanel\u002FGroupPanel\u002FPanel\u002FSimpleForm\u002FWindow等。\n\t\t-保留Form的Rows(FormRowCollection)属性和Grid的Rows属性(GridRowCollection)。\n\t\t-保留TabStrip的Tabs(TabCollection)属性。\n\t\t-保留PageLayout\u002FBorderLayout的Regions(RegionCollection)属性。\n\t-预祝今晚神七发射成功。\n\t\n\t\n\t\n+2008-09-22 v1.2 beta2\n\t+Grid选中项(SelectedRowIndexArray)在ajax回发过程中存在BUG [feedback:xmzhu]。[fixed]\n\t\t-\u003Cem\u003E表\u003C\u002Fem\u003E现为对Grid进行多次删除添加操作后,SelectedRowIndexArray选中项中会存在当前不存在的行序号,导致服务器端遍历选中项时数组越界。所有使用box控件的应用程序都受到此BUG的影响,需尽快更新到新版本。\n\t+代码优化与设计时支持(示例中\u003Cem\u003E表\u003C\u002Fem\u003E单控件都已支持设计)。[fixed]\n\t\t-PageManager\u002FSimpleForm\u002FButton\u002FHyperLink\u002FLabel\u002FImage\u002FLinkButton\u002FTextBox\n\t\t-TriggerBox\u002FTwinTriggerBox\u002FWindow\u002FTextArea\u002FHtmlEditor\u002FDatePicker\u002FNumberBox\n\t\t-CheckBox\u002FRadioButton\u002FRadioButtonList\u002FDropDownList\n\t\t-Grid\n\n\n\n+2008-09-19 v1.2 beta1\n\t-Image\u002FLinkButton\u002FHyperLink增加一些Ajax可更新属性。[fixed]\n\t+隐藏的方式由HideMode属性控制Visibility\u002FOffsets\u002FDisplay。[fixed]\n\t\t-修正Form\u002FSimpleForm中隐藏\u003Cem\u003E一个\u003C\u002Fem\u003E\u003Cem\u003E表\u003C\u002Fem\u003E单字段(Hidden=false)会占据页面空间的BUG。\n\t-ToolbarText\u002FToolbarFill\u002FToolbarSeparator在ASPX中设置Hidden=true不起作用的BUG [feedback:jbzhang]。[fixed]\n\t-Button去除MarginRight属性(可以通过CssStyle=\"margin-right:5px;\"达到相同的效果)[fixed]\n\t\n\t\n\t\n+2008-09-09 v1.1\n\t+Toolbar去除IsPageMenu属性,在网报中可以用自定义样式实现,而不应该写在控件中。[fixed]\n\t\t-网报:CssClass=\"toolbar-pagemenu\" CssStyle=\"border:0px;\",同时定义样式:.toolbar-pagemenu{ background: rgb(208, 222, 240) url(..\u002Fimages\u002Fpagemenu_toolbar_background.gif) repeat-x left top;}。\n\t-Region去除默认的Layout=Fit,如果希望Region使用Fit\u002FAnchor\u002FColumn\u002FRow等布局的话,需要手工指定。[fixed]\n\t-ToolbarSeparator\u002FToolbarFill在Ajax更新Hidden属性的BUG。[fixed]\n\t+布局整理。[fixed]\n\t\t-新增Column\u002FAbsolute\u002FRow三种布局,加上以前的Container\u002FFit\u002FAnchor\u002FAccordion\u002FBorder\u002FForm六种布局,总共有9中布局可供使用。\n\t\t-其中一些控件默认使用一种布局:SimpleForm(Form)\u002FForm(Form)\u002FPanel-GroupPanel(Container)\u002FAccordion(Accordion)\u002FPageLayout(Border)\u002FBorderLayout(Border)\u002FTabStrip(Card),所有布局控件默认的布局是Container。\n\t\t-经常用到的布局控件:SimpleForm\u002FForm\u002FAccordion\u002FTabStrip\u002FBorderLayout,经常用到的布局:Fit\u002FRow\u002FAnchor\n\t\n\t\n\t\n+2008-09-08 v1.1 beta7\n\t-MenuButton\u002FMenuHyperLink增加HideOnClick属性,如果\u003Cem\u003E一个\u003C\u002Fem\u003E菜单项的作用仅仅为了弹\u003Cem\u003E出\u003C\u002Fem\u003E下级菜单,点击没反应,则可以这样设置HideOnClick=\"false\" CssStyle=\"cursor:default;\" [feedback:huayu]。[fixed]\n\t-MenuButton\u002FMenuHyperLink\u002FMenuSeparator\u002FMenuText增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed]\n\t+大部分的ExtAspNet控件增加Hidden属性(少数几个控件没有此属性:Menu),这样在Ajax时可以显示隐藏控件。[fixed]\n\t\t-注意Visible和Hidden的区别:Visible=false的属性不会渲染到客户端,Hidden=true的控件渲染到客户端但是隐藏。\n\t\t-US的ExtAspNet改造强烈依赖于此属性,这个版本发布后可以继续。\n\t\t-网报中唯一没有用到ExtAspNetAjax的地方就是显示隐藏\u003Cem\u003E表\u003C\u002Fem\u003E单字段,现在也可以使用Ajax了。\n\n\n\n+2008-09-04 v1.1 beta6\n\t-PageContext.Redirect支持普通页面转向和ExtAspNetAjax下页面转向。[fixed]\n\t+模拟树的下拉列\u003Cem\u003E表\u003C\u002Fem\u003E的BUG(会使一些可选项变成不可选项)[feedback:xmzhu]。[fixed]\n\t\t-因为if(\"0,2,9,11,\".indexOf('1,')\u003E=0){ok},这显然是不对的,此BUG涉及很多控件(Grid,DropDownList,TabStrip)。\n\t\t-解决方法:testValue += '';if(domValue.split(',').indexOf(testValue) \u003E= 0){ok}。\n\t-DropDownList在Ajax时应该先更新数据再设置选定项 [feedback:xmzhu]。[fixed]\n\t-Button\u002FMenuButton增加Ajax可更新属性OnClientClick [feedback:xmzhu]。[fixed]\n\t-Tree的Ajax支持(尚需优化)。[fixed]\n\t\n\t\n\n+2008-09-02 v1.1 beta5\n\t-DropDownList如果第一次没有绑定值,应该绑定到[[]](二维数组),而不是[](一维数组)。[fixed]\n\t-模拟树的DropDownList,在Ajax重新绑定DataSource后,保持项是否可选状态是最新的(页面第一次加载时,即使没有数据也需要设置DataTextField\u002FDataValueField\u002FDataSimulateTreeLevelField\u002FDataEnableSelectField等属性的值,否则Ajax回发时会\u003Cem\u003E出\u003C\u002Fem\u003E错)。[fixed]\n\t-UserControlConnector导致的Ajax错误,去除UpdatePanelConnector控件(以后不会用AspnetAjax,这个控件已经完成使命)。[fixed]\n\t-不要使用Asp.net的控件HiddenField,而是使用ExtAspNet的HiddenField,因为Asp.net的控件在Ajax不会被更新,所以会导致视图状态不一致的错误。[fixed]\n\t-网报Ajax整合基本完成(除了待审批-\u003E下一步[审核\u002F归档\u002F\u003Cem\u003E出\u003C\u002Fem\u003E纳]操作,由于需要显示隐藏\u003Cem\u003E表\u003C\u002Fem\u003E单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed]\n\t-IE下,RadioButtonList中项如果存在汉字,则会换行的BUG。[fixed]\n\t-增加两个Theme[Slate\u002FBlack](样式尚需完善)。[fixed]\n\t\n\t\n\t\n+2008-09-01 v1.1 beta4\n\t-非当前Tab中如果有ContentPanel,则在页面上方会有空白(可以通过设置EnableDeferredRender=false解决,但会减慢页面的加载速度),现在已经解决这个问题。[fixed]\n\t-RadioButtonList去除EnableBackgroundColor\u002FEnableLightBackgroundColor属性,背景色是透明的,也就是和父控件(SimpleForm\u002FForm)的背景色一致。[fixed]\n\t-TwinTriggerBox的第\u003Cem\u003E一个\u003C\u002Fem\u003ETrigger图标不会先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed]\n\t-Web.config中增加配置项FormLabelWidth=\"80\"(默认为80),同时PageManager增加FormLabelWidth属性用来控制页面上所有SimpleForm\u002FForm的\u003Cem\u003E表\u003C\u002Fem\u003E单字段标题的宽度。[fixed]\n\t+完善Ajax。[fixed]\n\t\t-RadioButtonList增加Ajax可更新属性SelectedIndex(SelectedValue\u002FSelectedItem)。\n\t\t-DropDownList增加Ajax可更新属性Enable\u002FSelectedIndex(SelectedValue\u002FSelectedItem)\u002FDataSource。\n\t\t-Grid增加Ajax可更新属性Columns(也就是说Grid列在回发时隐藏显示了一些,也能正确的Ajax)。\n\t\t-ToolbarText增加Ajax可更新属性Text。\n\t\t\n\t\t\n\t\t\n+2008-08-31 v1.1 beta3\n\t-TabStrip增加EnableDeferredRender属性(是否启用延迟加载Tab,默认启用)。[fixed]\n\t-重定向页面,使用系统的方法 PageContext.Redirect(string url),使用Response.Redirect方法会\u003Cem\u003E出\u003C\u002Fem\u003E错。[fixed]\n\t+安全的Ajax设计。[fixed]\n\t\t-这个版本Ajax和上个版本(v1.1beta1)在设计思路上有很大区别,同时在速度上会有进一步的提升。\n\t\t-基本思想:安全的Ajax交互,明确Ajax回发时支持控件哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供控件级别的EnableAjax属性。\n\t\t-整理支持Ajax的控件属性改变列\u003Cem\u003E表\u003C\u002Fem\u003E(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不会对UI起作用,同时是安全的,不会有js错误)。\n\t-网报Ajax整合(目前只支持所有的列\u003Cem\u003E表\u003C\u002Fem\u003E页面)(v0.8.1)。[fixed]\n\t\n\t\n\t\n+2008-08-29 v1.1 beta1\n\t+Window控件是否弹\u003Cem\u003E出\u003C\u002Fem\u003E的状态在回发时维持。[fixed]\n\t\t-控件设计的\u003Cem\u003E一个\u003C\u002Fem\u003E原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。\n\t+完全抛弃Asp.NetAjax,ExtAspNet控件内置Ajax支持。[fixed]\n\t\t-这是\u003Cem\u003E一个\u003C\u002Fem\u003E值得骄傲的设计,可以明显提高页面回发的速度(相比普通的回发和Asp.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。\n\t\t-不需要做任何配置,所有的回发都是Ajax(在Web.config和PageManager中有设置启用Ajax回发的属性-EnableAjax-默认为true)。\n\t\t+在这种设计下,其实可以完全抛弃Javascript。\n\t\t\t-比如简单的点击\u003Cem\u003E一个\u003C\u002Fem\u003E按钮弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口,可以在Button的OnClick事件中设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。\n\t\t\t-第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。\n\t\t\t-推荐的做法是尽量用客户端实现,客户端实现复杂的直接用服务器端实现。\n\t\t+目前ExtAspNetAjax的限制。\n\t\t\t-只对ExtAspNet控件起作用,对Asp.net控件不起作用。\n\t\t\t-对容器控件(有子控件的控件)不起作用,只对最底层的控件起作用。\n\t\t\t-对改变控件的Visible属性会有错误。\n\t\t\t-Window控件的属性改变只有少数几个起作用(Popup,IFrameUrl)。\n\t-PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用页面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个页面都添加PageLoading控件。[fixed]\n\t-Grid中的回发事件(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执行,这样当前行被选中的状态在回发后会得到保持。[fixed]\n\t-Grid选中行的状态在第一次回发时不能保持的BUG。[fixed]\n\t\n\t\n\t\n+2008-08-26 v1.0\n\t+已知问题:IE的ActiveX插件IE Developer Toolbar会对IFrame的加载造成0.5m左右的延迟。\n\t\t-主要是父页面加载\u003Cem\u003E一个\u003C\u002Fem\u003E比较大的css文件(~100k),则每次打开iframe页面,onload事件的调用都会有500ms左右的延迟,在测试IE性能时要禁用此插件。\n\t+优化弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口中IFrame的显示速度。[fixed]\n\t\t-在当前页面弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口需要~20ms,在父页面弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口需要100~300ms。通过缓存弹\u003Cem\u003E出\u003C\u002Fem\u003E的窗口实例,从而第二次弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口不再需要创建时间。\n\t-PageLayout的Region增加SplitColor属性,默认的背景色是透明的。(在网报中需要设置SplitColor=\"#CADDF7\",以便分隔符的颜色和Toolbar的颜色一致)[fixed]\n\t+PageManager增加属性Theme、Language、FormMessageTarget、FormOffsetRight等属性,这些属性可以在Web.config中设置(推荐方法),也可以为每个页面设置。[fixed]\n\t\t-\u003Cem\u003E一个\u003C\u002Fem\u003E典型的应用是为每个用户设置不同的皮肤(根据用户浏览器中Cookie设置的值)(示例在default.aspx)。\n\t-TreeNode增加属性SingleClickExpand,\u003Cem\u003E表\u003C\u002Fem\u003E示点击可切换节点的折叠展开状态。[fixed]\n\t+TabStrip中非当前Tab会延迟渲染。[fixed]\n\t\t-这会明显加快页面的渲染速度,网报中\u003Cem\u003E一个\u003C\u002Fem\u003E典型的费用审批页面可以减少200ms的渲染时间。\n\t\t-由于非当前Tab不会在页面加载时渲染,所以那些Tab中的节点在页面加载后也是不可见的,需要将相关的脚本移动到控件的render事件中。\n\t-不能比较两个DataPicker大小的BUG。[fixed]\n\t-TabStrip延迟加载引起的BUG(非当前Tab中的ContentPanel会占据页面空间,已修正)。[fixed]\n\t-全新的ExtAspNet.Examples(基础知识\u002F\u003Cem\u003E表\u003C\u002Fem\u003E单控件\u002F数据绑定\u002F容器布局\u002FIFrame框架)。[fixed]\n\t\n\t\n\t\n+2008-08-19 v0.4 beta6\n\t+PageManager增加两个属性(EnableInlineStyleJavascript\u002FApplyParentStyleJavascript),可以在IFrame页面中使用父页面的脚本和样式(示例在iframe\u002Fdefault.aspx和iframe\u002Fpage3.aspx)。[fixed]\n\t\t-测试发现,IFrame页面的加载速度并没有明显加快,可以先不使用此属性。\n\t-RadioButtonList放在在BorderLayout中显示不了的BUG [feedback:zgjiang2]。[fixed]\n\t+extjs的BUG,当页面中含有iframe时,Ext.onReady会被调用两次(IE6\u002FIE7)(http:\u002F\u002Fwww.extjs.net\u002Fforum\u002Fshowthread.php?t=43246)(示例在test.aspx)[fixed]\n\t\t-现在的解决方法是在初始化时:if(this.initialized){return;}this.initialized=true;\n\t+需要先回发页面再弹\u003Cem\u003E出\u003C\u002Fem\u003EIFrame窗口。[fixed]\n\t\t-在回发时设置窗口的Popup和IFrameUrl属性,因为这些属性是可以保持状态的,所以在关闭窗口时要注意设置Popup=false。\n\t\t-另一种做法(推荐):PageContext.RegisterStartupScript(Window99.GetShowReference(\".\u002Fsimpleform.aspx\"));。\n\t\n\t\t\n\t\n+2008-08-15 v0.4 beta5\n\t-点击关闭窗口的按钮,在IE6下会有JS错误。[fixed]\n\t-增加BorderLayout控件,示例在iframe\u002Fborderlayout.aspx。[fixed]\n\t+Radiobuttonlist显示有重影(示例在radio.aspx)。[fixed]\n\t\t-全新的样式。\n\t\t-去除Horizontal属性,增加ColumnNumber(可以设置渲染成几列)。\n\t\t-GetValueReference取得的值不正确的BUG。\n\t-动态向Form中添加FormRow,并动态的向FormRow中添加\u003Cem\u003E表\u003C\u002Fem\u003E单字段,以及如何取得\u003Cem\u003E表\u003C\u002Fem\u003E单字段的值。(示例在form_dynamic.aspx)[fixed]\n\t+IFrame弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口关闭后回发父页面,则会多加载IFrame一次,再次打开窗口会重复加载IFrame2-3次[feedback:xmzhu]。[fixed]\n\t\t-这是\u003Cem\u003E一个\u003C\u002Fem\u003E重要的BUG,会严重影响页面的加载速度。原因是通过脚本改变的IFrameUrl会在回发时保持状态,从而回发父页面后Window中的IFrame被添加到页面,而这是不需要的。\n\t\t-现在\"是否弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口、窗口标题、IFrameUrl\"在客户端的改变,不会影响服务器端的属性,也即是不保持状态。此问题解决。(示例在button_iframe.aspx)\n\t\n\t\n\t\n+2008-08-13 v0.4 beta4\n\t-点击关闭窗口的按钮,在IE下会有JS错误。[fixed]\n\t-Window的右上角关闭图标增加提示,优化事件响应。[fixed]\t\n\t-Window的代码重构。[fixed]\t\n\t+修正\u003Cem\u003E一个\u003C\u002Fem\u003E的内存泄漏。[fixed]\n\t\t-IE7下测试,打开iframe\u002Fdefault.aspx页面,iexplorer占内存68.368M。\n\t\t-内存存在泄漏时,点击iframe\u002Fpage3.aspx页面8次后iexplorer占118.792M内存。\n\t\t-修正后,点击iframe\u002Fpage3.aspx页面8次后iexplorer占76.492M内存。\n\t\t-IE窗口最小化时,IE会自动进行垃圾回收。\n\t\n\t\n\t\n+2008-08-12 v0.4 beta3\n\t-底层的javascript框架Extjs升级为v2.2,Grid的渲染速度有很大提升。[fixed]\n\t-Grid的EnableDelayRender默认为true(如果没有设置Grid的高度或通过布局间接设置高度,则行不可见,可以通过AutoHeight=\"true\"解决)。[fixed]\n\t+页面正在加载的提示尽早的显示\u003Cem\u003E出\u003C\u002Fem\u003E来。[fixed]\n\t\t-首先在执行js来完成页面渲染之前延迟5ms,以便浏览器把当前页面内容显示\u003Cem\u003E出\u003C\u002Fem\u003E来。\n\t\t-加载js脚本的script标签放置在页面的最后,放置加载js而阻塞PageLoading的显示。\n\t\n\t\n\t\n+2008-08-08 v0.4 beta2\n\t-TabStrip延时加载\u003Cem\u003E出\u003C\u002Fem\u003E错。[fixed]\n\t-Window的IFrameUrl处理的BUG,比如Pages_ExtAspNet目录下的页面应该为.\u002FFE_ApplyEditor.aspx或~\u002FPages_ExtAspNet\u002FFE_ApplyEditor.aspx。[fixed]\n\t-Window的WindowPosition=\"Center\"并且Target=\"_parent\",则会JS错误。[fixed]\n\t-实现网报首页下拉菜单和左侧菜单的导航功能。[fixed]\n\t-Window的创建在页面显示后进行,不计算在js渲染时间内。[fixed]\n\t-优化费用申请页面(尽量减少不必要的层次嵌套)。[fixed]\n\t-button_iframe.aspx默认会加载form.aspx页面(Window控件的BUG)。[fixed]\n\t-Window中的保存并关闭按钮和Asp.netAjax冲突。[fixed]\n\t-优化关闭Window的js脚本,减少写到页面的js大小。[fixed]\n\t-加快“保存并关闭”按钮关闭窗口的速度,使用PageContext.RegisterExclusiveScript(CurrentActiveWindow.GetClosePostBackReference());,示例在(simpleform.aspx)。[fixed]\n\t\n\t\n\t\n+2008-08-05 v0.4 beta1\n\t-DropDownList去除Traditional属性,和传统的Asp.net控件一样不可编辑。[fixed]\n\t-DropDownList增加SelectedText属性(去除了模拟树时通过SelectedItem.Text的多余html字符)。[fixed]\n\t-为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed]\n\t-将生成的js对象的\u003Cem\u003E名称\u003C\u002Fem\u003E简单化,这样可以减少生成的js内容,加快页面加载速度(\u003Cem\u003E一个\u003C\u002Fem\u003E典型页面的js由原来的33.0k降低为21.4k)。[fixed]\n\t+弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口中,点击按钮回发然后点击关闭按钮,\u003Cem\u003E出\u003C\u002Fem\u003E现js错误 [feedback:xmzhu]。[fixed]\n\t\t-因为在页面的Page_Load中,if (!IsPostBack){PageContext.RegisterPageStateChangedStartupScript();}通过这样方法向页面注册了一段脚本,但是这段脚本在回发时没有注册到页面,因为js调用此脚本时报错。\n\t\t-一种解决方法是将向页面注册脚本的函数移动到if语句的外面,即每次都向页面注册此脚本。\n\t\t-另一种办法就是在PageManager控件中增加RegisterPageStateChangedScript(向页面注册监视页面中\u003Cem\u003E表\u003C\u002Fem\u003E单内容改变的脚本)的属性(会在每次页面回发(包含ajax回发)时注册脚本)(示例在button_iframe.aspx\u002Fsimpleform.aspx)。\n\t+PageManager控件增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.aspx)。[fixed]\n\t\t-这个手工添加onReady函数能够在每次页面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去做的麻烦(已经在网报中遇到这种情况)。\n\t-每个页面必须添加\u003Cem\u003E一个\u003C\u002Fem\u003EPageManager控件,否则会\u003Cem\u003E出\u003C\u002Fem\u003E错,同时去除DesignTimeStyle控件(作为PageManager的属性\u003Cem\u003E出\u003C\u002Fem\u003E现)。[fixed]\n\t-TextField等\u003Cem\u003E表\u003C\u002Fem\u003E单字段增加Readonly属性。[fixed]\n\t+全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和Asp.net Ajax保持兼容)。[fixed]\n\t\t-最大的好处是可以减少页面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下)\n\t\t+示例1,通过点击按钮弹\u003Cem\u003E出\u003C\u002Fem\u003EIFrame窗口,可直接关闭父页面,也可在关闭后刷新或回发父页面。(default.aspx\u002Fpage2.aspx\u002Fsimpleform.aspx)\n\t\t\t-虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要做的仅仅是为Window控件增加\u003Cem\u003E一个\u003C\u002Fem\u003E属性(Target=\"_parent\"),就完成了两种框架的转换,是不是很酷。\n\t\t\t-显然,控件本身封装了大量的代码,简单来看现在有三个页面(default.aspx(A)\u002Fpage2.aspx(B)\u002Fsimpleform.aspx(C)),其中A包含B页面,当你在B中打开包含有页面C的窗口时,窗口不是在B中打开,而是在A中打开,这样才能保证窗口覆盖整个页面,当你从C中返回需要回发页面B时,却发现取得的是A页面,因为我们窗口是在A页面中创建的。我会通过一篇文章来揭示这一过程,敬请期待。\n\t\t-示例2,Grid中弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口。(default.aspx\u002Fpage3.aspx\u002Fsimpleform.aspx)\t\n\t\t+示例3,TriggerBox弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口。(default.aspx\u002Ftriggerbox.aspx\u002Fsimpleform.aspx)\t\n\t\t\t-在整个页面弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口或者在当前页面弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口,仅仅设置Window的Target属性即可。\n\t\t-示例4,弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口中的弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口。\n\t-对整个Examples更新测试。[fixed]\n\t\n\t\n\t\n+2008-07-31 v0.3 beta12\n\t-IE下TabStrip在Ajax回发后不会去掉x-hide-display样式,导致Tab显示为空的BUG。[fixed]\n\t-对TabStrip\u002FPanel\u002FWindow中的IFrame重新设计,如果设置IFrameUrl=\"#\"或者\"about:blank\",则不渲染iframe到页面节点,同时第二次打开Window中的IFrame不会有残影\u003Cem\u003E出\u003C\u002Fem\u003E现。[fixed]\n\t-如果TabStrip的Tab不是激活Tab并且设置了IFrameUrl,则会延迟加载(示例在tabstrip_iframe.aspx)。[fixed]\n\t-Tree控件,点击\u003Cem\u003E一个\u003C\u002Fem\u003E节点自动回发,则当前点击的那个节点的选中状态不会保持的BUG [feedback:zgjiang2]。[fixed]\n\t+规范关闭窗口时提示用户保存已经修改的内容提示的调用方式(包含iframe中关闭按钮和window右上角关闭图标的调用方式)(示例在grid_iframe.aspx\u002Fsimpleform.aspx)。[fixed]\n\t\t-内部实现上,点击“保存并关闭按钮”,可以将关闭窗口的脚本更早的执行(在simpleform.aspx,PageContext.RegisterStartupScript增加重载函数),而不是原来的先创建整个页面UI,再关闭窗口。\n\t-参照Yslow的评分规则,将JS文件引用由head移动到body中。[fixed]\n\t-Firefox下,如果页面太长会\u003Cem\u003E出\u003C\u002Fem\u003E滚动条,原来在ViewPort样式中有body{overflow:hidden;}。[fixed]\n\t+IFrame内的页面宽度和高度会自动设置(是不是还在为1px\u002F2px的白边而烦恼,现在不用了:-)(示例在iframe_autosize.aspx\u002Fsimpleform.aspx\u002Fsimpleform2.aspx)[fixed]\n\t\t-增加PageManager控件(需要指定AutoSizePanelID,即需要设置宽度和高度为整个页面的宽度和高度的Panel),HideScrollbar属性用于隐藏滚动条(IE\u002FFirefox)。\n\t\n\t\n\t\n+2008-07-24 v0.3 beta11\n\t-web.config配置信息中MessageTarget改名为FormMessageTarget,增加FormOffsetRight配置项,用来定义全局\u003Cem\u003E表\u003C\u002Fem\u003E单字段距离右边界的宽度,同时每个\u003Cem\u003E表\u003C\u002Fem\u003E单字段都增加OffsetRight属性 [feedback:jima]。[fixed]\n\t-Window在回发时设置的Title不起作用的BUG。[fixed]\n\t-增加Image控件 [feedback:jima]。[fixed]\n\t-Tree控件,如果\u003Cem\u003E一个\u003C\u002Fem\u003E节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则会引起页面死循环回发 [feedback:zgjiang2]。[fixed]\n\t-Image增加ToolTipTitle\u002FToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.aspx)。[fixed]\n\t-去掉DropDownList控件的Text属性(强制性),可以通过设置SelectedValue来设置选中哪一项 [feedback:xmzhu]。[fixed]\n\t-过滤提示消息中的换行符(转换为\u003Cbr\u002F\u003E),否则提示信息可能导致页面渲染错误 [feedback:dcding]。[fixed]\n\t\n\t\n\t\n+2008-07-23 v0.3 beta10\n\t+完善Tree控件。[fixed]\n\t\t-如何将\u003Cem\u003E数据库\u003C\u002Fem\u003E中的数据绑定到Tree(示例在tree2_bind_database.aspx)。\n\t\t-ajax加载树节点,放在UpdatePanel中才有ajax的效果(示例在tree2_ajax.aspx)。\n\t\t-更改TreeNode的ID为NodeId,否则两个树中不能有相同ID的TreeNode,这是不合理的。\n\t-Grid的GridColumn的ID改名成ColumnId,否则同\u003Cem\u003E一个\u003C\u002Fem\u003E页面放置两个Grid,它们的GridColumn的ID不能同名,这是不合理的。注意需要更新以前的代码![fixed]\n\t-Grid所有类型的列增加DataTooltipField\u002FDataTooltipFormatString两个字段,以显示ToolTip(示例在grid.aspx)。[fixed]\n\t\n\t\n\t\n+2008-07-22 v0.3 beta9\n\t+IE6下,左侧导航链接的选中样式,以及鼠标移上去和移开的样式不对。[fixed]\n\t\t-发现原来ie6不能正确解析li的高度,必须手工设置才行(style=\"height:20px;\")。\n\t+IE6\u002FIE7下,模拟树的下拉列\u003Cem\u003E表\u003C\u002Fem\u003E如果文字长度太长,则显示的文字会换行,导致错位。[fixed]\n\t\t-虽然最后未能解决\u003Cdiv style=\"width: 60px; white-space: nowrap; overflow: hidden; border: solid 1px red;\"\u003E\u003Cdiv style=\"width: 16px; height: 18px; float: left;\"\u003E##\u003C\u002Fdiv\u003E差旅交通费\u003C\u002Fdiv\u003E在IE和Firefox下显示的不同效果。\n\t\t-但是通过用\u003Cimg src=\"##\" \u002F\u003E来代替\u003Cdiv style=\"background:url(##)\" \u002F\u003E,从而实现FF和IE下样式的统一。\n\t\t-刚看到old9的解决方案:把“差旅交通费”改成“\u003Cspan style=\"margin-right: -1000px;\"\u003E差旅交通费\u003C\u002Fspan\u003E”,在IE下和FF下的都不换行,:-)\n\t-LinkButton增加OnClick事件 [feedback:huihuang]。[fixed]\n\t-Window通过设置IFrameUrl和Popup不起作用的BUG。[feedback:xmzhu]。[fixed]\n\t+增加树控件(Tree)(示例在tree2.aspx)。[fixed]\n\t\t-可以在回发时维持树的状态(选中行,折叠\u002F展开,CheckBox)。\n\t\t-可以通过Inline的方式添加树节点,也可以绑定到XmlDocument\u002FXmlDataSource\u002FSiteMap。\n\t\t-点击树节点可以链接到页面,也可以引发PostBack事件,可以添加自定义脚本。\n\t\n\t\n\t\n+2008-07-16 v0.3 beta8\n\t+ContentPanel中放置ExtAspNet控件,则渲染时会\u003Cem\u003E出\u003C\u002Fem\u003E现各种问题,比如下拉列\u003Cem\u003E表\u003C\u002Fem\u003E显示样式\u003Cem\u003E出\u003C\u002Fem\u003E错,Grid没了滚动条等等。[fixed]\n\t\t-隐蔽性非常强,原来在ContentPanel中渲染ExtAspNet控件,如果容器的display='none',则会\u003Cem\u003E出\u003C\u002Fem\u003E现各种问题(主要是大小不对)。\n\t\t 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。\n\t\t-现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局实现),只要超过Grid容器就会显示滚动条。\n\t+IE6下,在应用Asp.NetAjax后,Form中字段的宽度渲染不正确。[fixed]\n\t\t-调试相当困难,如果你有过在IE下通过alert发现问题的经历,你就能明白。\n\t\t-最后发现IE6下应用Asp.NetAjax后不仅Form中列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG:\n\t\t 在MasterPage的onReady函数中,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正页面中所有\u003Cem\u003E表\u003C\u002Fem\u003E单的宽度(box_fixFormWidthInIE6();):\n\t\t 示例在 Site.Master 页面。\n\t+集成的AspNetAjax有\u003Cem\u003E一个\u003C\u002Fem\u003E很大的BUG,只要你在页面上进行过ajax操作,当改变窗口大小时你会惊讶的发现内容区域的内容全部为空了![fixed]\n\t\t-解决方法相当怪异,经过\u003Cem\u003E一个\u003C\u002Fem\u003E下午的不断尝试,终于用\u003Cem\u003E一个\u003C\u002Fem\u003E怪异的方法解决(box.{0}.setSize(box.{0}.getSize());box.{0}.doLayout();),\n\t\t 这样的代码让我想起刷新窗口时那个方法(window.location.href=window.location.href;),不管怎么说,我对能很好的解决这个重大的BUG很是欣喜。\n\t\n\t\n\t\n+2008-07-14 v0.3 beta6\n\t-增加FlashObject控件。[fixed]\n\t-PageLoading增加EnableFadeOut属性(默认false),可以启用淡\u003Cem\u003E出\u003C\u002Fem\u003E效果。[fixed]\n\t-Accordion选中样式微调。[fixed]\n\t-预加载Form\u003Cem\u003E表\u003C\u002Fem\u003E单\u003Cem\u003E出\u003C\u002Fem\u003E错时提示信息的背景图片。[fixed]\n\t+Grid增加EnableDelayRender属性(默认false),可以加快页面的渲染速度(\u003Cem\u003E一个\u003C\u002Fem\u003E典型的20个记录的页面,可提前0.7s-1s显示\u003Cem\u003E出\u003C\u002Fem\u003E来)。[fixed]\n\t\t-因为延迟加载数据不会改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置\"EnableDelayRender=false\"。\n\t-改变Grid中静态的CheckBoxField图片。[fixed]\n\t-TabStrip增加TabIndexChanged事件,同时Tab增加EnablePostBack,可以在点击\u003Cem\u003E一个\u003C\u002Fem\u003ETab时引起回发事件。这在延迟加载Tab的内容非常有用。(示例在tabstrip.aspx)[fixed]\n\t\n\t\n\t\n+2008-07-12 v0.3 beta5\n\t-页面菜单Toolbar的分割符和背景不相融合。[fixed]\n\t-\u003Cem\u003E表\u003C\u002Fem\u003E单字段之间可以比较大小,比如NumberBox可以和Label比较大小,同时增加CompareType,来指定比较的类型(示例在form_compare.aspx)。[fixed]\n\t\t-如果是同种类型的\u003Cem\u003E表\u003C\u002Fem\u003E单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而\u003Cem\u003E一个\u003C\u002Fem\u003ENumberBox和TextBox比较大小需要指定CompareType。\n\t+如果在编辑页面使用AspNetAjax,则不能在回发时关闭当前窗口[feedback:huihuang](示例在ajax_editor_main.aspx\u002Fajax_editor.aspx)。[fixed]\n\t\t-这是由于ajax后执行的javascript中不能有return false语句。\n\t+在文本框失去焦点时,执行一些Javascript脚本(示例在textbox_blur.aspx) [feedback:xmzhu]。[fixed]\n\t\t-在页面添加onReady函数(会被系统调用),然后用javascript监视文本框值的改变。\n\t-弹\u003Cem\u003E出\u003C\u002Fem\u003EWindow默认显示的错误页面,解决方法在当前目录添加\u003Cem\u003E一个\u003C\u002Fem\u003E空的html页面,然后把Window控件的IFrameUrl指向这个页面而不是\"#\"。[fixed]\n\t+弹\u003Cem\u003E出\u003C\u002Fem\u003E的窗口中的弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口的如果内容发生变化,则点击右上角的关闭按钮时会有提示用户先保存的对话框,但是这个对话框的被第二个弹\u003Cem\u003E出\u003C\u002Fem\u003E窗口覆盖了 [feedback:xmzhu]。[fixed]\n\t\t-原来的调用方法太麻烦(见示例中alert\\alert_1.aspx和alert\\alert_2.aspx,总计 6 行代码),现在只需要 3 行代码就OK了。\n\t-点击提交按钮后变成灰色不可再次点击(示例在button_click_gray.aspx)[feedback:jima]。[fixed]\n\t+增加Menu、MenuText、MenuSeparator、MenuButton、MenuHyperLink控件,用于按钮的下拉菜单(示例在button_menu.aspx)。[fixed]\n\t-增加SplitButton控件。[fixed]\n\t\n\t\n\t\n+2008-07-09 v0.3 beta4\n\t-DataPicker默认的日期格式为(yyyy-MM-dd)。[fixed]\n\t+Form\u003Cem\u003E表\u003C\u002Fem\u003E单字段(TextBox,DropDownList...)之间可以比较大小 [feedback:huihuang]。[fixed]\n\t\t-增加ControlToCompare\u002FValueToCompare\u002FCompareOperator\u002FCompareMessage四个属性,示例在form_compare.aspx。\n\t+TabStrip中放置IFrame会\u003Cem\u003E出\u003C\u002Fem\u003E现渲染错误 (示例在tabstrip_iframe.aspx)[feedback:jima]。[fixed]\n\t\t-特殊处理,拥有IFrame的Tab如果不是激活Tab,则不设置Url,只有在激活时才设置Url。\n\t-RadioButtonList增加AutoPostBack属性(示例在radio.aspx) [feedback:xmzhu]。[fixed]\n\t-FormRow可以设置各列的宽度百分比 (示例在form_columnwidths.aspx)[feedback:jima]。[fixed]\n\t+\u003Cem\u003E表\u003C\u002Fem\u003E单字段Enable=false时显示颜色太浅 [feedback:jima]。[fixed]\n\t\t-覆盖缺省样式的.x-item-disabled,设置不透明。\n\t\n\t\n\t\n+2008-07-08 v0.3 beta3\n\t-Grid没有数据,向后翻页按钮可以点击的BUG [feedback:huihuang]。[fixed]\n\t+增加HiddenField控件。[fixed]\n\t\t-其实用TextBox也能模拟HiddenField的行为,只需要设置CssStyle=\"display:none;\"即可。\n\t+TriggerBox 如果 EnableTextBox = true,则不能将Text回发(这是html的限制)。[fixed]\n\t\t-最后的解决方案居然是设置 readonly=true,同时更改属性为 Readonly(示例在textbox2.aspx)。\n\t-模拟树的下拉列\u003Cem\u003E表\u003C\u002Fem\u003E在失去焦点后显示的文字不对的BUG。[fixed]\n\t+控制下拉列\u003Cem\u003E表\u003C\u002Fem\u003E某些项不可以选择(示例在dropdownlist2.aspx)。[fixed]\n\t\t-增加 DataEnableSelectField 属性,不可选择的项变灰,并且鼠标经过时没有样式。\n\t-LinkButton和Grid的LinkButtonField增加Enable属性(示例在hyperlink.aspx和grid.aspx)。[fixed]\n\t\n\t\n\t\n+2008-07-07 v0.3 beta2\n\t+增加UpdatePanelConnector控件,支持在布局构建的页面使用Asp.net Ajax。[fixed]\n\t\t-使用UpdatePanelConnector有\u003Cem\u003E一个\u003C\u002Fem\u003E要求:ContentTemplate下只能有\u003Cem\u003E一个\u003C\u002Fem\u003E子节点,比如box:Panel。\n\t\t-示例在ajax3.aspx\u002Fcontent_page4.aspx。\n\t\t-示例content_page3.aspx中,点击“Ajax\u003Cem\u003E查询\u003C\u002Fem\u003E”按钮和关闭弹\u003Cem\u003E出\u003C\u002Fem\u003E的窗口(点击右上角的叉)都引发异步更新。\n\t \n\t \n\t\n+2008-07-03 v0.3 beta1\n\t+容器控件的AutoHeight\u002FAutoWidth默认为false。[fixed]\n\t\t-使用GroupPanel的地方需要手工添加AutoHeight=\"true\"属性。\n\t+增加UserControlConnector,可以在其中放置用户控件(示例在page_usercontrol.aspx)。[fixed]\n\t\t-也可以在ContentPanel中放置用户控件,注意两者的区别。\n\t+增加ContentPlaceHolderConnector,\u003Cem\u003E替换\u003C\u002Fem\u003E原来Region的ContentPlaceHolderId属性(示例在Site.master)。[fixed]\n\t+支持Asp.net ajax异步加载。[fixed]\n\t\t-有很大局限性,只能在ContentPanel中使用,示例在ajax1.aspx\u002Fcontent_ajax2.aspx中。\n\t\t-对于使用布局构建的页面(比如content_page1.aspx)还不能使用Asp.net ajax,因为页面是整体渲染的,先放弃。\n\t\n\t\n\t\n+2008-07-02 v0.2 beta12\n\t+关闭前提示当前页面已经被修改(示例在content_page1.aspx\u002Fsimpleform.aspx)[fixed]\n\t\t-支持Iframe内按钮和window右上角关闭按钮。\n\t\t-删除CloseAction属性,可以在后台通过OnClientCloseButtonClick属性指定(为了和iframe中做法一致)。\n\t+iframe中的alert\u002Fconfirm要覆盖整个父页面,而不仅仅是iframe页面。[fixed]\n\t\t-在Firefox下还有问题。[fix pending]\n\t+排序时在标题栏显示排序箭头,可以排序的列标题光标为手形(示例在grid_sorting.aspx)。[fixed]\n\t\t-可以通过设置Grid1.CurrentSortColumnIndex = 0;来强制某列显示排序箭头。\n\t\t-可以通过 Grid1.Columns[Grid1.CurrentSortColumnIndex].SortExpression 的方式取得当前Grid的排序\u003Cem\u003E表\u003C\u002Fem\u003E达式。\n\t+HyperLinkField\u002FWindowField的链接地址支持服务器端格式(即是~\u002Falert.aspx)。[fixed]\n\t-TabStrip的Tab中如果放置ContentPanel,则内容渲染位置不正确。[fixed]\n\t-可以在ContentPanel中放置用户控件(示例在page_usercontrol.aspx)。[fixed]\n\t\t\n\t\n\t\n+2008-06-30 v0.2 beta11\n\t-增加TwinTriggerBox控件(示例在twintriggerbox.aspx)。[fixed]\n\t-Grid的\u003Cem\u003E数据库\u003C\u002Fem\u003E分页需要增加属性IsDatabasePaging=true,以便普通分页和\u003Cem\u003E数据库\u003C\u002Fem\u003E分页,否则在添加删除记录时总记录数不会变化 [feedback:zgjiang2]。[fixed]\n\t-关闭Window时PostBack事件OnClose可以指定\u003Cem\u003E参数\u003C\u002Fem\u003E,来区分是哪些操作引发的PostBack事件 [feedback:zgjiang2](示例在window_postback.aspx)。[fixed]\n\t-如果\u003Cem\u003E表\u003C\u002Fem\u003E单验证不通过,则需要弹\u003Cem\u003E出\u003C\u002Fem\u003E对话框提示(第\u003Cem\u003E一个\u003C\u002Fem\u003E没通过验证的字段)(目前还不能切换到相应的tab)。[fixed]\n\t+页面中任意可输入\u003Cem\u003E表\u003C\u002Fem\u003E单字段发生变化,可提示先保存。(示例在content_page1.aspx\u002Fsimpleform.aspx)[fixed]\n\t\t-目前还不支持Window右上角关闭按钮的提示保存功能。\n\t-Master\u002FContent的内容页中Grid的Sort事件不起作用的BUG [feedback:zgjiang2]。[fixed]\n\t-Grid中的LinkButtonField设置ConfirmText会\u003Cem\u003E出\u003C\u002Fem\u003E错 [feedback:huihuang]。[fixed]\n\t-增加静态类Confirm。[fixed]\n\t\n\t\n\t\n+2008-06-27 v0.2 beta10\n\t+Grid完善。[fixed]\n\t\t-CheckBoxField在回发时不能保持状态的BUG (已经更新了grid_checkboxfield.aspx示例)。\n\t\t-Grid中模拟树显示,GridColumn增加DataSimulateTreeLevelField属性(\u003Cem\u003E一个\u003C\u002Fem\u003EGrid只能有\u003Cem\u003E一个\u003C\u002Fem\u003EColumn指定此属性),指定此列模拟树显示时的层次字段(0,1,2,...)(示例在grid_simulate_tree.aspx)。\n\t\t-切换分页时清空选中的值 [feedback:jqpeng]。\n\t\t-增加PreRowDataBound事件,可以在数据绑定之前设置某列的属性 [feedback:xmzhu] (示例在grid_prerowdatabound.aspx)。\n\t-DropDownList模拟树的方式显示,增加DataSimulateTreeLevelField属性,使用方法和Grid的类似(示例在dropdownlist_simulate_tree.aspx)。\n\t\n\t\n\t\n+2008-06-25 v0.2 beta9\n\t+Window窗体中的Iframe只让内容区域滚动,而Toolbar不滚动的规则。(示例在content_page2.aspx\u002Fsimpleform.aspx)[fixed]\n\t\t-在simpleform.aspx中:Panel[BodyPadding=5](Toolbar,Panel[Height=450 Layout=Fit](SimpleForm[AutoScroll=true])),则外面窗口的高度=450 + 5*2 + 26 + 32,其中26是Toolbar的高度,32是窗口的标题栏和下边框的高度。\n\t+关闭Iframe的LoadMask,所以需要Iframe页面添加PageLoading控件,这样效果统一。[fixed]\n\t+Grid完善。\n\t\t-去除EnableClientPaging和EnableClientSort属性,客户端排序和客户端分页在ASP.NET应用中会有很多问题(主要是状态保持的问题)。\n\t\t+EnableServerSort改名AllowSorting。(示例在grid_sorting.aspx)\n\t\t\t-使用非常简单:设置AllowSorting=true,注册OnSort事件,在事件处理函数中重新绑定数据。\n\t\t+增加AllowPaging属性。(示例在grid_paging.aspx)\n\t\t\t-使用非常简单:设置AllowPaging=true,PageSize=3,注册OnPageIndexChange事件,在事件处理函数中Grid1.PageIndex = e.NewPageIndex;OK。\n\t\t+\u003Cem\u003E数据库\u003C\u002Fem\u003E分页支持。(示例在grid_database_paging.aspx)\n\t\t\t-使用也非常简单:设置AllowPaging=true,PageSize=3,在绑定时设置RecordCount为总的记录数,在OnPageIndexChange事件处理函数中Grid1.PageIn","createTime":"2010-04-01 09:41:27","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-2190657-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-2190657-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"3\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fsuper_zhaowenke\u002F2190657\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-2190657-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1715086686466_68342\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"3\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fsuper_zhaowenke\u002F2190657\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-2190657-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1715086686466_68342\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fblog.csdn.net\u002Fluosai19910103\u002Farticle\u002Fdetails\u002F122990447","title":"mysql \u003Cem\u003E字符串\u003C\u002Fem\u003E转数组,并将对应的\u003Cem\u003E名称\u003C\u002Fem\u003E拼接存到某个字段上","desc":"一、背景\n由于\u003Cem\u003E名称\u003C\u002Fem\u003E字段因为bug,导致缺失需要修复。而该字段可以由另外\u003Cem\u003E一个\u003C\u002Fem\u003E字段\u003Cem\u003E查询\u003C\u002Fem\u003E\u003Cem\u003E出\u003C\u002Fem\u003E来多条进行拼接。现在需要处理所有此类的数据。\n二、 处理\n– 1获得所有以“某个符号“分割的\u003Cem\u003E字符串\u003C\u002Fem\u003E的个数\nDELIMITER $$\nCREATE FUNCTION `func_get_split_string_total`(\nf_string varchar(1000),f_delimiter varchar(5)\n) RETURNS int(11)\nBEGIN\n-- Get the total number of giv","createTime":"2022-02-17 19:47:42","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~Rate-4-122990447-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~Rate-4-122990447-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"4\",\"dest\":\"https:\u002F\u002Fblog.csdn.net\u002Fluosai19910103\u002Farticle\u002Fdetails\u002F122990447\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~Rate-4-122990447-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1715086686466_68342\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"4\",\"dest\":\"https:\u002F\u002Fblog.csdn.net\u002Fluosai19910103\u002Farticle\u002Fdetails\u002F122990447\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~Rate-4-122990447-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1715086686466_68342\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"blog"},{"url":"https:\u002F\u002Fblog.csdn.net\u002Fweixin_43914604\u002Farticle\u002Fdetails\u002F105171740","title":"3.4 《\u003Cem\u003E数据库\u003C\u002Fem\u003E系统概论》之数据\u003Cem\u003E查询\u003C\u002Fem\u003E---SELECT(单\u003Cem\u003E表\u003C\u002Fem\u003E\u003Cem\u003E查询\u003C\u002Fem\u003E、连接\u003Cem\u003E查询\u003C\u002Fem\u003E、嵌套\u003Cem\u003E查询\u003C\u002Fem\u003E、集合\u003Cem\u003E查询\u003C\u002Fem\u003E、多\u003Cem\u003E表\u003C\u002Fem\u003E\u003Cem\u003E查询\u003C\u002Fem\u003E)","desc":"文章目录0.前言1.思维导图2.Student\u002FSC\u002FCourse\u003Cem\u003E表\u003C\u002Fem\u003E数据及结构3.SELECT语句的一般格式4.单\u003Cem\u003E表\u003C\u002Fem\u003E\u003Cem\u003E查询\u003C\u002Fem\u003E(1)选择\u003Cem\u003E表\u003C\u002Fem\u003E中的若干列① \u003Cem\u003E查询\u003C\u002Fem\u003E指定列② \u003Cem\u003E查询\u003C\u002Fem\u003E全部列③ \u003Cem\u003E查询\u003C\u002Fem\u003E经过计算的值❶ 算术\u003Cem\u003E表\u003C\u002Fem\u003E达式❷ \u003Cem\u003E字符串\u003C\u002Fem\u003E常量及函数❸ 使用列别名改变\u003Cem\u003E查询\u003C\u002Fem\u003E结果的列标题(2)选择\u003Cem\u003E表\u003C\u002Fem\u003E中的若干元组(行)① 关键词DISTINCT去掉\u003Cem\u003E表\u003C\u002Fem\u003E中重复的行② \u003Cem\u003E查询\u003C\u002Fem\u003E满足条件的元组(行)❶ 比较大小❷ 确定范围❸ 确定集合❹ 字...","createTime":"2020-03-29 00:04:48","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~activity-5-105171740-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~activity-5-105171740-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"5\",\"dest\":\"https:\u002F\u002Fblog.csdn.net\u002Fweixin_43914604\u002Farticle\u002Fdetails\u002F105171740\",\"strategy\":\"2~default~OPENSEARCH~activity\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~activity-5-105171740-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1715086686466_68342\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"5\",\"dest\":\"https:\u002F\u002Fblog.csdn.net\u002Fweixin_43914604\u002Farticle\u002Fdetails\u002F105171740\",\"strategy\":\"2~default~OPENSEARCH~activity\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~activity-5-105171740-bbs-270013448.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1715086686466_68342\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"blog"}],"staffDOList":[{"id":null,"communityId":227,"username":"community_109","userNickname":"C#","roleCode":1,"status":1,"createUsername":"","updateUsername":"","avatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","createTime":"2021-05-12 18:07:21","updateTime":"2021-05-12 18:07:21","lastLoginTime":"2021-05-12 18:07:21"},{"id":null,"communityId":227,"username":"sunhui","userNickname":"Web++","roleCode":2,"status":1,"createUsername":"bbs_assistant","updateUsername":"","avatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F4da5553c0cca498aa6129165b431f71b_sunhui.jpg!1","createTime":"2021-07-29 12:01:41","updateTime":"2021-07-29 12:01:41","lastLoginTime":"2021-07-29 12:01:41"},{"id":null,"communityId":227,"username":"diaodiaop","userNickname":"by_封爱","roleCode":2,"status":1,"createUsername":"bbs_assistant","updateUsername":"","avatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F1bbdb34c745a495686ef96bd81e655c3_diaodiaop.jpg!1","createTime":"2021-07-13 16:47:41","updateTime":"2021-07-13 16:47:41","lastLoginTime":"2021-07-13 16:47:41"}],"communityConfig":{"scoreType":0,"scoreItems":{"0":"给本帖投票","1":"锋芒小试,眼前一亮","2":"潜力巨大,未来可期","3":"持续贡献,值得关注","4":"成绩优异,大力学习","5":"贡献巨大,全力支持"}},"shouldApply":false,"subscribeAble":false,"operatorAble":false,"commentNeedJoinCommunity":false},"default2014LiveRoom":[{"itemType":"","description":"高峰论坛","title":"2022 技术英雄会","url":"https:\u002F\u002Flive.csdn.net\u002Froom\u002Fiframe\u002Fcsdnnews\u002FfsNR5NWp?chat=1&title=1&footer=1","images":["https:\u002F\u002Fimg-home.csdnimg.cn\u002Fimages\u002F20221016050009.png"],"ext":{"time":"9:00","liveRoomUrl":"https:\u002F\u002Flive.csdn.net\u002Froom\u002Fcsdnnews\u002FfsNR5NWp"}}]},"isGooglebot":false,"canonical":"https:\u002F\u002Fwww.csdn.net\u002Ftopics\u002F270013448","openUrl":"","isApp":false,"localUrl":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F270013448","typeId":"index","hasIndex":false},"CFG":{"ALIPLAYER_VERSION":"v4","ALIPLAYER_H5_VERSION":"mobile_v1","ENV":"prod","ROOT_URL":"https:\u002F\u002Fcms-mall.csdn.net\u002F","VUE_APP_API_URL_SERVER":"http:\u002F\u002Fcms-community-api.internal.csdn.net\u002F","VUE_APP_API_URL":"https:\u002F\u002Fcms-api.csdn.net\u002F","LOGIN_URL":"https:\u002F\u002Fpassport.csdn.net\u002Faccount\u002Flogin","VUE_APP_DOMAIN_SKILL":"https:\u002F\u002Fedu.csdn.net\u002F","VUE_APP_DOMAIN_PATH":"https:\u002F\u002Fedu.csdn.net\u002F","VUE_APP_COMMUNITY_API_URL":"https:\u002F\u002Fcommunity-api.csdn.net\u002F","VUE_APP_CCLOUD_API_URL":"https:\u002F\u002Fbizapi.csdn.net\u002Fcommunity-cloud\u002Fv1\u002F","VUE_APP_SKILL_API_URL":"https:\u002F\u002Fbizapi.csdn.net\u002Fskilltree\u002Fapi\u002F","VUE_APP_SEARCH_PLUGIN_API_URL":"https:\u002F\u002Fbizapi.csdn.net\u002Fsearchplugin\u002F","VUE_APP_COMMUNITY_ASK_API_URL":"https:\u002F\u002Fmp-ask.csdn.net\u002F","VUE_APP_ME_URL":"https:\u002F\u002Fme.csdn.net\u002F","VUE_APP_CCLOUD_RESUME":"https:\u002F\u002Fbizapi.csdn.net\u002Fjob-api\u002F","VUE_APP_CCLOUD_MAIN":"https:\u002F\u002Fwww.csdn.net\u002F","VUE_APP_CCLOUD_UC":"https:\u002F\u002Fwww.csdn.net\u002F","VUE_APP_CCLOUD_BZP_API_URL":"https:\u002F\u002Fbizapi.csdn.net\u002F","VUE_APP_CCLOUD_START_API_URL":"https:\u002F\u002Fmp-action.csdn.net\u002F","VUE_APP_PRACTIVE":"https:\u002F\u002Fbizapi.csdn.net\u002Fdaily-practice\u002F","VUE_APP_CCLOUD_HOSTPATH":"https:\u002F\u002Fbbs.csdn.net\u002F"},"queries":{"pageId":[],"domain":["ccloud.csdn.net\u002Fccloud\u002Fdetail1"],"id":["270013448"],"deviceType":"pc","isSpider":"","hostname":["bbs.csdn.net"]},"basePath":"bbs.csdn.net\u002Fccloud\u002Ftopics\u002F270013448","hrefUrl":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F270013448","active":0,"navBarFixed":false,"title":"请问,怎么将一个字符串内的所有参数,根据数据库表的同名称列名查询出的结果将它们替换?","isLive":false,"contentType":{"text":"text","picture":"picture","link":"link","video":"video","vote":"vote","live":"live","blog":"blog","long_text":"long_text","task_text":"task_text"},"liveUrl":"https:\u002F\u002Flive.csdn.net\u002Froom\u002Fiframe\u002F","spmExtra":{"id":227,"topicId":270013448},"keywords":"","description":"以下内容是CSDN社区关于请问,怎么将一个字符串内的所有参数,根据数据库表的同名称列名查询出的结果将它们替换?相关内容,如果想了解更多关于C#社区其他内容,请访问CSDN社区。"};</script><script type="text/javascript" src="https://csdnimg.cn/release/cmsfe/public/js/runtime.3e5c09eb.js"></script><script type="text/javascript" src="https://csdnimg.cn/release/cmsfe/public/js/chunk/common.7672e502.js"></script><script type="text/javascript" src="https://csdnimg.cn/release/cmsfe/public/js/chunk/tpl/ccloud-detail/index.243a94d0.js"></script></body> <!----> <script> window.csdn.sideToolbar = { options: { qr: { isShow: true, data: [ { imgSrc: 'https://csdnimg.cn/release/cmsfe/public/img/ewm.9010d6e5.png', desc: "关注公众号" }, ] }, help: { isShow: false, }, contentEl: document.getElementsByClassName("cloud-maintainer")[0] }, }; </script> <script src="https://g.csdnimg.cn/side-toolbar/2.9/side-toolbar.js" ></script> <!----> <!----> <!----> <script src="https://csdnimg.cn/release/blog_editor_html/release1.7.5/ckeditor/plugins/codesnippet/lib/highlight/highlight.pack.js"></script> <script src="https://g.csdnimg.cn/lib/editor-page-detail/v2.2.0/js/runDetail.min.js"></script> <!----> <!----> <!----> <!----> <!----> <!----> <script src="https://g.csdnimg.cn/collection-box/2.1.0/collection-box.js"></script> <!----> <!----> <!----> <!----> <script src="https://g.csdnimg.cn/common/csdn-cert/csdn-cert.js"></script> <!----></html>