大佬们,mysql调用了存储过程,如何获得该存储过程的名字

存储过程里调用了 存储过程,存储过程有可能报错,现在想记录报错的存储过程名,求指点有没有类似 sqlService里 ERROR_procedure()的方法

2个回答

可以通过在调用的每个存储过程中定义异常处理,根据不同存储过程返回不同的值来判断到底是哪一个存储过程运行出错。
这是我自己写的一个异常处理的例子:
/*异常处理 异常定义必须在变量定义之后 */
DECLARE EXIT HANDLER FOR SQLEXCEPTION
BEGIN
GET DIAGNOSTICS condition 1 @sqlcode = RETURNED_SQLSTATE, @sqlerr = MESSAGE_TEXT;
SET state='0';
SET @b_id=(SELECT b_id FROM T_BATCH WHERE r_state='1');
SET @sp_name='haw_bus_orig_proc';
INSERT INTO sp_error_log(b_id,sp_name,sqlcode,sqlerr)
VALUES(@b_id,@sp_name,@sqlcode,@sqlerr);
END;
我这个例子是如果存储过程运行出错,将返回0,并将本身的存储过程名及出错信息等记录在表中。@b_id可以忽略

weixin_43637245
weixin_43637245 算了,采纳你的吧
一年多之前 回复
weixin_43637245
weixin_43637245 我也是用的mysql自带的异常处理加错误缓存做的,但是我想着有没有方法在这个里面直接获取当前的存储过程的名字
一年多之前 回复

记录报错应该使用 MySQL里面的触发器。

weixin_43637245
weixin_43637245 回复: 还请您不啬指教
一年多之前 回复
weixin_43637245
weixin_43637245 可这前提是有获取异常的方法啊
一年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
pymysql(0.9.2) + mysql(5.7.23 ) 调用存储过程,获取输出参数有时为空

os : 16.4, python : 3.6, pymysql : 0.9.2, mysql : 5.7.23 调用存储过程,获取输出参数有时为空 存储过程为 ``` CREATE DEFINER=`root`@`%` PROCEDURE `P_TEST`(OUT aCode varchar(4), OUT aMsg varchar(16), IN aAppName varchar(16)) COMMENT '测试' BEGIN set aCode = '1'; set aMsg = '错误信息'; select aAppName; END ``` python端代码为: ``` def executeProc(aProcName, aParams): tmpDbConn = None tmpCursor = None try: tmpListData = list(aParams) tmpListData.insert(0, '') tmpListData.insert(0, '') aParams = tuple(tmpListData) print(aProcName, aParams) tmpDbConn = DBPools.connection() tmpCursor = DBPools.connection().cursor() tmpCursor.callproc(aProcName, aParams) tmpDatas1 = tmpCursor.fetchall() print(tmpDatas1) tmpCursor.execute('select @_%s_0, @_%s_1 ;' % (aProcName, aProcName)) tmpDatas2 = tmpCursor.fetchall() print(tmpDatas2) code = tmpDatas2[0][0] msg = tmpDatas2[0][1] tmpCursor.close() tmpDbConn.close() return (code, msg, tmpDatas1) except InternalError as e: print(e) return (sqlServerInternalError, all_code[sqlServerInternalError]) except ProgrammingError as e: print(e) return (sqlServerProgrammingError, all_code[sqlServerProgrammingError]) except InterfaceError as e: print(e) return (sqlServerConnectFail, all_code[sqlServerConnectFail]) except OperationalError as e: print(e) return (sqlServerInterfaceError, all_code[sqlServerInterfaceError]) except Exception as e: print(e) return (sqlServerException, all_code[sqlServerException]) finally: if tmpCursor: tmpCursor.close() if tmpDbConn: tmpDbConn.close() if __name__ == "__main__": for i in range(100): executeProc('P_TEST', ('a')) ``` 测试结果为: ``` P_TEST ('', '', 'a') (('a',),) (('1', '错误信息'),) P_TEST ('', '', 'a') (('a',),) ((None, None),) P_TEST ('', '', 'a') (('a',),) ((None, None),) P_TEST ('', '', 'a') (('a',),) (('1', '错误信息'),) P_TEST ('', '', 'a') (('a',),) (('1', '错误信息'),) ``` 这种情况只是偶尔出现,单独调用存储过程也是没有问题的,请大佬帮忙解决一下,谢谢!

关于mysql存储过程执行时间长,求优化思路?

现有一张包含经(lon)纬(lat)度的A (c_pc_stake_info)表,在另一张B表( b_pc_compaction_info)中也包含有经(lon)纬(lat)度字段,需要返回的数据是A表的经纬度、通过A表每两条数据的经纬度和B表的经纬度相比较,得到B表数据在A表这两条数据经纬度之间的个数 CREATE DEFINER=`root`@`%` PROCEDURE `compaction`( out num INTEGER, out startLon DOUBLE, out startLat DOUBLE, out startStakeNum varchar(100), out endLon DOUBLE, out endLat DOUBLE, out endStakeNum varchar(100) ) BEGIN -- 定义变量 DECLARE s int DEFAULT 0; DECLARE stakeId INTEGER; DECLARE lons DOUBLE; DECLARE lats DOUBLE; DECLARE stakeNum VARCHAR(50); DECLARE compaction_lon DOUBLE; DECLARE compaction_lat DOUBLE; -- 临时表 -- 封装最后所得数据 create temporary table if not exists stake_info_vo ( number INTEGER, startLon DOUBLE, startLat DOUBLE, startStakeNum VARCHAR(50), endLon DOUBLE, endLat DOUBLE, endStakeNum VARCHAR(50) ); -- 经B表筛选过的数据插入此表 create temporary table if not exists lon_lat ( lon1 DOUBLE, lat1 DOUBLE ); BEGIN -- B表筛选后的数据 declare lonLat CURSOR for SELECT lon, lat from b_pc_compaction_info where 1=1 and SUBSTRING_INDEX(create_time," ",1) = SUBSTRING_INDEX((select max(create_time) from b_pc_compaction_info)," ",1) -- ; and LENGTH(SUBSTRING_INDEX(lon,".",-1)) = 8 and LENGTH(SUBSTRING_INDEX(lat,".",-1)) = 8; -- insert into lon_lat VALUES (compaction_lon,compaction_lat); DECLARE CONTINUE HANDLER FOR NOT FOUND SET s=1; open lonLat; fetch lonLat into compaction_lon,compaction_lat; set s = 0; while(s=0) do insert into lon_lat VALUES (compaction_lon,compaction_lat); fetch lonLat into compaction_lon,compaction_lat; end while; -- 关闭游标 close lonLat; END; BEGIN -- 定义游标,并将sql结果集赋值到游标中 DECLARE report CURSOR FOR -- 查询A表数据 select id,lon,lat,stake_num from c_pc_stake_info ORDER BY id; -- 声明当游标遍历完后将标志变量置成某个值 DECLARE CONTINUE HANDLER FOR NOT FOUND SET s=1; -- 打开游标 open report; -- 将游标中的值赋值给变量,注意:变量名不要和返回的列名同名,变量顺序要和sql结果列的顺序一致 fetch report into stakeId,lons,lats,stakeNum; set s=0; -- 当s不等于1,也就是未遍历完时,会一直循环 while (s<>1) do -- 通过遍历获取A表的第二条数据 SELECT lon, lat, stake_num into endLon,endLat,endStakeNum FROM c_pc_stake_info WHERE id = (SELECT MIN(id) FROM c_pc_stake_info WHERE id > stakeId); -- 获取B表数据在A表每两条数据经纬度之间的个数 SELECT count(1) into num from lon_lat where 1=1 and lon1 between lons and endLon and lat1 between lats and endLat ; SET startLon = lons; set startLat = lats; set startStakeNum = stakeNum; -- set num = 1; INSERT INTO stake_info_vo VALUES (num,startLon,startLat,startStakeNum,endlon,endlat,endStakeNum); -- 当s等于1时表明遍历以完成,退出循环 fetch report into stakeId,lons,lats,stakeNum; end while; -- 关闭游标 close report; SELECT * from stake_info_vo; -- SELECT * from lon_lat; end; truncate TABLE stake_info_vo; truncate TABLE lon_lat; END 第一次用csdn,问题有些格式不是太对,望大佬们谅解 ```

mysql 存储过程定义变量出错

各位大佬帮忙看看哪里有语法错误 CREATE PROCEDURE update_customer_code () BEGIN DECLARE mysort INT;             DECLARE done tinyint; DECLARE customerId VARCHAR; DECLARE cur CURSOR FOR SELECT customer_id FROM customer_association_process;     OPEN cur;   WHILE done DO FETCH cur INTO customerId; CALL superior_splice (customerId);       SET mysort = mysort + 1;    END WHILE;     CLOSE cur; END; # 错误提示: [Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '      SET mysort = 1;     DECLARE done tinyint; SET done = 1; D' at line 4

mysql 怎样在存储过程中实现逐条判断输出结果

create procedure tt() begin if exists(select x.a from t1 x where x.a='a1' limit 1) then if exists(select y.b from t1 y where y.b='b2' limit 1) then if exists(select z.c from t1 z where z.c='c3' limit 1) then if exists(select n.d from t1 n where n.d='d4' limit 1) then select x.a,y.b,z.c,n.d from t1 x,t1 y,t1 z,t1 n; end if; end if; end if; end if; end 然后我自己写了一下 出来结果是一个笛卡尔积 判断语句跟没加一样 怎么正确写一下啊 大概就是一张表四个字段 ABCD 然后各自有四个值 a1 a2 a3 a4 b1 b2 b3 b4 c1 c2 c3 c4 d1 d2 d3 d4 q请教一下怎样实现判断A 是否为a1 如果是a1 然后a1与b2关联 B字段就是b2 如果B字段是b2然后判断一下C字段是否是c3 如果是c3那么D字段就是d4 最后输出结果是a1b2c3d4 我知道可以吧t1表虚拟成四张表然后做一个关联 限定一下ABCD的值也可以求出来a1b2c3d4但是与要求用的方法不一样 有没有大佬看看这个功能怎么实现 谢谢了![图片说明](https://img-ask.csdn.net/upload/201807/31/1533030512_102194.png)

MySQL:请问游标的使用局限于存储过程吗?能否单独地使用游标。

有MySQL高手吗?想请教一个关于游标的问题。 请问游标的使用局限于存储过程吗?能否单独地使用游标? 比如在命令行中直接使用类似语句: ```mysql DECLARE ordernumbers CURSOR FOR SELECT order_num FROM orders; ``` 事实上我在mysql(5.7.12)版本 ubuntu(18.04)的 mysql 命令行环境下进行过测试 ,上述语句会报语法错误。但是,我查的资料上都没有明确说明游标不能直接使用,所以 想问下有没有知道的大佬能够解答一下,感谢!

如何使用c++通过ADO调用mysql有参存储过程并获取结果集

先放代码,遇到的问题是 调用mysql**有参**存储过程时获取不到结果集 ``` #include <iostream> #include <atlstr.h> #import "MSADO15.DLL" rename_namespace("ADOCG") rename("EOF","EndOfFile") using namespace ADOCG; using namespace std; int main() { try { HRESULT hr = CoInitialize(NULL); assert(SUCCEEDED(hr));//返回值可判断初始化COM是否成功,请用SUCCEEDED来判断 _CommandPtr m_DBCommand; //命令对象 _RecordsetPtr m_DBRecordset; //记录对象 _ConnectionPtr m_DBConnection; //数据对象 //创建对象 m_DBCommand.CreateInstance(__uuidof(Command)); m_DBRecordset.CreateInstance(__uuidof(Recordset)); m_DBConnection.CreateInstance(__uuidof(Connection)); //效验数据 if (m_DBCommand == NULL) throw TEXT("创建 m_DBCommand 对象失败"); if (m_DBRecordset == NULL) throw TEXT("创建 m_DBRecordset 对象失败"); if (m_DBConnection == NULL) throw TEXT("创建 m_DBConnection 对象失败"); CString m_strConnect; //构造连接 m_strConnect.Format(TEXT("Driver={MySQL ODBC 8.0 Unicode Driver};UID=%s;PWD=%s;DataBase=%s;Persist Security Info=True;Server=%s;Port=%d;Option=3"), "hhh", "123456", "Test", "192.168.1.115", 3306); //打开连接 m_DBConnection->Open(_bstr_t(m_strConnect), L"", L"", adConnectUnspecified); m_DBConnection->CursorLocation = adUseClient; m_DBCommand->ActiveConnection = m_DBConnection; assert(SUCCEEDED(hr));//返回值可判断初始化COM是否成功,请用SUCCEEDED来判断 LONG lParameterCount = m_DBCommand->Parameters->Count; if (lParameterCount > 0L) { for (LONG i = lParameterCount; i > 0; i--) { m_DBCommand->Parameters->Delete(i - 1); } } //添加参数 _ParameterPtr Parameter; Parameter = m_DBCommand->CreateParameter("wServerID", adInteger, adParamInput, sizeof(LONG), _variant_t((LONG)0)); m_DBCommand->Parameters->Append(Parameter); Parameter = m_DBCommand->CreateParameter("wMachineID", adInteger, adParamInput, sizeof(LONG), _variant_t((LONG)0)); m_DBCommand->Parameters->Append(Parameter); m_DBCommand->CommandText = "LoadGameRoomItem2"; m_DBCommand->CommandType = adCmdText; m_DBRecordset = m_DBCommand->Execute(NULL, NULL, adCmdStoredProc); long RecordCount = m_DBRecordset->GetRecordCount(); cout << RecordCount << endl; _variant_t DBVarValue; if (m_DBRecordset->EndOfFile != VARIANT_TRUE) { FieldsPtr RecordFields = m_DBRecordset->GetFields(); DBVarValue = RecordFields->GetItem("ServerID")->GetValue(); WORD wValue = DBVarValue; } } catch (_com_error& ComError) { cout << ComError.Description() << endl; } return 0; } ``` 储存过程如下 ``` CREATE DEFINER=`root`@`%` PROCEDURE `LoadGameRoomItem2`( in wServerID INT, in wMachineID INT ) BEGIN SELECT * from gameroominfo; END ``` 目前遇到的问题就是,怎么也获取不到结果集,RecordCount始终为零(强行读取提示“BOF 或 EOF 中有一个是“真”,或者当前的记录已被删除,所需的操作要求一个当前的记录。”并不是 显示没有其实有,而是确实没有结果集),但是如果我将参数去掉 ``` //添加参数 // _ParameterPtr Parameter; // Parameter = m_DBCommand->CreateParameter("wServerID", adInteger, adParamInput, sizeof(LONG), _variant_t((LONG)0)); // m_DBCommand->Parameters->Append(Parameter); // Parameter = m_DBCommand->CreateParameter("wMachineID", adInteger, adParamInput, sizeof(LONG), _variant_t((LONG)0)); // m_DBCommand->Parameters->Append(Parameter); CREATE DEFINER=`root`@`%` PROCEDURE `LoadGameRoomItem2`( ) BEGIN SELECT * from gameroominfo; END ``` 那么则可以获得结果集(RecordCount数量为40,if (m_DBRecordset->EndOfFile != VARIANT_TRUE)判断能进去,ServerID也能读取到),我试过在存储过程前面后面分别加一个update判断过是不是存储过程没执行成功,但是不管有参无参存储过程,两个Updata都走到了,而且不管有参无参直接在数据库调用都是有结果集的 数据库日志如下 ``` 190923 15:32:38 7534 Connect hhh@DESKTOP-989OGGH on Test 7534 Query SET NAMES utf8 7534 Query SET character_set_results = NULL 7534 Query SET SQL_AUTO_IS_NULL = 0 7534 Query select database() 7534 Query select database() 7534 Query SELECT @@tx_isolation 7534 Query set @@sql_select_limit=DEFAULT 7534 Query call LoadGameRoomItem2 7534 Quit 190923 15:47:54 7621 Connect hhh@DESKTOP-989OGGH on Test 7621 Query SET NAMES utf8 7621 Query SET character_set_results = NULL 7621 Query SET SQL_AUTO_IS_NULL = 0 7621 Query select database() 7621 Query select database() 7621 Query SELECT @@tx_isolation 7621 Prepare call LoadGameRoomItem2(?, ?) 7621 Query set @@sql_select_limit=DEFAULT 7621 Execute call LoadGameRoomItem2('0', '0') 7621 Close stmt 7621 Quit ``` 困扰小弟好几天了,希望各位神仙大佬能帮帮小弟T_T ----------------------------------编辑分界线-------------------------------- ![图片说明](https://img-ask.csdn.net/upload/201909/23/1569232509_546308.png)![图片说明](https://img-ask.csdn.net/upload/201909/23/1569232516_421262.png) 如图,是要像这样处理一张表的内容的,单单用output参数是做不到的,主要问题在如果不加参数这些东西是可以读出来的,但是加了参数就获取不到结果集了。。。。

如何把以下SQLServer版本的存储过程改为MYSQL版本?

CREATE PROCEDURE proStudentByNo21(@sNo char(7), @sName varchar(20) OUTPUT, @avg numeric(5, 1) OUTPUT ) AS BEGIN SELECT @sName=studentName FROM Student WHERE studentNo=@sNo SELECT @avg=avg(score) FROM Score WHERE studentNo=@sNo GROUP BY studentNo END 执行存储过程proStudentByNo2 1 DECLARE @sNamevarchar(20), @avg numeric(5, 1) EXECUTE proStudentByNo21 '0800001', @sName OUTPUT, @avg OUTPUT SELECT @sName, @avg 把以上SQLServer版本的存储过程改为MYSQL版本并运行 (萌新,求教,求救大佬)

oracle数据库如何创建存储过程

创建存储过程检测指定教师、指定节次是否有课; 创建存储过程生成指定班级的课程表; 跪求各位大佬帮帮我~~~~~~~

Mybaits调用存储过程报错There is no setter for property named 'result' in 'class java.lang.Class'

存储过程: CREATE PROCEDURE my_test (OUT result VARCHAR(10)) BEGIN SELECT DATE_FORMAT(NOW(),'%Y%m%d') INTO result; -- SELECT result; END Mybatis调用 <select id="getPredureValue" resultType="string" statementType="CALLABLE"> CALL my_test (#{result,mode=OUT,jdbcType=VARCHAR}) </select> 报错: 严重: Servlet.service() for servlet [spring] in context with path [/MyBatis_06_ssm] threw exception [Request processing failed; nested exception is org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.reflection.ReflectionException: Could not set property 'result' of 'class java.lang.Class' with value '_20190316_' Cause: org.apache.ibatis.reflection.ReflectionException: There is no setter for property named 'result' in 'class java.lang.Class'] with root cause org.apache.ibatis.reflection.ReflectionException: There is no setter for property named 'result' in 'class java.lang.Class' at org.apache.ibatis.reflection.Reflector.getSetInvoker(Reflector.java:401) at org.apache.ibatis.reflection.MetaClass.getSetInvoker(MetaClass.java:168) at org.apache.ibatis.reflection.wrapper.BeanWrapper.setBeanProperty(BeanWrapper.java:177) at org.apache.ibatis.reflection.wrapper.BeanWrapper.set(BeanWrapper.java:59) 如上mybatis调用存储过程报错,实际上是查询出了结果:20190316,就是在返回结果的时候报错了,不知道是存储过程的问题还是mybatis调用问题, 返回结果这里程序使用的是BeanWrapper,如果使用MapWrapper应该就没有问题,但不明白哪里出问题了,请大佬们帮忙啊!

mysql大数据如何存储方便

我有大概500亿以上的数据 每条数据除了相应的主键ID外 由7个坐标点外加两个字段组成 属于全球范围内的坐标点 请问大佬如何存储这些数据比较好 另外 这500亿以上的数据还要每个再分化100份 请问 如何建表 mysql数据库 数据开始一次性生成 后续主要以查询为主 偶尔会update一下 update量小 单次最多100条数据

MS_SQL的存储过程中,如何判断update语句执行成功 ?

我需要写一个存储过程,根据前面的更新语句是否成功,决定后面的语句是否执行。看了很久旧帖子说要用@@ROWCOUNT判断,但是经过我的测试,发现这种判断并不支持并发的场景,很容易因为其他sql语句的执行导致判断结果发生变化。 跪求大佬们提供支持高并发的判断方法!

MySQL社区版支持数据最大存储量问题

因为最近要启动一个项目,想请教各位大佬一个问题:MySQL社区版是否支持100T的数据量(主要做存储用)? 是否支持50+个客户端的并发访问? 由于之前用MySQL存储的数据量小,没有存储过这么大数据的经验 还有就是如果处理这么大的数据量,需要什么配置的计算机性能?

delphi 7 执行有返回参数的oracle存储过程

存储过程名 Pro_zxc 参数 : 卡号 ,编号, 数量,金额,时间,错误代码(0/1),返回消息 ``` exce Pro_zxc('301007087','001','1','1000',to_date('2018-03-17','yyyy-mm-dd'),:Result_Code,:Result_Code) ``` 我用 ``` OrclSql := 'exce Pro_zxc(' + QuotedStr(edtID.Text) + ',' + QuotedStr(edtNum.Text) + ',''' + IntToStr(CNum) +''',' + QuotedStr(HcDBLabelEdit3.Text) + ',' + 'to_date('+QuotedStr(dateSigContractDate.Text)+','+'''yyyy-mm-dd'')'+',:Result_Code,:Result_Code)'; WriteLog(OrclSql); UniQueryMoney.Close; UniQueryMoney.SQL.Clear; UniQueryMoney.SQL.Add(OrclSql); WriteLog('UniQueryMoney.SQL.Add(OrclSql);'); UniQueryMoney.Open; //报错 ora-00900 invalid sql statement WriteLog('UniQueryMoney.Open;'); Result_Num := UniQueryMoney.ParamByName('Result_Code').AsString; WriteLog('Result_Num = '+Result_Num); Result_Msg := UniQueryMoney.ParamByName('Result_Msg').AsString; WriteLog('Result_Msg = '+Result_Msg); ``` 这样报错,有没有大佬能够教导一下,这个存储过程我delphi7该怎样执行

存储过程萌新,求助大佬们指点,在线等

![图片说明](https://img-ask.csdn.net/upload/201807/04/1530670691_566166.png) 怎么将update中语句包含ID,creater放到指定游标thecursor中

利用存储过程创建表提示权限不足,但是单独创建就可以

利用存储过程创建表提示权限不足,但是单独创建就可以 ``` create or replace procedure PRC_GZF_BZ_YWSLID(ywslid in verchar2) as L_YWSLID verchar2(30); tpg_gzfspbnum verchar2(30); begin L_YWSLID:=ywslid; tpg_gzfspbnum:='tpg_gzfspb'||L_SLIDID; execute immediate' create table '||tpg_gzfspbnum||' as select * from GZF_ZFBZ.tpg_gzfspb@gzf_zfbz where ywslid = '''||L_YWSLID||''''; end PRC_GZF_BZ_YWSLID; ``` 各位大佬,求教.

SQL Server 数据库存储过程缓存表sys.dm_exec_procedure_stats的具体作用

关于数据库存储过程 看到很多文章提出可以通过表sys.exec_procedure_stat来查询数据库存储过程 执行了多少次、执行的执行计划如何、执行的平均读写如何、执行平均需要多少时间等信息。 具体代码如: ``` SELECT a.name AS 存储过程名称, a.create_date AS 创建日期, a.modify_date AS 修改日期, b.cached_time AS 缓存时间, b.last_execution_time AS 最后执行日期, b.execution_count AS 执行次数 FROM sys.procedures a LEFT JOIN sys.dm_exec_procedure_stats b ON a.object_id = b.object_id AND b.database_id = '11' WHERE a.is_ms_shipped = 0 ORDER BY b.execution_count desc ``` 但它的查询结果里有很多我很确信执行了的存储过程完全没有执行记录。 想请大佬指导一下这个表sys.exec_procedure_stat到底什么时候发挥作用?什么情况下能更新这个表?什么情况无法更新? 如何能在数据库中记录存储过程执行情况? 感激不尽

求个大佬帮忙改下这段mysql的存储过程 一直报错 改了半天

delimiter // create procedure pp() declare aa varchar(10); declare bb varchar(10); declare cc varchar(10); declare dd varchar(10); declare ee varchar(10); declare ff varchar(10); declare gg varchar(10); declare ii int not null; deciare c1 cursor selecr * from (select id id1,a from t3 where id=1) a, (select id id2,b from t3 where id=2) b, (select id id3,c from t3 where id=3) c, (select id id4,d from t3 where id=4) d, (select id id5,e from t3 where id=5) e, (select id id6,f from t3 where id=6) f, (select id id7,g from t3 where id=7) g; open c1; fetch next from c1 into aa,bb,cc,dd,ee,ff,gg,ii; declare x int; begin for i in c1; read_loop:Loop select count(m) into x from ( select i.id1 m union select i.id2 union select i.id3 union select i.id4 union select i.id5 union select i.id6 union select i.id7 ); if x/7>0.5 then insert into t4 values(i.a,i.b,i.c,i.d,i.e,i.f,i.g); commit; end if; leave read_loop; end loop read_loop; close c1; end; // 本意是用游标找到t3表的的笛卡尔积中每行数据每个字段id重复不超过一半的数据然后插入到t4表中 但是写出来一直报错 新手 一直改然后一直报错 哪位哥哥姐姐看下这个怎么修正能运行 帮帮忙 改完能用的话我可以再给20c 拜谢

Sql Server2012 如何在存储过程中实现根据判断插入更新数据

目标表唯一字段:hrid,该字段不为空也不为NULL!![图片说明](https://img-ask.csdn.net/upload/201712/21/1513843904_856663.png) ![图片说明](https://img-ask.csdn.net/upload/201712/21/1513844104_641753.png) 通过存储过程插入数据时加入判断条件语句,判断结果hrid字段与数据源中有相同值时删除目标表相同数据(整条记录),在做插入!请各位大佬给出语句!存储过程如下 create procedure [dbo].[PACS_His_Report_insert] as insert into PACS_His_Report (a,b,c,d....) select (a,b,c,d....) [192.168.0.18].pacs4all.dbo.His_Report a (nolock) where a.RepDate > (select max(b.RepDate) from PACS_His_Report b)

oracle中执行存储过程比直接执行打印语句慢得多

因为调用的语句需要大量的条件,最初在写语句时,使用 WHERE (参数1 IS NULL OR T.条件1 = 参数1) 这种形式来写,但是条件一多的时候,发现大量的or会导致语句特别慢,后改用动态sql拼接条件,但是发现这种写法非常不稳定,经常会特别慢,有时候在sql后面拼接一个空格都会导致查询速度变化非常大。同样的语句,在存储过程里面执行,然后dbms打印出来之后再执行,速度差距在5倍以上,有没有大佬能告诉一下,这种情况要怎么优化,目前还没有找到什么办法。之前在拼接语句后面拼上" AND 1= 1 "后速度正常了两天,然后现在查询速度又变慢了,实在是没办法了

定量遥感中文版 梁顺林著 范闻捷译

这是梁顺林的定量遥感的中文版,由范闻捷等翻译的,是电子版PDF,解决了大家看英文费时费事的问题,希望大家下载看看,一定会有帮助的

Java 最常见的 200+ 面试题:面试必备

这份面试清单是从我 2015 年做了 TeamLeader 之后开始收集的,一方面是给公司招聘用,另一方面是想用它来挖掘在 Java 技术栈中,还有那些知识点是我不知道的,我想找到这些技术盲点,然后修复它,以此来提高自己的技术水平。虽然我是从 2009 年就开始参加编程工作了,但我依旧觉得自己现在要学的东西很多,并且学习这些知识,让我很有成就感和满足感,那所以何乐而不为呢? 说回面试的事,这份面试...

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

远程工具,免费

远程工具,免费

java jdk 8 帮助文档 中文 文档 chm 谷歌翻译

JDK1.8 API 中文谷歌翻译版 java帮助文档 JDK API java 帮助文档 谷歌翻译 JDK1.8 API 中文 谷歌翻译版 java帮助文档 Java最新帮助文档 本帮助文档是使用谷

csma/ca和csma/cd的matlab仿真源代码带有详细的注释

csma/ca和csma/cd的matlab仿真源代码带有详细的注释,载波侦听,随意设置节点数,带有炫酷的图形展示效果。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

软件测试入门、SQL、性能测试、测试管理工具

软件测试2小时入门,让您快速了解软件测试基本知识,有系统的了解; SQL一小时,让您快速理解和掌握SQL基本语法 jmeter性能测试 ,让您快速了解主流来源性能测试工具jmeter 测试管理工具-禅道,让您快速学会禅道的使用,学会测试项目、用例、缺陷的管理、

pokemmo的资源

pokemmo必须的4个rom 分别为绿宝石 火红 心金 黑白 还有汉化补丁 资源不错哦 记得下载

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

无线通信中的智能天线:IS-95和第3代CDMA应用_.pdf

无线通信中的智能天线:IS-95和第3代CDMA应用_.pdf

设计模式(JAVA语言实现)--20种设计模式附带源码

课程亮点: 课程培训详细的笔记以及实例代码,让学员开始掌握设计模式知识点 课程内容: 工厂模式、桥接模式、组合模式、装饰器模式、外观模式、享元模式、原型模型、代理模式、单例模式、适配器模式 策略模式、模板方法模式、观察者模式、迭代器模式、责任链模式、命令模式、备忘录模式、状态模式、访问者模式 课程特色: 笔记设计模式,用笔记串连所有知识点,让学员从一点一滴积累,学习过程无压力 笔记标题采用关键字标识法,帮助学员更加容易记住知识点 笔记以超链接形式让知识点关联起来,形式知识体系 采用先概念后实例再应用方式,知识点深入浅出 提供授课内容笔记作为课后复习以及工作备查工具 部分图表(电脑PC端查看):

Java8零基础入门视频教程

这门课程基于主流的java8平台,由浅入深的详细讲解了java SE的开发技术,可以使java方向的入门学员,快速扎实的掌握java开发技术!

玩转Linux:常用命令实例指南

人工智能、物联网、大数据时代,Linux正有着一统天下的趋势,几乎每个程序员岗位,都要求掌握Linux。本课程零基础也能轻松入门。 本课程以简洁易懂的语言手把手教你系统掌握日常所需的Linux知识,每个知识点都会配合案例实战让你融汇贯通。课程通俗易懂,简洁流畅,适合0基础以及对Linux掌握不熟练的人学习; 【限时福利】 1)购课后按提示添加小助手,进答疑群,还可获得价值300元的编程大礼包! 2)本月购买此套餐加入老师答疑交流群,可参加老师的免费分享活动,学习最新技术项目经验。 --------------------------------------------------------------- 29元=掌握Linux必修知识+社群答疑+讲师社群分享会+700元编程礼包。 &nbsp;

极简JAVA学习营第四期(报名以后加助教微信:eduxy-1)

想学好JAVA必须要报两万的培训班吗? Java大神勿入 如果你: 零基础想学JAVA却不知道从何入手 看了一堆书和视频却还是连JAVA的环境都搭建不起来 囊中羞涩面对两万起的JAVA培训班不忍直视 在职没有每天大块的时间专门学习JAVA 那么恭喜你找到组织了,在这里有: 1. 一群志同道合立志学好JAVA的同学一起学习讨论JAVA 2. 灵活机动的学习时间完成特定学习任务+每日编程实战练习 3. 热心助人的助教和讲师及时帮你解决问题,不按时完成作业小心助教老师的家访哦 上一张图看看前辈的感悟: &nbsp; &nbsp; 大家一定迫不及待想知道什么是极简JAVA学习营了吧,下面就来给大家说道说道: 什么是极简JAVA学习营? 1. 针对Java小白或者初级Java学习者; 2. 利用9天时间,每天1个小时时间; 3.通过 每日作业 / 组队PK / 助教答疑 / 实战编程 / 项目答辩 / 社群讨论 / 趣味知识抢答等方式让学员爱上学习编程 , 最终实现能独立开发一个基于控制台的‘库存管理系统’ 的学习模式 极简JAVA学习营是怎么学习的? &nbsp; 如何报名? 只要购买了极简JAVA一:JAVA入门就算报名成功! &nbsp;本期为第四期极简JAVA学习营,我们来看看往期学员的学习状态: 作业看这里~ &nbsp; 助教的作业报告是不是很专业 不交作业打屁屁 助教答疑是不是很用心 &nbsp; 有奖抢答大家玩的很嗨啊 &nbsp; &nbsp; 项目答辩终于开始啦 &nbsp; 优秀者的获奖感言 &nbsp; 这是答辩项目的效果 &nbsp; &nbsp; 这么细致的服务,这么好的氛围,这样的学习效果,需要多少钱呢? 不要1999,不要199,不要99,只要9.9 是的你没听错,只要9.9以上所有就都属于你了 如果你: 1、&nbsp;想学JAVA没有基础 2、&nbsp;想学JAVA没有整块的时间 3、&nbsp;想学JAVA没有足够的预算 还等什么?赶紧报名吧,抓紧抢位,本期只招300人,错过只有等时间待定的下一期了 &nbsp; 报名请加小助手微信:eduxy-1 &nbsp; &nbsp;

Python数据清洗实战入门

本次课程主要以真实的电商数据为基础,通过Python详细的介绍了数据分析中的数据清洗阶段各种技巧和方法。

董付国老师Python全栈学习优惠套餐

购买套餐的朋友可以关注微信公众号“Python小屋”,上传付款截图,然后领取董老师任意图书1本。

linux下利用/proc进行进程树的打印

在linux下利用c语言实现的进程树的打印,主要通过/proc下的目录中的进程文件,获取status中的进程信息内容,然后利用递归实现进程树的打印

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

HoloLens2开发入门教程

本课程为HoloLens2开发入门教程,讲解部署开发环境,安装VS2019,Unity版本,Windows SDK,创建Unity项目,讲解如何使用MRTK,编辑器模拟手势交互,打包VS工程并编译部署应用到HoloLens上等。

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

MySQL 8.0.19安装教程(windows 64位)

话不多说直接开干 目录 1-先去官网下载点击的MySQL的下载​ 2-配置初始化的my.ini文件的文件 3-初始化MySQL 4-安装MySQL服务 + 启动MySQL 服务 5-连接MySQL + 修改密码 先去官网下载点击的MySQL的下载 下载完成后解压 解压完是这个样子 配置初始化的my.ini文件的文件 ...

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

网络工程师小白入门--【思科CCNA、华为HCNA等网络工程师认证】

本课程适合CCNA或HCNA网络小白同志,高手请绕道,可以直接学习进价课程。通过本预科课程的学习,为学习网络工程师、思科CCNA、华为HCNA这些认证打下坚实的基础! 重要!思科认证2020年2月24日起,已启用新版认证和考试,包括题库都会更新,由于疫情原因,请关注官网和本地考点信息。题库网络上很容易下载到。

Ubuntu18.04安装教程

Ubuntu18.04.1安装一、准备工作1.下载Ubuntu18.04.1 LTS2.制作U盘启动盘3.准备 Ubuntu18.04.1 的硬盘空间二、安装Ubuntu18.04.1三、安装后的一些工作1.安装输入法2.更换软件源四、双系统如何卸载Ubuntu18.04.1新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列...

sql语句 异常 Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your

在我们开发的工程中,有时候会报 [Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ------ 这种异常 不用多想,肯定是我们的sql语句出现问题,下面...

西南交通大学新秀杯数学建模试题

题目比较难,如果符合大家的口味欢迎大家下载哈,提高你的思维想象能力

Windows版YOLOv4目标检测实战:训练自己的数据集

课程演示环境:Windows10; cuda 10.2; cudnn7.6.5; Python3.7; VisualStudio2019; OpenCV3.4 需要学习ubuntu系统上YOLOv4的同学请前往:《YOLOv4目标检测实战:训练自己的数据集》 课程链接:https://edu.csdn.net/course/detail/28745 YOLOv4来了!速度和精度双提升! 与 YOLOv3 相比,新版本的 AP (精度)和 FPS (每秒帧率)分别提高了 10% 和 12%。 YOLO系列是基于深度学习的端到端实时目标检测方法。本课程将手把手地教大家使用labelImg标注和使用YOLOv4训练自己的数据集。课程实战分为两个项目:单目标检测(足球目标检测)和多目标检测(足球和梅西同时检测)。 本课程的YOLOv4使用AlexyAB/darknet,在Windows系统上做项目演示。包括:安装软件环境、安装YOLOv4、标注自己的数据集、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算)和先验框聚类分析。还将介绍改善YOLOv4目标检测性能的技巧。 除本课程《Windows版YOLOv4目标检测实战:训练自己的数据集》外,本人将推出有关YOLOv4目标检测的系列课程。请持续关注该系列的其它视频课程,包括: 《Windows版YOLOv4目标检测实战:人脸口罩佩戴检测》 《Windows版YOLOv4目标检测实战:中国交通标志识别》 《Windows版YOLOv4目标检测:原理与源码解析》

Spring Boot -01- 快速入门篇(图文教程)

Spring Boot -01- 快速入门篇 今天开始不断整理 Spring Boot 2.0 版本学习笔记,大家可以在博客看到我的笔记,然后大家想看视频课程也可以到【慕课网】手机 app,去找【Spring Boot 2.0 深度实践】的课程,令人开心的是,课程完全免费! 什么是 Spring Boot? Spring Boot 是由 Pivotal 团队提供的全新框架。Spring Boot...

相关热词 c# dbml文件 修改 c#遍历tree c# 能够控制单片机 c#对象写入数据库 c# 添加activex c#2005 json c# 数据库在云端 c# 字符串移位加密 c#禁用滚轮 c#实体类list去重复
立即提问