前提 : 1数据库和表都是utf8_general_ci格式 2程序代码也是utf-8格式,且使用了mysql_query("set names utf-8"); 及 htmlentities ENT_QUOTES...原因及解决方法: 原因可能是mysql在安装的时候的设置不对。 解决方法,你无法改变供应商重新安装mysql的话,只能接受这样的事实。...就让它乱码吧, 需要导出数据的话可以自己手写代码用csv或者xls导出。...Language选项,把默认的中文 - Chinese simplified-gb2312改成 中文 - Chinese simplified,则左边的MySQL 字符集会变成UTF-8 Unicode...如果数据库编码没有问题,则 确保所有页面都是 utf-8 无BOM 另外在调用页面 mysql_query 前也 写入 mysql_query("set names utf8") 就可以保证无乱码
存储过程特点: 封装,复用, 可以把某一业务SQL封装在存储过程中,需要用到的时候直接调用即可; 可以接收参数,也可以返回数据, 在存储过程中,可以传递参数,也可以接收返回值; 减少网络交互,提升效率,...delimiter 指定SQL语句的结束符 存储过程中的变量 在MySQL中,变量一般可分为分为三种类型: 系统变量、用户定义变量、局部变量; 一、系统变量 系统变量是MySQL服务器系统自身提供的...注意点: mysql服务重新启动之后,所设置的全局参数会失效,要想不失效,可以在 /etc/my.cnf 中配置; 全局变量(GLOBAL): 全局变量针对于所有的会话; 会话变量(SESSION):...循环语句在编程中经常被用到,常用于对批量的数据进行循环处理,在mysql的存储过程中,也提供了几种常用的循环语句,包括:while循环,repeat循环,和loop循环; 1、while循环语句 while...,使用存储过程也可以完成,但是存储函数的局限在于,函数必须要有返回结果; 八、存储过程中游标的使用 游标(CURSOR)是用来存储查询结果集的数据类型 , 在存储过程和函数中可以使用游标对结果集进行循环的处理
MySQL 存储过程(了解) 1 什么是存储过程 MySQL 5.0 版本开始支持存储过程 存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用的一种数据 库对象。...中间加入了一些逻辑控制 2 存储过程的优缺点 优点: 存储过程一旦调试完成后,就可以稳定运行,(前提是,业务需求要相对稳定,没有变化) 存储过程减少业务系统与数据库的交互,降低耦合...,数据库交互更加快捷(应用服务器,与 数据库服务器不在同一个地区) 缺点: 在互联网行业中,大量使用MySQL,MySQL的存储过程与Oracle的相比较弱,所以较少使用,并且互联网行业需求变化较快也是原因之一...语法格式 DELIMITER $$ -- 声明语句结束符,可以自定义 一般使用$$ CREATE PROCEDURE 过程名称() -- 声明存储过程 BEGIN -- 开始编写存储过程 -- 要执行的操作...goods; END $$ 3) 调用存储过程 语法格式 call 存储过程名 -- 调用存储过程 查询goods表所有数据 call goods_proc; 方式2 1) IN 输入参数:表示调用者向存储过程传入值
MyISAM在所有MySQL版本里被支持;不支持事务处理;它是MySQL的默认的存储引擎; MEMORY MEMORY存储引擎,别称HEAP存储引擎;提供“内存中”表,将数据存储在内存中。...MEMORY存储引擎不支持事务处理;MySQL的所有版本都支持InnoDB存储引擎;注释:MEMORY存储引擎正式地被确定为HEAP引擎。...InnoDB存储引擎;它支持事务处理; BDB BDB存储引擎,别名BERKELEYDB;BDB存储引擎提供事务安全表;mysql 5.1以下版本才支持此存储引擎; EXAMPLE EXAMPLE存储引擎是一个...你可以用这个引擎创建表,但没有数据被存储于其中或从其中检索。这个引擎的目的是服务,在MySQL源代码中的一个例子,它演示说明如何开始编写新存储引擎。同样,它的主要兴趣是对开发者。...NDB NDB存储引擎,别名NDBCLUSTER;NDB Cluster是被MySQL Cluster用来实现分割到多台计算机上的表的存储引擎。它在MySQL-Max 5.1二进制分发版里提供。
实战mysql存储程序与定时器 存储过程定时器eventprocedure实战 需求:一个庞大的日志表,现每天做定时统计一天的总数,放另一个表中,方便查看,运营。...本文重点,用mysql定时器定时执行存储程序。...定时器 如果不是on,就执行 Sql代码 set global event_scheduler=1; 不需要重启mysql 会发现mysql多起了一个daemon进程 (注: 对于我们线上环境来说,使用...在两种计划任务中,时间戳可以是任意的TIMESTAMP 和DATETIME 数据类型,时间戳需要大于当前时间。...在重复的计划任务中,时间(单位)的数量可以是任意非空(Not Null)的整数式,时间单位是关键词:YEAR,MONTH,DAY,HOUR,MINUTE 或者SECOND。
不同的存储引擎提供不同的存储机制、索引技巧、锁定水平等功能。现在 许多不同的数据库管理系统都支持多种不同的数据引擎。MySQL的核心就是存储引擎。...用户可以 根据不同的需求为数据表选择不同的存储引擎 可以使用 SHOW ENGINES 命令 可以查看Mysql的 所有执行引擎我们 可以到 默认的执行引擎是innoDB 支持事务,行级锁定和外键。...拥有较高的插入,查询速度,但不支持事 务 InnoDB:事务型速记的首选引擎,支持ACID事务,支持行级锁定,MySQL5.5成为默认数据库引 擎 Memory: 所有数据置于内存的存储引擎,拥有极高的插入...并且其内容会在MYSQL重新启动是会丢失。 Archive :非常适合存储大量的独立的,作为历史记录的数据。因为它们不经常被读取。...Mrg_Myisam Merge存储引擎,是一组MyIsam的组合,也就是说,他将MyIsam引擎的多个表聚合起来,但是他 的内部没有数据,真正的数据依然是MyIsam引擎的表中,但是可以直接进行查询、
数据库存储引擎是数据库管理系统用于从数据库进行增删改查数据的底层软件组织。不同存储引擎提供不同的存储机制、索引技巧、锁定水平等功能。 在MySQL 5.5.5以后,InnoDB作为其默认存储引擎。...查看存储引擎 MySQL提供了多种不同的存储引擎,具体可通过如下命令进行查看: SHOW ENGINES;Copy 结果: mysql> SHOW ENGINES; +-----------------...| NO | NO | NO | | FEDERATED | NO | Federated MySQL...存储引擎的选择 不同存储引擎有不同的特点,以适应不同的需求。...适用于存储归档数据。 温馨提示 一个数据库中的多个表可以使用不同的引擎以满足各种性能和实际需求,可灵活选择。
show engines; 查看支持的存储引擎。...mysql表的存储引擎: InnoDB myISAM Memory MRG_MYISAM archive federated,CSV,BLACKHOLE 1、InnoDB 支持事务和外键...如果应用中需要执行大量的INSERT或UPDATE操作,则应该使用InnoDB,这样可以提高多用户并发操作的性能 全文索引 不支持 锁 InnoDB支持行级锁,InnoDB表的行锁也不是绝对的...,如果在执行一个SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表,注意间隙锁的影响 存储: InnoDB,基于磁盘的资源是InnoDB表空间数据文件和它的日志文件,InnoDB...需要事务支持(具有较好的事务特性) 行级锁定对高并发有很好的适应能力,但需要确保查询是通过索引完成 数据更新较为频繁的场景 数据一致性要求较高 硬件设备内存较大,可以利用InnoDB较好的缓存能力来提高内存利用率
1.1 简介 1.1.1 概述 MySQL 5.0 版本开始支持存储过程。存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用的一种数据库对象。...② 存储过程可以回传值,并可以接受参数。 ③ 存储过程无法使用 select 指令来运行,因为它是子程序,与查看表,数据表或用户定义函数不同。 ...④ 存储过程可以用在数据检验,强制实行商业逻辑等。 ☞ 缺点 ① 存储过程,往往定制化于特定的数据库上,因为支持的编程语言不同。当切换到其他的数据库系统时,需要重写原有的存储过程。 ...② 一个存储过程可以有多个输入、多个输出、多个输入输出参数。...存储过程不能修改,只能先删除,然后重新创建 1.2.5 删除存储过程 ☞ 语法 # if exites 可以省略,但是不建议 drop procedure [if exists] 存储过程名称
存储函数可以和内置函数或者表达式一样用于 SQL 语句,可以提高代码的可读性以及可维护性。 MySQL 存储过程和存储函数统称为存储例程(Stored Routine)。...在创建存储函数时还可以指定一些可选的属性,这些属性与创建存储过程时的属性是一致的。关于这些属性的含义请参见 MySQL 存储过程。 下面是创建函数的一个实例。...3.调用存储函数 在 MySQL 中,可以通过在 SQL 查询中使用 SELECT 调用存储函数。 比如调用上面创建的存储函数 hello 并传入字符串 world。...5.修改存储函数 修改存储函数与修改存储过程类似,可以使用 ALTER FUNCTION 语句修改存储函数的属性。...如果启用了二进制日志记录,则 ALTER FUNCTION 语句可能还需要 SUPER 权限 6.删除存储函数 MySQL 使用 DROP FUNCTION 语句可以删除存储函数。
当别人问我Mysql的存储引擎的时候,我就知道Myisam和innodb 虽然知道有其他的存储引擎,但是从来没有去了解过今天了解一下扩充知识 查看Mysql的存储引擎 show engines; MyISAM...Mysql 5.5之前默认的存储引擎 MyISAM存储引擎由MYD和MYI组成 ? ....frm表结构 .ibd数据+索引 聚集索引 mysql5.6以前默认为系统表空间 系统表空间和独立表空间 系统表空间无法简单的收缩文件大小 独立表空间可以通过optimize table 收缩系统文件...接下来的了解一下就可以 存储引擎CSV 组成 数据以文本方式存储在文件 .csv文件存储内容 .csm文件存储表的元数据如表状态和数据量 .frm存储表结构 ? ...特点: 以CSV格式进行数据存储 所有列都不能为Null 不支持索引(不适合大表,不适合在线处理) 可以对数据文件直接编辑(保存文本文件内容) 创建时提示这个存储引擎不支持列为null,需要在字段后添加
看你的mysql现在已提供什么存储引擎: mysql> show engines; 看你的mysql当前默认的存储引擎: mysql> show variables like ‘%storage_engine...%’; 你要看某个表用了什么引擎(在显示结果里参数engine后面的就表示该表当前用的存储引擎): mysql> show create table 表名; 使用命令修改系统变量(system variables
Mysql存储过程和存储函数 1.1. 存储过程的好处 1.2. 存储函数 1.2.1. 创建存储函数 1.2.1.1. 指定参数 1.2.2. 调用存储函数 1.2.3....参考文章 Mysql存储过程和存储函数 存储过程的好处 增强SQL语言的功能和灵活性:存储过程可以用控制语句编写,有很强的灵活性,可以完成复杂的判断和较复杂的运算。...存储函数 创建存储函数 在Mysql中有许多已经存在的存储函数,比如CONCAT(..),LENGTH(str)。但是我们也可以自己定义存储函数。...MySQL存储过程的参数用在存储过程的定义,共有三种参数类型,IN,OUT,INOUT: IN参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值 OUT:该值可在存储过程内部被改变...存储函数可以使用return返回一个返回值,但是存储过程不能有返回值,如果需要实现返回的功能,可以使用OUT参数实现返回 存储函数只能有输入参数,而且不能带in, 而存储过程可以有多个in,out,inout
1、添加存储过程 DELIMITER // CREATE PROCEDURE AddLLdata( in L_Longitude double , in L_Latitude double, IN...,L_Latitude,L_Elevation,L_LaserHeight,L_FollowHeight,L_PlaneId,L_FlyDate); END // DELIMITER ; 2、查询存储过程...from chkdata; END 3、查询两个时间之差 select UNIX_TIMESTAMP(now())-UNIX_TIMESTAMP('2018-04-23 14:18:12'); 4、添加存储过程...DATETIME ) LANGUAGE SQL NOT DETERMINISTIC CONTAINS SQL SQL SECURITY DEFINER COMMENT '' BEGIN /*定义一个变量存储是否存在的值...DATETIME ) LANGUAGE SQL NOT DETERMINISTIC CONTAINS SQL SQL SECURITY DEFINER COMMENT '' BEGIN /*定义一个变量存储是否存在的值
】 (如果存储过程存在删除后创建!...如果不写只能执行一次) 2.DELIMITER // (将每句结束符号;换成//) 3.CREATE PROCEDURE `存储过程名`(参数) (创建一个存储过程(参数列表【IN 输入参数【out...输出参数 inout输入输出参数】 u 参数名 参数类型 】)) 4.LANGUAGE sql (存储语句为sql了语句) 5.DETERMINISTIC【not DETERMINISTIC】...(表示存储过程对同样的输入参数产生相同的结果【表示会产生不确定的结果(默认)。】)...) 7.COMMENT ‘’ (对存储过程描述类似于java) 8.BEGIN 方法体开始 ... 写sql语句 END//方法体结束 9. call XX (调用存储过程XX为存储名)
参数类型 举例: in stuname varchar(20) 参数模式: in:该参数可以作为输入,也就是该参数需要调用方传入值 out:该参数可以作为输出,也就是该参数可以作为返回值 inout:...该参数既可以作为输入又可以作为输出,也就是该参数既需要传入值,又可以返回值 2、如果存储过程体仅仅只有一句话,begin end可以省略 存储过程体中的每条sql语句的结尾要求必须加分号。...存储过程的结尾可以使用 delimiter 重新设置 语法: delimiter 结束标记 案例: delimiter $ 二、存储过程创建和使用语法 2-1、语法 CALL 存储过程名(实参列表);...b ON b.boyfriend_id = bo.id WHERE b.name=beautyName ; END $ #定义变量接收返回值 SET @boyName = ''#注意可以不定义变量直接使用即可...create procedure 存储过程名 SHOW CREATE PROCEDURE p1; #错误演示 DESC p1; 存储过程案例 #一、创建存储过程实现传入用户名和密码,插入到admin
存储过程可以被重复使用。 存储过程只连接一次数据库,sql语句在访问多张表时,连接多次数据库。 存储的程序是安全的。存储过程的应用程序授予适当的权限。...格式: create procedure 过程名([IN|OUT|INOUT] 参数名 参数数据类型 ) begin ...... end; 注意: in:传入参数 out:传出参数 inout:可以传入也可以传出...status like '%emp%'; 7.2、存储过程删除 格式: drop procedure 存储过程名; 案例: mysql> drop procedure emp_id; Query OK...,它能根据对表的操作时间,触发一些动作,这些动作可以是insert,update,delete等操作。...trigger emp_insert; Query OK, 0 rows affected (0.02 秒) 十、事件 事件取代了原先只能由操作系统的计划任务来执行的工作,而且MySQL的事件调度器可以精确到每秒钟执行一个任务
前言 MySQL提供了插件式的存储引擎架构。所以MySQL存在多种存储引擎,可以根据需要使用相应的引擎。MySQL支持的存储引擎有很多,常用的是:InnoDB,MyISAM。...: 查看Mysql数据库的默认引擎指令: show variables like '%storage_engine%'; 1.1 InnoDB InnoDB存储引擎是Mysql的默认引擎。...外键约束 MySQL支持外键的存储引擎只有InnoDB,在创建外键的时候,要求父表必须有对应的索引,子表在创建外键的时候,也会自动的创建对应的索引。...在8.0版本后.frm文件就没有了,由.sdi文件存储元数据,并且是以JSON格式存储的,可以格式化一下,就可以方便的看到数据库名、表名以及各个字段。...1.4 MERGE MERGE存储引擎是一组MyISAM表的组合,这些MyISAM表必须结构完全相同,MERGE表本身并没有存储数据,对MERGE类型的表可以进行查询、更新、删除操作,这些操作实际上是对内部的
文章目录 创建/调用存储过程 存储过程体 为语句块贴标签 参数列表 存储过程的优缺点 存储过程的优点 存储过程的缺点 存储过程和函数可以理解为一段sql的集合,他们被事先编译好并且存储在数据库中。...创建/调用存储过程 create procedure 存储过程名(参数列表) begin 存储过程体 end 例如: delimiter $$ #将语句的结束符号从分号;临时改为两个$$(可以是自定义...sql语句的开销要小的多 3.第三点就是提高系统安全性,因为存储过程可以使用权限控制,而且参数化的存储过程可以有效的放置slq注入攻击,保证了其安全性 4.第四点就是耦合性降低,当我们表结构发生变化之后...,我们可以修改相应的存储过程,我们的应用程序在一定程度上需要改动的地方就比较少了 5.第五点就是重用性强。...因为我们在写好一个存储过程之后,再次调用只需要一个名称即可,也就是一次编写,随处调用,而且使用存储过程也可以让程序的模块化加强 存储过程的缺点 1.移植性差。
存储过程的优点: (1).增强SQL语言的功能和灵活性:存储过程可以用控制语句编写,有很强的灵活性,可以完成复杂的判断和较复杂的运算。...(2).标准组件式编程:存储过程被创建后,可以在程序中被多次调用,而不必重新编写该存储过程的SQL语句。而且数据库专业人员可以随时对存储过程进行修改,对应用程序源代码毫无影响。...MySQL的存储过程 存储过程是数据库的一个重要的功能,MySQL 5.0以前并不支持存储过程,这使得MySQL在应用上大打折扣。...好在MySQL 5.0开始支持存储过程,这样即可以大大提高数据库的处理速度,同时也可以提高数据库编程的灵活性。...MySQL存储过程的控制语句 变量作用域 内部变量在其作用域范围内享有更高的优先权,当执行到end时,内部变量消失,不再可见了,在存储 过程外再也找不到这个内部变量,但是可以通过out参数或者将其值指派给会话变量来保存其值
领取专属 10元无门槛券
手把手带您无忧上云