- react 全局状态管理 redux的使用
小刘的代码仓库
react.js前端javascript
redux为全局状态管理类似vuex目录redux官网一、安装npminstallredux二、创建三、修改四、接受五、拆分、合并六、异步处理redux-thunk的使用七、redux-promise的使用八、async和await九、react-redux的使用十、修改soter的属性值十一、异步的完整代码redux官网入门Redux|Redux中文官网一、安装npminstallredux二、
- react【五】redux/reduxToolkit/手写connext
KIKIo_
reactreact.js前端javascript
文章目录1、回顾纯函数2、redux2.1redux的基本使用2.2通过action修改store的数值2.3订阅state的变化2.4目录结构2.5Redux的使用过程2.6redux的三大原则2.7Redux官方图3、redux在React中的使用4、react-redux使用4.1react-redux的基本使用4.2异步请求redux-thunk4.3对redux代码结构进行优化和redu
- Redux(0x02)-redux进阶
ChuckieWIll
Redux进阶1Redux-thunk中间件GIthub地址:Redux-thunk对Redux-thunk中间件的理解此中间件是指在action和store中间注意是Redux的中间件,而不是React的中间件此中间件就是对dispatch重新做了一次封装当传入的action是对象时,直接交给store处理当传入的action是函数时,先执行函数,若函数中有对象形式的action再交给store
- 巧用Redux
Redux类适用所有React生态项目import{applyMiddleware,combineReducers,legacy_createStoreascreateStore,Store,compose,}from"redux";importthunkfrom"redux-thunk";import{connect,Provider}from"react-redux";import{Actio
- Redux中间件redux-thunk使用详解
噢,我明白了
reduxreact中间件javascript开发语言
什么是redux-thunk?redux-thunk主要用于处理reducer无法处理的异步1.什么是异步?同步:就是指前一个任务完成之后在继续执行下一个任务,程序的执行顺序与任务的排列顺序是一致的、同步的。异步:每一个任务有一个或多个回调函数(callback),前一个任务结束后,不执行下一个任务,而是执行回调函数,后一个任务不等前一个任务结束就执行,所以程序的执行顺序与任务的排列顺序是不一致的
- React一学就会(7): 细说redux及其应用
码蚁先生
前端react技术积累react.js前端前端框架javascriptRedux
不知不觉一个星期结束了,很快就要过年了,中间休息了两天,小孩生病,我也有点感冒了,还好,我的这个React基础教学课程也基本结束了。大家有不明白的可以留言问我,我一定竭尽所能的帮助你。后面几节课就React常用的几款第三方插件进行详细的讲解。本系列课程以ReactRedux、ReactRouter、Axios、styled-components、redux-thunk、ReactTransitio
- redux配置中间件后,redux调试工具DEVTools不能用,这可咋整
EcbJS
redux配置中间件后,redux调试工具DEVTools不能用,这可咋整我的第一篇技术博客,请各位大佬多多指点,问题如上,我使用的是redux-think中间件,主要用来存放一些ajax请求,配置过程仿照官网,使用webpack来配置打开控制台输入,首先进入我们创建的项目中npminstall--saveredux-thunk安装完成后,打开store下的index.jsimport{creat
- 边黎安 reactnataive 0.60 react 最深最全的react 的原理探究 死磕源码
大神边黎安
1redvx的中间件的原理是什么?改装dispactch派发action-》(中间件(redvx-thunk(转化成fun))(store.dispatch))store=》reducerredvx-thunk(源码)redux-thunk的源码非常简洁,出去空格一共只有11行,这11行中如果不算上},则只有8行。最后三行模块的导出方法很好理解,//thunk的内容如下({dispatch,get
- redux、react-redux、redux-thunk、immutable、redux-immutable 实现各组件同步、异步状态管理
暴躁程序员
1.安装依赖库注意:immutable版本,如果出错可版本回退到immutable@^3.8.2npmireduxreact-reduxredux-thunkimmutable@^3.8.2redux-immutable-S2.在程序index.js入口文件中,导入store,使用Provider组件包裹根组件被Provider包裹的组件,都可以获取和操作store状态importReactfro
- Redux
ios_prestige
react.jsjavascript前端
一、课程说明1.目的为React移动端项目做支撑:redux、redux-thunk、react-redux(useDispath、useSelector)、redux-devtools-extension2.内容顺序(课程目标)1)redux单独使用2)react-redux结合react项目进行使用3)中间件react-thunk的基本使用4)useDispatch、useSelector的基
- 【React】TS项目配置Redux
田本初
ReactReduxreact.jsjavascriptecmascript
前提条件在React中使用Redux,官方要求安装两个插件,ReduxToolkit和react-reduxReduxToolkit(RTK):官方推荐编写Redux逻辑的方式,是一套工具的集合集,简化书写方式。简化store的配置方式内置immer支持可变式状态修改内置thunk更好的异步创建react-redux:用来链接Redux和React组件的中间件。安装npmi@reduxjs/too
- 面试 React 框架八股文十问十答第九期
程序员小白条
React八股文学习面试react.js职场和发展javascript八股文前端前端框架
面试React框架八股文十问十答第九期作者:程序员小白条,个人博客相信看了本文后,对你的面试是有一定帮助的!关注专栏后就能收到持续更新!⭐点赞⭐收藏⭐不迷路!⭐1)Redux中异步的请求怎么处理在Redux中,处理异步请求通常使用中间件来实现。常见的中间件有redux-thunk、redux-saga等。以下是使用redux-thunk的简单示例://安装redux-thunk:npminstal
- redux中间件原理及实现
Jason_Zeng
最近看跟react相关库的源码,越来越发现里面中间件机制的特别重要,各种类库都是基于此封装的功能,比如redux简单的几个函数,却巧妙的实现了中间件创建,组合,调用,下面就一一分析先看下面最简单的redux使用例子import{createStore,applyMiddleware,compose}from'redux'importthunkfrom'redux-thunk'importreduc
- redux 异步处理之 redux-thunk 和 redux-saga
CondorHero
书接上文:在上次案例我们使用redux做了一个加法器。现在我们想让它延迟两秒钟在加一。这就涉及异步处理了,只不过我们平时的异步处理是发送Ajax而已。延迟两秒一、异步添加第一种添加方法{setTimeout(()=>this.props.dispatch({type:"ADD"}),2000);}}>按我加一第二种添加方法importReact,{Component}from"react";imp
- ES6 - generator 函数与异步
恒星的背影
Thunk函数:constThunk=function(fn){returnfunction(...args){returnfunction(callback){returnfn.call(this,...args,callback);}};};生成fs.readFile的Thunk函数:varreadFileThunk=Thunk(fs.readFile);readFileThunk(fileA
- 【Redux】自己动手实现redux-thunk
古狼(Jenkin_guwolf)
前端开发前端javascript开发语言
1.前言在原始的redux里面,action必须是plainobject,且必须是同步。而我们经常使用到定时器,网络请求等异步操作,而redux-thunk就是为了解决异步动作的问题而出现的。2.redux-thunk中间件实现源码functioncreateThunkMiddleware(extra){return({dispatch,getState})=>next=>action=>{if(
- Redux中同步 action 与异步 action 最大的区别是什么
帅帅的mum
同步只返回一个普通的action对象,异步操作中途会返回一个promise函数,在promise函数处理完毕后也会返回一个action对象,thunk中间件就是判断如果返回的是promise函数则不传递给reducer,直到检测到是普通的action对象才传递给reducer处理
- React面试题汇总 --2
DOM曼珠沙华
Reactjavascript前端react.js
1.何为redux,解决什么问题操作流程使用场景优缺点?Redux使用详解(一)Redux的核心思想与基本使用__聪明勇敢有力气的博客-CSDN博客Redux使用详解(一)Redux的核心思想与基本使用https://blog.csdn.net/weixin_65402230/article/details/1281936562.ReduxThunk的作用是什么?关于redux-thunk的作用,
- redux-thunk 异步实现
_贺瑞丰
1.redux同步简介image.png2.thunk异步实现思路从action发出到store接受用reducer处理的过程中,没有可以插入异步的地方。我们拦截action的发送,在dispatch的过程中,dispatch一个异步函数,异步函数执行完成后才dispatch一个同步的action,送达store.dispatch发送的不再是纯js对象,而是一个函数!!!!在这个函数里面可以做各种
- 对Redux中间件的理解?常用的中间件有哪些?实现原理?
北海屿鹿
React中间件
一、是什么中间件(Middleware)是介于应用系统和系统软件之间的一类软件,它使用系统软件所提供的基础服务(功能),衔接网络上应用系统的各个部分或不同的应用,能够达到资源共享、功能共享的目的二、常用的中间件有很多redux中间件,如:redux-thunk:用于异步操作redux-logger:用于日志记录上述的中间件都需要通过applyMiddlewares进行注册,作用是将所有的中间件组成
- react-redux
现_状
index.jsimportReactfrom'react';importReactDomfrom'react-dom';import{createStore,applyMiddleware,compose}from'redux';importthunkfrom'redux-thunk'import{Provider}from'react-redux';importAppfrom'./App';i
- Redux与React环境准备、实现counter(及传参)、异步获取数据
怕冷的火焰(~杰)
reduxreact.js前端前端框架
环境说明:一:说明在React中使用redux,官方要求安装两个其他插件:ReduxToolkit和react-redux1.ReduxToolKit(RTK)-官方推荐编写Redux逻辑的方式,是一套工具的集合集,简化书写方式(简化store的配置方式内置immer支持可变式状态修改内置thunk更好的异步创建)2.react-redux-用来链接Redux和React组件的中间件-------
- 使用Redux管理异步数据
喵巨人
简介Redux相关知识参考:Redux基本使用Redux中的reducer只能处理同步如果需要用Redux处理异步请求,可以使用异步相关的插件。一般有两个步骤:1、异步请求接口;2、将请求结果存到store中比较常用的有:redux-thunk、redux-sagaredux-thunk使用安装:npmiredux-thunk--save使用applyMiddleware添加中间件使用compos
- 在React项目中使用redux
WindyZ_34ec
前言:此博文是记录我在b站上观看redux教学视频的记录原视频链接在此react-redux看这个视频就够了!一、安装相关的插件1、安装reduxnpminstall-Sredux2、安装redux-thunknpminstall-Sredux-thunk3、在chrome应用商店安装redux-devtools二、引入相关插件import{createStore,combineReducers,
- 到底什么是Redux中间件——基于Redux-thunk和Redux-saga理解分析
雪燃归来
前面的文章中,我们介绍过,React在发送Ajax等异步请求的时候,我们应该将异步请求的逻辑放在componentDidMount钩子函数中。但是有一个问题,当一个组件中有很多个异步请求操作,都放在这个钩子函数中,那么这个钩子函数会显得很臃肿,该怎么解决这个问题了?在React中我们可以通过引入中间件的机制来解决这个问题。常用的中间件有redux-thunk和dedux-saga。一、Redux中
- UE4C++泛型蓝图节点
混迹中的咸鱼
UEC++ue4c++
UE4C++泛型蓝图节点注:这篇文章是博主边学边写的便于自己学习,很多东西可能解释得不是很详细。此处采用的是UE4.26要求:掌握基本的c++知识+基本的UE元组符的使用,例如:UFUNCTION等等全局搜索CustomThunk关键字,我们可发现泛型蓝图节点的实现规律,包含:UFUNCTION的函数声明;自定义Thunk函数体DECLARE_FUNCTION(execFunctionName);
- 从0到0.01入门React | 005.精选 React 面试题
ai_todo
从0到0.01入门Reactreact.js前端前端框架
前端开发工程师(主业)、技术博主(副业)、已过CET6阿珊和她的猫_CSDN个人主页牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js和Egg.js开发企业级健康管理项目》、《带你从入门到实战全面掌握uni-app》文章目录介绍一下Redux-Thunk。在使用Redux时,如何避免状态的污染?如何使用Redux-Dispatch
- 从0到0.01入门React | 002.精选 React 面试题
ai_todo
从0到0.01入门Reactreact.js前端前端框架
前端开发工程师(主业)、技术博主(副业)、已过CET6阿珊和她的猫_CSDN个人主页牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js和Egg.js开发企业级健康管理项目》、《带你从入门到实战全面掌握uni-app》文章目录在Redux中,是否可以使用类来定义Action?在Redux中,如何使用Thunk中间件来处理异步操作?详
- 前端追梦人Redux Toolkit教程(简化redux的使用)
ilovethesunshine
前端react
一.简介该包是redux的工具集,旨在解决以下问题:store的配置复杂想让redux更加好用需要安装大量额外包redux要求写很多模板代码二.包含的apiconfigureStore()提供简化的配置选项和良好的默认值。它可以自动组合众多的reducers,添加用户提供的任何Redux中间件,默认情况下包括Redux-thunk(处理异步Action的中间件),并支持使用ReduxDevTool
- react学习笔记-06 -- Redux & react-redux & redux-thunk
weixin_47360323
前端reactreact.js学习javascript
ReduxRedux中文文档安装npminstall--saveredux原理图storestore(仓库)存放整个应用的state。createStore创建仓库import{createStore}from'redux';importreducerfrom'./store/reducer';letstore=createStore(reducer)//createStore还有第二个参数,表示
- Spring4.1新特性——综述
jinnianshilongnian
spring 4.1
目录
Spring4.1新特性——综述
Spring4.1新特性——Spring核心部分及其他
Spring4.1新特性——Spring缓存框架增强
Spring4.1新特性——异步调用和事件机制的异常处理
Spring4.1新特性——数据库集成测试脚本初始化
Spring4.1新特性——Spring MVC增强
Spring4.1新特性——页面自动化测试框架Spring MVC T
- Schema与数据类型优化
annan211
数据结构mysql
目前商城的数据库设计真是一塌糊涂,表堆叠让人不忍直视,无脑的架构师,说了也不听。
在数据库设计之初,就应该仔细揣摩可能会有哪些查询,有没有更复杂的查询,而不是仅仅突出
很表面的业务需求,这样做会让你的数据库性能成倍提高,当然,丑陋的架构师是不会这样去考虑问题的。
选择优化的数据类型
1 更小的通常更好
更小的数据类型通常更快,因为他们占用更少的磁盘、内存和cpu缓存,
- 第一节 HTML概要学习
chenke
htmlWebcss
第一节 HTML概要学习
1. 什么是HTML
HTML是英文Hyper Text Mark-up Language(超文本标记语言)的缩写,它规定了自己的语法规则,用来表示比“文本”更丰富的意义,比如图片,表格,链接等。浏览器(IE,FireFox等)软件知道HTML语言的语法,可以用来查看HTML文档。目前互联网上的绝大部分网页都是使用HTML编写的。
打开记事本 输入一下内
- MyEclipse里部分习惯的更改
Array_06
eclipse
继续补充中----------------------
1.更改自己合适快捷键windows-->prefences-->java-->editor-->Content Assist-->
Activation triggers for java的右侧“.”就可以改变常用的快捷键
选中 Text
- 近一个月的面试总结
cugfy
面试
本文是在学习中的总结,欢迎转载但请注明出处:http://blog.csdn.net/pistolove/article/details/46753275
前言
打算换个工作,近一个月面试了不少的公司,下面将一些面试经验和思考分享给大家。另外校招也快要开始了,为在校的学生提供一些经验供参考,希望都能找到满意的工作。 
- HTML5一个小迷宫游戏
357029540
html5
通过《HTML5游戏开发》摘抄了一个小迷宫游戏,感觉还不错,可以画画,写字,把摘抄的代码放上来分享下,喜欢的同学可以拿来玩玩!
<html>
<head>
<title>创建运行迷宫</title>
<script type="text/javascript"
- 10步教你上传githib数据
张亚雄
git
官方的教学还有其他博客里教的都是给懂的人说得,对已我们这样对我大菜鸟只能这么来锻炼,下面先不玩什么深奥的,先暂时用着10步干净利索。等玩顺溜了再用其他的方法。
操作过程(查看本目录下有哪些文件NO.1)ls
(跳转到子目录NO.2)cd+空格+目录
(继续NO.3)ls
(匹配到子目录NO.4)cd+ 目录首写字母+tab键+(首写字母“直到你所用文件根就不再按TAB键了”)
(查看文件
- MongoDB常用操作命令大全
adminjun
mongodb操作命令
成功启动MongoDB后,再打开一个命令行窗口输入mongo,就可以进行数据库的一些操作。输入help可以看到基本操作命令,只是MongoDB没有创建数据库的命令,但有类似的命令 如:如果你想创建一个“myTest”的数据库,先运行use myTest命令,之后就做一些操作(如:db.createCollection('user')),这样就可以创建一个名叫“myTest”的数据库。
一
- bat调用jar包并传入多个参数
aijuans
下面的主程序是通过eclipse写的:
1.在Main函数接收bat文件传递的参数(String[] args)
如: String ip =args[0]; String user=args[1]; &nbs
- Java中对类的主动引用和被动引用
ayaoxinchao
java主动引用对类的引用被动引用类初始化
在Java代码中,有些类看上去初始化了,但其实没有。例如定义一定长度某一类型的数组,看上去数组中所有的元素已经被初始化,实际上一个都没有。对于类的初始化,虚拟机规范严格规定了只有对该类进行主动引用时,才会触发。而除此之外的所有引用方式称之为对类的被动引用,不会触发类的初始化。虚拟机规范严格地规定了有且仅有四种情况是对类的主动引用,即必须立即对类进行初始化。四种情况如下:1.遇到ne
- 导出数据库 提示 outfile disabled
BigBird2012
mysql
在windows控制台下,登陆mysql,备份数据库:
mysql>mysqldump -u root -p test test > D:\test.sql
使用命令 mysqldump 格式如下: mysqldump -u root -p *** DBNAME > E:\\test.sql。
注意:执行该命令的时候不要进入mysql的控制台再使用,这样会报
- Javascript 中的 && 和 ||
bijian1013
JavaScript&&||
准备两个对象用于下面的讨论
var alice = {
name: "alice",
toString: function () {
return this.name;
}
}
var smith = {
name: "smith",
- [Zookeeper学习笔记之四]Zookeeper Client Library会话重建
bit1129
zookeeper
为了说明问题,先来看个简单的示例代码:
package com.tom.zookeeper.book;
import com.tom.Host;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.ZooKeeper;
import org.apache.zookeeper.Wat
- 【Scala十一】Scala核心五:case模式匹配
bit1129
scala
package spark.examples.scala.grammars.caseclasses
object CaseClass_Test00 {
def simpleMatch(arg: Any) = arg match {
case v: Int => "This is an Int"
case v: (Int, String)
- 运维的一些面试题
yuxianhua
linux
1、Linux挂载Winodws共享文件夹
mount -t cifs //1.1.1.254/ok /var/tmp/share/ -o username=administrator,password=yourpass
或
mount -t cifs -o username=xxx,password=xxxx //1.1.1.1/a /win
- Java lang包-Boolean
BrokenDreams
boolean
Boolean类是Java中基本类型boolean的包装类。这个类比较简单,直接看源代码吧。
public final class Boolean implements java.io.Serializable,
- 读《研磨设计模式》-代码笔记-命令模式-Command
bylijinnan
java设计模式
声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
/**
* GOF 在《设计模式》一书中阐述命令模式的意图:“将一个请求封装
- matlab下GPU编程笔记
cherishLC
matlab
不多说,直接上代码
gpuDevice % 查看系统中的gpu,,其中的DeviceSupported会给出matlab支持的GPU个数。
g=gpuDevice(1); %会清空 GPU 1中的所有数据,,将GPU1 设为当前GPU
reset(g) %也可以清空GPU中数据。
a=1;
a=gpuArray(a); %将a从CPU移到GPU中
onGP
- SVN安装过程
crabdave
SVN
SVN安装过程
subversion-1.6.12
./configure --prefix=/usr/local/subversion --with-apxs=/usr/local/apache2/bin/apxs --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr --with-openssl=/
- sql 行列转换
daizj
sql行列转换行转列列转行
行转列的思想是通过case when 来实现
列转行的思想是通过union all 来实现
下面具体例子:
假设有张学生成绩表(tb)如下:
Name Subject Result
张三 语文 74
张三 数学 83
张三 物理 93
李四 语文 74
李四 数学 84
李四 物理 94
*/
/*
想变成
姓名 &
- MySQL--主从配置
dcj3sjt126com
mysql
linux下的mysql主从配置: 说明:由于MySQL不同版本之间的(二进制日志)binlog格式可能会不一样,因此最好的搭配组合是Master的MySQL版本和Slave的版本相同或者更低, Master的版本肯定不能高于Slave版本。(版本向下兼容)
mysql1 : 192.168.100.1 //master mysq
- 关于yii 数据库添加新字段之后model类的修改
dcj3sjt126com
Model
rules:
array('新字段','safe','on'=>'search')
1、array('新字段', 'safe')//这个如果是要用户输入的话,要加一下,
2、array('新字段', 'numerical'),//如果是数字的话
3、array('新字段', 'length', 'max'=>100),//如果是文本
1、2、3适当的最少要加一条,新字段才会被
- sublime text3 中文乱码解决
dyy_gusi
Sublime Text
sublime text3中文乱码解决
原因:缺少转换为UTF-8的插件
目的:安装ConvertToUTF8插件包
第一步:安装能自动安装插件的插件,百度“Codecs33”,然后按照步骤可以得到以下一段代码:
import urllib.request,os,hashlib; h = 'eb2297e1a458f27d836c04bb0cbaf282' + 'd0e7a30980927
- 概念了解:CGI,FastCGI,PHP-CGI与PHP-FPM
geeksun
PHP
CGI
CGI全称是“公共网关接口”(Common Gateway Interface),HTTP服务器与你的或其它机器上的程序进行“交谈”的一种工具,其程序须运行在网络服务器上。
CGI可以用任何一种语言编写,只要这种语言具有标准输入、输出和环境变量。如php,perl,tcl等。 FastCGI
FastCGI像是一个常驻(long-live)型的CGI,它可以一直执行着,只要激活后,不
- Git push 报错 "error: failed to push some refs to " 解决
hongtoushizi
git
Git push 报错 "error: failed to push some refs to " .
此问题出现的原因是:由于远程仓库中代码版本与本地不一致冲突导致的。
由于我在第一次git pull --rebase 代码后,准备push的时候,有别人往线上又提交了代码。所以出现此问题。
解决方案:
1: git pull
2:
- 第四章 Lua模块开发
jinnianshilongnian
nginxlua
在实际开发中,不可能把所有代码写到一个大而全的lua文件中,需要进行分模块开发;而且模块化是高性能Lua应用的关键。使用require第一次导入模块后,所有Nginx 进程全局共享模块的数据和代码,每个Worker进程需要时会得到此模块的一个副本(Copy-On-Write),即模块可以认为是每Worker进程共享而不是每Nginx Server共享;另外注意之前我们使用init_by_lua中初
- java.lang.reflect.Proxy
liyonghui160com
1.简介
Proxy 提供用于创建动态代理类和实例的静态方法
(1)动态代理类的属性
代理类是公共的、最终的,而不是抽象的
未指定代理类的非限定名称。但是,以字符串 "$Proxy" 开头的类名空间应该为代理类保留
代理类扩展 java.lang.reflect.Proxy
代理类会按同一顺序准确地实现其创建时指定的接口
- Java中getResourceAsStream的用法
pda158
java
1.Java中的getResourceAsStream有以下几种: 1. Class.getResourceAsStream(String path) : path 不以’/'开头时默认是从此类所在的包下取资源,以’/'开头则是从ClassPath根下获取。其只是通过path构造一个绝对路径,最终还是由ClassLoader获取资源。 2. Class.getClassLoader.get
- spring 包官方下载地址(非maven)
sinnk
spring
SPRING官方网站改版后,建议都是通过 Maven和Gradle下载,对不使用Maven和Gradle开发项目的,下载就非常麻烦,下给出Spring Framework jar官方直接下载路径:
http://repo.springsource.org/libs-release-local/org/springframework/spring/
s
- Oracle学习笔记(7) 开发PLSQL子程序和包
vipbooks
oraclesql编程
哈哈,清明节放假回去了一下,真是太好了,回家的感觉真好啊!现在又开始出差之旅了,又好久没有来了,今天继续Oracle的学习!
这是第七章的学习笔记,学习完第六章的动态SQL之后,开始要学习子程序和包的使用了……,希望大家能多给俺一些支持啊!
编程时使用的工具是PLSQL