MySql - 军军小站|张军博客
MySql

MySQL InnoDB存储引擎锁机制实验

之前的文章提到MySQL的InnoDB存储引擎使用的是行级锁,并且默认的事务隔离级别为可重复读,而不同于Oracle默认的事务隔离级别提交读。那么MySQL的InnoDB存储引擎的锁机制的具体表现是怎样的呢?实验如下:首先建立一张测试使用的表:CREATETABLE`test_innodb_lock`(`a`int(11)DEFAULTNULL,`b`varchar(16)DEFAULTNULL,KEY`test_innodb_lock_a_IDX`(`a

系统 2019-08-12 01:52:03 2225

MySql

Mysql个人语句笔记

--一些简单语句记录:/*mysql*/SHOWDATABASESCREATEDATABASEguoDROPDATABASEguo/*查看创建的数据库*/SHOWCREATEDATABASEzf/*字符集*/CREATEDATABASEguoCHARACTERSETgbkSHOWCREATEDATABASEguoALTERDATABASEguoCHARACTERSETutf8;SHOWCREATEDATABASEguo--创建表USEzfCREATETAB

系统 2019-08-12 01:33:40 2225

MySql

mysql基础之基本数据类型

原文:mysql基础之基本数据类型列类型学习mysql三大列类型整型Tinyint/smallint/mediumint/int/bigint(M)unsignedzerofill字符串型Char(M)Varchar(M)Text文本类型日期时间类型Date日期Time时间Datetime时间时间类型Year年类型整形:整型系列所占字节与存储范围的关系.定性:占字节越多,存储范围越大.下图:是具体的数字分析Tinyint1个字节8个位0-2^8-1,0-2

系统 2019-08-12 01:33:15 2225

MySql

MySQL SQL优化小结

优化是一个综合复杂的问题,涉及到硬软件平台。这里仅就MySQL5.0SQL查询语句方面作个小结。先举个例子:现在表register(PRIMARYKEYregId),service(PRIMARYKEYservId,indexserviceId)和subscribe(PRIMARYKEYsubId,FOREIGNKEYregId/servId),且前两表跟后张表均为一对多关联,假设有如下表格结构:CREATETABLE`subscribe`(`subId`

系统 2019-08-29 23:34:21 2224

MySql

MySQL引擎介绍ISAM,MyISAM,HEAP,InnoDB

MySQL数据库引擎取决于MySQL在安装的时候是如何被编译的。要添加一个新的引擎,就必须重新编译MYSQL。在缺省情况下,MYSQL支持三个引擎:ISAM、MYISAM和HEAP。另外两种类型INNODB和BERKLEY(BDB),也常常可以使用。如果技术高超,还可以使用MySQL++API自己做一个引擎。下面介绍几种数据库引擎:ISAM:ISAM是一个定义明确且历经时间考验的数据表格管理方法,它在设计之时就考虑到数据库被查询的次数要远大于更新的次数。因

系统 2019-08-12 01:55:11 2224

MySql

怎样解决MySQL数据库主从复制延迟的问题

mysqlreplication中主从延迟是一个比较常见的问题,请看前期一篇博文:怎样解决MySQL数据库主从复制延迟的问题。根据目前有些公司使用的方案,最近测试了两个,其中之一是阿里的relayfetch,业绩说法数据预热,当然也有其他开源类似开源工具,目前诸如mk-slave-prefetch及replication-prefetch等,感兴趣可以去看看。整理的文档主要是参考了官方的《relayfetch读取本地binlog进行备库预热》,有些图片直接

系统 2019-08-12 01:54:42 2224

MySql

mysql 导入导出数据

使用Mysqldump和mysqlimport命令导入导出数据,这两个命令是在cmd中的命令行状态执行的。即从开始菜单点击运行,输入cmd,cd到mysql安装目录下的bin目录下执行。一、导出数据:1.导出数据mysqldump总式:mysqldump--opt数据库名>文本文件名称(一般命名为mysql.数据库名)实例:把stud数据库中的数据导出到文本文件mysql.studMysqldump–uroot–pstud>mysql.stud提示输出密码

系统 2019-08-12 01:54:33 2224

MySql

{php 编程下有效防止MySQL数据库注入攻击}

PHP编程下有效防止MySQL数据库注入攻击2009-07-1109:46SQL注入是网站危险的最重要来源之一.黑客往往会向一个网页表单提交一些恶意代码来达到一些注入目的.要了解注入的过程.我们先来看一下如下的基础SQLSELECT语句:SELECT*FROMxmenWHEREusername='wolverine'以上SQL查询会返回“xmen”表中username(用户名)=“wolverine”的数据记录。其中wolverine为用户通过表单提交,设

系统 2019-08-12 01:54:18 2224

MySql

mysql联合索引的应用

有一个log表,结构是这样的:CREATETABLE`weblog`(`id`int(10)unsignedNOTNULLAUTO_INCREMENT,`ip`varchar(45)NOTNULL,`time`timestampNOTNULLDEFAULTCURRENT_TIMESTAMPONUPDATECURRENT_TIMESTAMP,`kind`varchar(255)NOTNULL,PRIMARYKEY(`id`))ENGINE=MyISAMAUT

系统 2019-08-12 01:54:18 2224

MySql

错误测试mysql时间相减的问题(bug)

在写这篇文章之前,xxx已经写过了几篇关于改错误测试主题的文章,想要了解的朋友可以去翻一下之前的文章mysql时光相减的问题(bug)明天看到宁青同窗的一条微博,提到mysql日期相减的错误结果,之前没有怎么意注,于是测试了一下,发明实确很坑爹,很易容踩雷,于是理整客博提示一下大家。先看一下错误的景象如下,第1条确正,第2,3条的t2-t1不确正:mysql>selectt1,t2,t2-t1frommytest;+--------------------

系统 2019-08-12 01:54:01 2224

MySql

MySQL定时任务

原文:MySQL定时任务一、简介:Mysql属于中小型数据库系统,它的事件调度器EventScheduler是在mysql5.1才开始引入事件调度器是在MySQL5.1中新增的另一个特色功能,可以作为定时任务调度器,取代部分原先只能用操作系统任务调度器才能完成的定时功能。事件调度器是定时触发执行的,在这个角度上也可以称作是"临时的触发器"。触发器只是针对某个表产生的事件执行一些语句,而事件调度器则是在某一个(间隔)时间执行一些语句。事件是由一个特定的线程来

系统 2019-08-12 01:53:25 2224

MySql

mysql5.5.15配置主从数据库

1、编辑主库的my.cnf在[mysqld]下添加如下配置server-i=1#一般默认为1,不需要修改(一般都以ip的后两位为server-id,保证全局的一致)read-only=0#主库读写都可以binlog-do-db=test#需要同步的数据库名称,要同步多个可以写多行binlog-ignore-db=mysql#不需要同步的数据库名称,可以写多行binlog-ignore-db=performance_schemalog-bin=mysql-b

系统 2019-08-12 01:52:31 2224

MySql

MySql Date函数

1、获取当前时间mysql>selectcurrent_timestamp();+---------------------+|current_timestamp()|+---------------------+|2010-01-1821:24:37|+---------------------+1rowinset(0.00sec)mysql>selectcurrent_date();+----------------+|current_date()|+

系统 2019-08-12 01:51:34 2224

MySql

MySQL 升级方法指南大全

原文:MySQL升级方法指南大全通常,从一个发布版本升级到另一个版本时,我们建议按照顺序来升级版本。例如,想要升级MySQL3.23时,先升级到MySQL4.0,而不是直接升级到MySQL4.1或MySQL5.0。如果都是比较新的版本的升级可以参考下面的文章,MySQL数据库的版本更新很快,新的特性也随之不断的更新,更主要的是解决了很多影响我们应用的BUG,为了让我们的MySQL变得更美好,我们有必要去给它升级,尽管你会说它现在已经跑得很好很稳定完全够用了

系统 2019-08-12 01:33:31 2224

MySql

Mysql高级之主从复制

原文:Mysql高级之主从复制主从复制不就是多台服务器嘛!,一个改变另一个也改变啦,内容其实都一样!原理:对数据库进行操作会生成一个文件,binlog(二进制文件),从服务器配置relaylog文件,用来读取master里面binlog(有必要开启binlog,相当于备份),当然要有权限读取是吧,这就需要用到上次的权限配置啦!和普通登录没什么差别。主做出什么动作,从也做出什么动作。这时就需要注意主配置文件里面binlog-format,里面值为row,二进

系统 2019-08-12 01:33:19 2224