- [Ljava.lang.Object; cannot be cast to [Ljava.lang.String;
这些不会的
解释:这个错误是很常见的错误,错误的提示已经很清楚了就是java的Object数组不能转换成为String[]数组,这就说明你要转换的数组它本身是Object类型的数组,但是你却非要把它转换为String类的数组,这当然是错误的。示例:[java]viewplaincopypackagecom.dada;importjava.util.ArrayList;importjava.util.List;
- UE5 自动生成插件汇总:提升创作效率的得力助手
阿贾克斯的黎明
游戏开发ue5
目录UE5自动生成插件汇总:提升创作效率的得力助手目录一、地形生成插件1.Polycam2.M4电影级地形工具包3.WorldCreatortoUnrealEngine插件二、场景生成插件1.PrometheanAI2.physicallayout(物理布局)三、动画生成插件1.CasterAI2.blender骨骼绑定模型一键导入UE5场景插件MagicBoneUE5RigCreator四、特效
- #ScalersTalk成长会2019追溯阅读预行动#Day 16 10.25
筱轩私塾
今日阅读任务Part4(2015.4.3至2015.8.29)P29-86首篇:[480]Scalers:参加知乎「盐Cub2014」是一种怎样的体验?末篇:ScalersCast第11期:信息时代新文盲的三大特征文档下载链接:https://pan.baidu.com/s/1SqEXKwNdl6jTELawOJLEFw提取码:99z8今日阅读中,对你有启发的文字(摘抄原文“金句”,不要大段复制)
- systemd和OpenSSH
SEP5010
SystemsystemdOpenSSH
1systemd1.1配置文件/etc/systemd/system,AmbientCapabilities=CAP_SYS_NICECAP_NETCAP_NET_RAWCAP_NET_ADMINCAP_NET_BROADCAST/lib/systemd/system/run/systemd/system/usr/lib/systemd/user1.2commandssystemctllist-u
- 在python中安装geohash库
pip安装使用镜像网站安装pipinstall-iGeohashhttp://mirrors.aliyun.com/pypi/simple报错:CannotdeterminearchiveformatofC:\Users\Zz\AppData\Local\Temp\pip-req-build-t35bzb_f解决办法:重新安装,添加信任pipinstall-ihttps://pypi.tuna.t
- Java泛型
一念&
Javajava
在Java中,泛型(Generics)是一种允许在定义类、接口或方法时使用类型参数的特性。它的核心目的是增强类型安全性、减少类型转换错误,并提高代码复用性。下面通过关键概念和示例详细解释:一、泛型的核心作用类型安全:编译时检查类型错误,避免运行时ClassCastException消除强制类型转换:代码更简洁代码复用:一套逻辑可处理多种数据类型二、基本语法1.泛型类//T是类型参数(可自定义名称)
- Missing Coin Sum 硬币可以组成的连续面额上限
YouQian772
贪心算法
题目描述Youhavencoinswithpositiveintegervalues.Whatisthesmallestsumyoucannotcreateusingasubsetofthecoins?输入Thefirstinputlinehasanintegern(1≤n≤2*105):thenumberofcoins.Thesecondlinehasnintegersx1,x2,...,xn(
- LayerMask
全新的饭
官方文档LayerMask概念LayerMask是位掩码:指定要在Physics.Raycast中使用的层Unity中最多可设置32个层,其中前8层已被Unity占用,用户可以使用其余的24层位掩码的32位各自表示自己所代表的层是否要被使用(真或假)位掩码可以转为对应的int值可以通过一组层名获取对应的位掩码,可以根据层序数获取对应层名,也可以根据层名获取对应的层序数位掩码位掩码(BitMask)
- 【代码问题】【模型部署】部署千问时,ImportError: Cannot import available module of Qwen2_5_VLForConditionalGeneration
Catching Star
pythonpytorch开发语言
多半是环境的问题,最主要的是python版本要高python==3.12.9accelerate==1.8.1pipinstallqwen-vl-utils[decord]==0.0.8peft==0.14.0transformers==4.52.3torch==2.7.0torchvision==0.22.0modelscope==1.27.1
- ImportError: cannot import name ‘create_prompt_application‘ from ‘prompt_toolkit.shortcuts‘解决方案
weixin_43178406
Python基础课程
大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的知识进行总结与归纳,不仅形成深入且独到的理解,而且能够帮助新手快速入门。 本文主要介绍了ImportError:cannot
- 【每天一句,30天学好英语】
壹典心理咨询
【2023-3-18】早安春夏秋冬Everythingthatappearsinlifecannotbepossessed,canonlybeexperienced,infact,itdoesnotmatteraboutlosing,butjustpassing;Itdoesn'tmatterwhatyouget,it'sjustanexperience,whatyougothrough,even
- 粒子群优化在实际工程中的应用
国际期刊InternationalJournalofComplexityinAppliedScienceandTechnology,收录进化计算,机器学习和大数据方面的论文,网址:https://www.inderscience.com/jhome.php?jcode=ijcast粒子群优化(PSO)算法因其简单、高效和灵活性在实际工程中的许多领域得到了广泛应用。以下是一些具体的应用实例:1.结构
- 【Android Studio】安装Trae插件后Android Studio 启动崩溃问题处理
ganshenml
androidstudioandroidide
Mac安装AndroidStudioPreview启动失败问题排查实录(libjli.dylib错误)❗问题描述在macOS上安装AndroidStudioPreview(如2025.1.1或2025.1.2)时,IDE无法启动,并提示以下错误(即便重装):CannotstarttheruntimeCausedby:0:Failedtoload'libjli.dylib'1:dlopen(.../
- INVALID_COLUMN_NAME _AS_PATH
sparksql异常[INVALID_COLUMN_NAME_AS_PATH]ThedatasourceHiveFileFormatcannotsavethecolumnmin(birth_date)becauseitsnamecontainssomecharactersthatarenotallowedinfilepaths.Piease,useanallastorenameidemosqlSE
- 【论文精读】AGCRN-自适应图卷积循环神经网络
打酱油的葫芦娃
时序预测算法时空预测GCNGRUAGCRN交通预测
AGCRN模型是新南威尔士大学和悉尼科技大学的Bai等人发表在NeurIPS2020NeurIPS2020NeurIPS2020会议上的自适应图卷积循环神经网络,论文题目为:《AdaptiveGraphConvolutionalRecurrentNetworkforTrafficForecasting》,文章地址为:
- Android13 研究可以静态注册的广播
峥嵘life
android广播接收者android
Android13研究可以静态注册的广播文章目录Android13研究可以静态注册的广播一、前言二、静态注册和代码示例1、AI搜到可静态注册的常见系统广播类型三、静态注册、动态注册对比示例1、AndroidManifest.xml代码2、MyBroadcast.java3、MySerivce.java4、MainActivity.java代码5、验证过程(1)开机重启后应用启动的广播日志(2)开关
- stable diffusion No module named taming
图片gan模型部署报错。pipinstalltaming-transformersImportError:cannotimportname'VectorQuantizer2'from'taming.modules.vqvae.quantize',用https://github.com/CompVis/taming-transformers/blob/master/taming/modules/vq
- 【python】pyinstaller打包后运行exe可执行文件出现报错:ImportError: cannot import name ‘tarfile‘ from ‘backports‘
魔都吴所谓
实用工具Pythonpythonlinux
Traceback(mostrecentcalllast):File"D:\mdwsw\python\Lib\site-packages\PyInstaller\hooks\rthooks\pyi_rth_pkgres.py",line16,inimportpkg_resourcesFile"PyInstaller\loader\pyimod02_importers.py",line499,ine
- cx_Oracle.DatabaseError: DPI-1047: Cannot locate a 64-bit Oracle Client library:
首先确定pthon版本和oracle客户端版本一致即可,即都为64位或都为32位。但我这里要讲的是如何解决这个问题的过程:在python中的报错中提示了这个:DPI-1047:Cannotlocatea64-bitOracleClientlibrary:“Thespecifiedmodulecouldnotbefound”.Seehttps://cx-oracle.readthedocs.io/e
- 深度隐匿源IP:高防+群联AI云防护防绕过实战
群联云防护小杜
安全问题汇总tcp/ip人工智能网络协议服务器网络运维前端
隐蔽性挑战黑客常通过以下手段绕过基础防护:HTTPS证书嗅探:访问https://源站IP,通过证书域名匹配暴露真实IP历史解析记录追踪:从DNS数据库获取旧A记录CDN缓存渗透:利用边缘节点回源漏洞定位源站三重防护方案高防IP动态路由通过Anycast技术分散流量,黑客无法通过单一路径反推源IP。群联AI云防护隐匿层三层架构(流量入口层、AI调度层、加密回源层)彻底隔离源站。协议混淆+虚假诱饵返
- LeetCode #841 Keys and Rooms 钥匙和房间
air_melt
841KeysandRooms钥匙和房间Description:Therearenroomslabeledfrom0ton-1andalltheroomsarelockedexceptforroom0.Yourgoalistovisitalltherooms.However,youcannotenteralockedroomwithouthavingitskey.Whenyouvisitaroom
- npm build报错Cannot find module ‘webpack/lib/rules/BasicEffectRulePlugin‘解决方法
奔跑吧邓邓子
常见问题解答(FAQ)npm前端webpack
提示:“奔跑吧邓邓子”的常见问题专栏聚焦于各类技术领域常见问题的解答。涵盖操作系统(如CentOS、Linux等)、开发工具(如AndroidStudio)、服务器软件(如Zabbix、JumpServer、RocketMQ等)以及远程桌面、代码克隆等多种场景。针对如远程桌面无法复制粘贴、Kubernetes报错、自启动报错、各类软件安装报错、内存占用问题、网络连接问题等提供了详细的问题描述与有效
- 配图丨个性微信朋友圈背景图
画像集
每天早晨请记得打开手机,查收我的礼物hedaythatyouseemeldandIamalreadynot,havepatienceandtrytounderstandme…IfIgetdirtywheneating…ifIcannotdress…havepatience.RememberthehoursIspentteachingittoyou.If,whenIspeaktoyou,Irepea
- Python 程序无法找到 Oracle 的 64 位客户端库 (libclntsh.so)
期待着2013
python
数据库错误:DPI-1047:Cannotlocatea64-bitOracleClientlibrary:"libclntsh.so:cannotopensharedobjectfile:Nosuchfileordirectory".Seehttps://oracle.github.io/odpi/doc/installation.html#linuxforhelp这个错误表明Python程序无
- Lily的Scalers Talk第八轮新概念朗读持续力训练Day219 2023-07-06
草木Lily
Lesson14-1TheButterflyEffectBeyondtwoorthreedays,theworld'sbestweatherforecastsarespeculative,andbeyondsixorseventheyareworthless.TheButterflyEffectisthereason.Forsmallpiecesofweather--andtoaglobalfor
- Tomcat问题Cannot find /data/tomcat/bin/setclasspath.sh
问题:linux环境下,启动startup命令报错Cannotfind/data/tomcat/bin/setclasspath.shThisfileisneededtorunthisprogram任一目录下面执行下面命令unsetCATALINA_HOME再次启动即可暂时解决问题./startup.sh根本上解决则vim/etc/profile去掉CALALINE_HOME这个变量。
- tomcat启动报错Cannot find /usr/local/tomcat9/bin/setclasspath.sh解决办法
墨染琉璃
tomcattomcatjava服务器
最近在练习在虚拟机上部署项目并运行就遇到了好多的问题逐个记录下来吧我在tomcat启动的时候报了一个这样的错误后来百度了一番找到了解决的办法Cannotfind/usr/local/tomcat/bin/setclasspath.shThisfileisneededtorunthisprogram在任意目录执行命令unsetCATALINA_HOME之后再执行./startup.sh再后来我每一次
- Cannot find tomcat目录/bin/setclasspath.sh This file is needed to run this program
sailor7
linuxtomcat
问题:Cannotfind/opt/tomcat/apache-tomcat-8.5.79/bin/setclasspath.shThisfileisneededtorunthisprogram原因:没有在setclasspath.sh上设置JAVA_HOME和JRE_HOME解决:打开setclasspath.sh,设置JAVA_HOME和JRE_HOMEsudovisetclasspath.s
- C#编程,.Net 依赖注入IOC框架入门之一 CastleWindso
子不语
依赖注入.net依赖注入IOC
一、简介Castle是.net平台上的一个开源项目,为企业级开发和WEB应用程序开发提供完整的服务,用于提供IOC的解决方案.IOC被称为控制反转或者依赖注入(DependencyInjection)。Windsor是Castle的一个IOC容器。它构建于MicroKernel之上,功能非常之强大,能检测类并了解使用这些类时需要什么参数,检测类型和类型之间工作依赖性,并提供服务或者发生错误时提供预
- ROS报错:ERROR: cannot launch node of type [rqt_joint_trajectory_controller/rqt_joint_trajectory.......
机械专业的计算机小白
ROS报错ros
详细报错:ERROR:cannotlaunchnodeoftype[rqt_joint_trajectory_controller/rqt_joint_trajectory_controller]:rqt_joint_trajectory_controllerROSpath[0]=/opt/ros/melodic/share/rosROSpath[1]=/home/rosmelodic/catki
- 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