首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Mysql使用存储过程快速添加百万数据

为了体现不加索引和添加索引区别,需要使用百万级数据,但是百万数据表,如果使用一条条添加,特别繁琐又麻烦,这里使用存储过程快速添加数据,用时大概4个小时。...COMMENT '用户类型 1,2,3,4 随机', PRIMARY KEY (`id`), KEY `idx_username` (`username`) USING BTREE ) 然后创建存储过程...,批量添加数据。...- floor(rand() * 800000)),floor(1 + rand() * 4)); set i = i + 1; end while; end 然后调用存储过程...call salesAdd() 改进版 虽然使用存储过程添加数据相对一个个添加更加便捷,快速,但是添加几百万数据要花几个小时时间也是很久,后面在网上找到不少资料,发现mysql每次执行一条语句都默认自动提交

3.4K20

Mysql使用存储过程快速添加百万数据

前言 为了体现不加索引和添加索引区别,需要使用百万级数据,但是百万数据表,如果使用一条条添加,特别繁琐又麻烦,这里使用存储过程快速添加数据,用时大概4个小时。...,批量添加数据。...DELIMITER//和DELIMITER;两句, DELIMITER是分割符意思,因为MySQL默认以";"为分隔符,如果我们没有声明分割符,那么编译器会把存储过程当成SQL语句进行处理,则存储过程编译过程会报错...,所以要事先用DELIMITER关键字申明当前段分隔符,这样MySQL才会将";"当做存储过程代码,不会执行这些代码。...然后调用存储过程 call salesAdd() 改进版 虽然使用存储过程添加数据相对一个个添加更加便捷,快速,但是添加几百万数据要花几个小时时间也是很久,后面在网上找到不少资料,发现mysql每次执行一条语句都默认自动提交

1.8K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    数据存储过程_数据存储过程语句

    大家好,又见面了,我是你们朋友全栈君。 一、存储过程与函数区别:   1.一般来说,存储过程实现功能要复杂一点,而函数实现功能针对性比较强。   ...二、存储过程优点:   1.执行速度更快 – 在数据库中保存存储过程语句都是编译过   2.允许模块化程序设计 – 类似方法复用   3.提高系统安全性 – 防止SQL注入   4.减少网络流通量...– 只要传输存储过程名称 系统存储过程一般以sp开头,用户自定义存储过程一般以usp开头 三、定义存储过程语法,”[” 里面的内容表示可选项   create proc 存储过程名   @参数...,就是调用者需要传递一个变量进来,然后在存储过程中为该变量完成赋值工作,存储过程执行完成以后,将执行对应结果返回给传递进来变量。...本文用3个题目,从建立数据库到创建存储过程,详细讲解数据功能。

    3.9K20

    MySQL存储过程_MySQL创建存储过程

    什么是存储过程 存储过程就是事先经过编译并存储数据库中一段 SQL 语句集合; 为什么使用存储过程 调用存储过程可以简化应用开发人员很多工作,减少数据数据库和应用服务器之间传输,对于提高数据处理效率是有好处...存储过程思想上很简单,就是数据库 SQL 语言层面的代码封装与重用。...存储过程特点: 封装,复用, 可以把某一业务SQL封装在存储过程中,需要用到时候直接调用即可; 可以接收参数,也可以返回数据, 在存储过程中,可以传递参数,也可以接收返回值; 减少网络交互,提升效率,...很明显,不够灵活,通常来说,在实际业务中,我们更希望存储过程能够接收参数,并且返回处理结果,以便提供给后续业务逻辑使用,这就需要用到存储过程输入输出参数了; 五、存储过程输入输出参数使用 存储过程中使用到参数类型...,使用存储过程也可以完成,但是存储函数局限在于,函数必须要有返回结果; 八、存储过程中游标的使用 游标(CURSOR)是用来存储查询结果集数据类型 , 在存储过程和函数中可以使用游标对结果集进行循环处理

    22.2K21

    数据库|存储过程管理

    问题描述 存储过程是由一系列Transact-SQL语句组成程序,它们经过编译后保存在数据库中。因此存储过程比普通Transact-SQL语句执行更快,且可以多次调用。...在SQL Server中包含存储过程类型主要包括:系统存储过程和用户定义存储过程。 解决方案 格式各样存储过程非常多,并且具有类似功能存储过程也不只有一两个。...同样,存储过程与表、视图以及关系图这些数据库对象一样,在创建之后可以根据需求对它进行修改和删除操作。 对于现成存储过程,我们有几种方法可以对该过程信息进行查看。...图1-1 查看存储过程 这样就可以查看到相应数据存储过程。接下来就看看怎么修改存储过程吧。在SQL Server 2008中通常使用ALTER PROCEDURE语句修改存储过程。...管理好数据存储过程,往往会有事半功倍效果!

    2K10

    Mysql数据库-存储过程

    Mysql数据库-存储过程 1. 存储过程和函数概述 1. 存储过程和函数是事先经过编译并存储数据库中一段SQL语句集合 a. 类似于java中方法: 是一段java代码集合 b....减少数据数据库和应用服务器之间传输,对于提高数据处理效率 java : 1....end$ delimiter ; -- 修改结束分隔符为; -- 调用存储过程 call 存储过程名称(实际参数) ; 2.2 实例: 2.2.1 准备数据 -- 准备数据 create database...int primary key auto_increment, name varchar(20), age int, gender varchar(5), score int ); -- 添加数据...查看和删除存储过程 3.1 语法: -- 查询数据库中所有的存储过程 select * from mysql.proc where db='数据库名称'; -- 删除存储过程 drop procedure

    11K10

    存储过程

    存储过程存储过程是用于将代码存储数据库端,通过存储过程名称就可以调用。...存储过程类似于java方法,但是也是有区别的,方法只能返回一个值,并且需要声明返回值类型,但是存储过程可以带出多个值,而且不需要声明返回值类型,而且也可以带值进和带值出。...,将一些功能操作使用存储过程来完成,并且存储数据库端,连接数据时候就可以直接使用名称进行调用。...虽然存储过程可以将一些功能在数据库端实现,并且只需要使用名称就可以调用,但是这种代码可移植性差,因为每个数据存储过程sql语法都不太一样。...所以不能直接将代码移植,移植的话需要重写一部分代码,所以存储过程实际上也并不经常使用,但是却是必须了解学习一个知识点。 创建存储过程: ? 在数据库中是可以进行编程,所以也是有流程控制语句

    2.1K10

    Mysql存储过程

    存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用一种数据库对象。...存储过程是为了完成特定功能SQL语句集,经编译创建并保存在数据库中,用户可通过指定存储过程名字并给定参数(需要时)来调用执行。...2.2、Mysql存储过程缺点   存储过程,往往定制化于特定数据库上,因为支持编程语言不同。当切换到其他厂商数据库系统时,需要重写原有的存储过程。   ...存储过程性能调校与撰写,受限于各种数据库系统。 3、存储过程创建和调用   存储过程就是具有名字一段代码,用来完成一个特定功能。   创建存储过程保存在数据数据字典中。...:默认情况下,存储过程和默认数据库相关联,如果想指定存储过程创建在某个特定数据库下,那么在过程名前面加数据库名做前缀。

    6.7K10

    存储过程

    存储过程 是SQL语句和控制语句预编译集合,以一个名称存储并作为一个单元处理 增强SQL语句功能和灵活性 实现较快执行速度 减少网络流量 参数:输入类型 输出类型 输入&&输出 创建存储过程 CREATE...OUT,表示该参数值可以被存储过程改变,并且可以返回 INOUT,表示该参数调用时指定,并且可以被改变和返回 特性 COMMENT:注释 CONSTRAINS SQL:包含SQL语句,但不包含读或写数据语句...NO SQL:不包含SQL语句 READS SQL DATA:包含读数据语句 MODIFIES SQL DATA:包含写数据语句 SQL SECURITY {DEFINER|INVOKE}指明谁有权限来执行...过程过程体是由合法SQL语句构成; 过程体可以是任意SQL语句; 过程体如果为复合结构则使用BEGIN...END 语句 复合结构可以包含声明,循环,控制结构 不带参数存储过程 CREATE...存储过程可以返回多个值;函数只能有一个返回值 存储过程一般独立来执行;而函数可以作为其他SQL语句组成部分来出现。

    1.8K41

    存储过程

    存储过程好处: 1.由于数据库执行动作时,是先编译后执行。然而存储过程是一个编译过代码块,所以执行效率要比T-SQL语句高。...2.一个存储过程在程序在网络中交互时可以替代大堆T-SQL语句,所以也能降低网络通信量,提高通信速率。 3.通过存储过程能够使没有权限用户在控制之下间接地存取数据库,从而确保数据安全。...每个过程参数仅用于该过程本身;相同参数名称可以用在其它过程中。默认情况下,参数只能代替常量,而不能用于代替表名、列名或其它数据库对象名称。有关更多信息,请参见 EXECUTE。...4.data_type:参数数据类型。所有数据类型(包括 text、ntext 和 image)均可以用作存储过程参数。不过,cursor 数据类型只能用于 OUTPUT 参数。...说明 对于可以是 cursor 数据类型输出参数,没有最大数目的限制。 5.VARYING: 指定作为输出参数支持结果集(由存储过程动态构造,内容可以变化)。仅适用于游标参数。

    2K30

    存储过程

    更好性能  * 存储过是预编译,在创建时编译;一般SQL是每次执行都会编译 2....功能实现更加灵活  * 存储过程可以使用条件判断和游标,有很强灵活性,还可以使用数据库内置函数,完成复杂判断和运算 3....减少网络传输  * 复杂多条SQL操作会消耗大量网络传输,多条SQL存入存储过程会降低网络负载 4....安全性  * 存储过程可以屏蔽对底层数据库对象直接访问  * 执行过程调用是可见,无法看到表结构和数据库,不能嵌入SQL,有助于避免SQL注入 缺点 1....事务涉及多个SQL语句或者操作多个表可以选择使用存储过程 2. 事务完成很复杂逻辑可以考虑使用存储过程 3. 比较复杂统计或汇总可以应用存储过程

    1.8K70

    Oracle存储过程及举例(几种参数情况存储过程

    大家好,又见面了,我是你们朋友全栈君。 存储过程 存储过程可以有多个或者零个输入输出参数,但通常没有返回值。...存储过程是已经编译好代码,所以执行效率非常高 存储过程创建语句 create [or replace] procedure 存储过程名 [(输入、输出参数、in/out模式参数)] is/as begin...sentences; [exception sentences;] end 存储过程名; 举例一个没有参数存储过程 create or replace procedure pro_no_par...举例一个带in模式参数存储过程 参数方式有三种:指定名称传递;按位置传递;混合方式传递 注意混合方式传递从使用【指定名称传递】位置开始,后面的参数必须使用【指定名称传递】 create or...*Action: 观察存储过程中变量使用(存储过程输入输入参数,字符型不用定义长度,内部字符型型变量是需要带长度) 内部变量不需要用declare,内部变量定义在as之后, begin end

    1.6K30

    SQL Server 存储过程_mysql存储过程教程

    SQL SERVER 存储过程 **相对于视图优势(为什么使用存储过程):** Sql Server中视图通过简单Select查询来解决多次复杂查询,但是视图不能提供业务逻辑功能,而存储过程可以...**什么是存储过程:** 存储过程(Procedure)是一组为了完成特定功能Sql语句集合,相当于C#中方法,只编译一次,经编译后存储数据库中,用户可以通过制定存储过程名称并给出所需参数来执行...存储过程优点: 模块化编程 写一次存储过程,可以多次从应用程序不同部分调用,重复使用 性能 存储过程提供更快代码执行,减少了网络流量负担。...安全 用户无需使用写任何Sql语句去执行存储过程,防止了Sql注入攻击 可维护性 一组需求改变,修改存储过程即可再次重复调用 存储过程缺点: 不可移植性 每种数据内部编程语法都不太相同,当你系统需要兼容多种数据库时最好不要用存储过程...存储过程有复杂运算,或者复杂运算过多的话,会增加数据库运行负担。

    5.5K30

    MySQL数据库之存储过程存储函数

    当想要在不同应用程序或平台上执行相同功能一段程序或者封装特定功能时,存储程序是非常有用数据库中存储程序可以看做是面向对编程中面向对象方法,它允许控制数据访问方式。   ...存储过程参数类型有三种,IN、out和INOUT:     a. in:数据只是从外部传入内部使用(值传递),可以是数值也可以是变量     b. out:只允许过程内部使用(不用外部数据),给外部使用...3 存储过程 3.1 创建存储过程   创建存储过程语法结构如下: CREATE PROCEDURE 过程名([[IN|OUT|INOUT] 参数名 数据类型[,[IN|OUT|INOUT] 参数名...3.2 创建存储函数   语法结构如下: CREATE FUNCTION 函数名([ 参数名 数据类型 [, …]]) RETURNS返回类型 BEGIN   过程体 END   存储过程存储函数一个很大不同就是制定参数...参数指定存储过程或函数特性,可能取值有:   CONTAINS SQL:子程序包含SQL语句,但不包含读或写数据语句。

    6.9K21

    数据蒋堂 | 存储过程利之弊

    来源:数据蒋堂 作者:蒋步星 本文长度为2240字,建议阅读5分钟 本文通过剖析存储过程优点,探查存储过程潜在风险及应用场景。...存储过程数据库领域中应用非常广泛技术,关于它利弊讨论由来已久,我们这里针对存储过程两个公认度较高优点进行剖析,从而更清楚存储过程潜在风险及应用场景。 存储过程利于界面与逻辑分离!...有些场合无法利用存储过程计算能力,就只能实现库外数据访问层了。比如数据来源涉及多数据库或非数据情况。 存储过程利于界面与逻辑分离?...不采用存储过程整体应用结构更为合理。 存储过程有更好数据计算性能? 实际测试表明,用存储过程实现数据计算,常常比用SQL取出数据后在外部计算性能更好。存储过程快在哪里了?...而且,如果把很多计算都放到存储过程中,并发运算时会加重数据负担,使本来就不快存储过程更慢。 存储过程性能更好,与其说是优势,倒不如说是被低效数据库访问接口绑架所致。

    80580
    领券