-
使用Limit参数优化MySQL查询的方法
我们在做一些查询的时候总希望能避免数据库引擎做全表扫描,因为全表扫描时间长,而且其中大部分扫描对客户端而言是没有意义的。那么在 MySQL 中有那些方式是可以避免全表扫面的呢?除了我们大家很熟悉的通过使用索引列或分区等方式来进行查询的优化之外还有那些呢? 前些天看了一个老外写的程序,在 MySQL 查询中使用了很多 Limit 关键字,这就让我很感兴趣了,因为在我印象中, Limit 关键字似乎更多被使用 MySQL 数据库的程序员用来做查询分页(当然这也是一种很好的查询优化),那在这里举个例子,假设我们需要一个分页的查询 ,Oracle中一般来说都是用以下 SQL 句子实现: SELECT * FROM ( SELECT a1.*, rownum rownum_ FROM testtable a1 WHERE rownum > 20) WHERE rownum_ <= 1000 这个语句就能查询到 testtable 表中的 20 到 1000 记录,而且还需要嵌套查询,效率不会太高,看看 MySQL 的实现: SELECT * FROM testta...
数据库操作教程 2014-11-30 01:14:13 -
用mysql触发器自动更新memcache的实现代码
本文为大家讲解的是使用mysql触发器自动更新memcache的实现代码,非常实用的一个技巧,感兴趣的同学参考下. mysql 5.1支持触发器以及自定义函数接口(UDF)的特性,如果配合libmemcache以及Memcached Functions for MySQL,就能够实现memcache的自动更新。简单记录一下安装测试步骤...
数据库操作教程 2014-11-30 01:13:26 -
Mysql错误:mysql服务无法启动 发生系统错误1067的解决办法
本文主要为大家讲解的是Mysql错误:mysql服务无法启动 发生系统错误1067的解决办法 ,非常实用,感兴趣的同学参考下。 mysql错误如下图: 问题原因: 将本地的Apache+MySQL+PHP环境移植到别人电脑,其中mysql中的data没有拷贝,导致别人电脑运行mysql时出现“mysql服务无法启动 发生系统错误1067”的错误...
数据库操作教程 2014-11-30 01:11:02 -
memcached 和 mysql 主从环境下php开发详解
本文为大家讲解的是memcached 和 mysql 主从环境下php开发详解及思路,感兴趣的同学参考下。 一般的大站通常做法是 拿着内存当数据库来用(memcached). 和很好的读 写分离 备份机制 (mysql 的主从) 在这样的环境下我们怎么进行PHP开发呢...
PHP 2014-11-29 23:45:16 -
使用python将mdb数据库文件导入postgresql数据库示例
本文是一个python实现的可以将mdb数据库文件导入到postgresql数据库的示例代码,非常实现的一个功能,感兴趣的同学参考下. mdb格式文件可以通过mdbtools工具将内中包含的每张表导出到csv格式文件。由于access数据库和postgresQL数据库格式上会存在不通性,所以使用python的文件处理,将所得csv文件修改成正确、能识别的格式 导入脚本说明(此脚本运行于linux): 1.apt-get install mdbtools,安装mdbtools工具 2.将mdb 文件拷贝到linux虚拟机中,修改脚本中mdb文件目录‘dir' 3.修改服务器及数据库配置 4.执行脚本 # -*- encoding: utf-8 -*- import os import re import psycopg2 import csv #mdb文件目录 dir = r'/home/kotaimen/mdb_file/' mdb_tbl_dic =...
PHP 2014-11-29 11:11:14 -
oracle组函数avg(),sum(),max(),min(),count()、多行函数,分组数据(group by,求各部门的平均工资),分组过滤(having和where),sql优化详解
1组函数 avg(),sum(),max(),min(),count()示例: selectavg(sal),sum(sal),max(sal),min(sal),count(sal) from emp/ 截图: 2 组函数和null在一起 案例:求员工的平均奖金 错误sql: select avg(comm) 方式1,sum(comm)/count(comm)方式2,sum(comm)/count(*) 方式3 from emp; 截图: 错误原因: select count(comm),count(*) from emp; 分析: --组函数自动滤空,组函数忽略空值 --修正函数的滤空 select count(nvl(comm,0)),count(*) fromemp; 3.分组数据 A 求各个部门的平均工资 思路:需要把各个部门的数据划分…....
PHP 2014-11-29 05:04:59 -
SQL Server锁分区特性引发死锁解析
本文为大家讲解的是SQL Server锁分区特性引发死锁解析,锁分区技术使得SQL Server可以更好地应对并发情形,但也有可能带来负面影响,这里通过实例为大家介绍,分析由于锁分区造成的死锁情形.感兴趣的同学参考下。 Code(执行测试脚本时请注意执行顺序,说明) 步骤1 创建测试数据 use tempdb go create table testdlk ( id int identity(1,1) primary key, str1 char(3000) ) go insert into testdlk(str1) select 'aaa' insert into testdlk(str1) select 'bbb' insert into testdlk(str1) select 'ccc' insert into testdlk(str1) select 'ddd' 步骤2 开启 session 1 执行语句 --ses...
PHP 2014-11-29 01:33:40 -
Sql Server bak文件数据导入示例
本文为大家讲解的是Sql Server数据库 bak文件数据导入的方法,感兴趣的同学参考下. 第一步首先在你的数据库中建立一个空数据库 选中新建的数据库 鼠标右键 任务 还原 数据库 这个时候会弹出这样的一个框 之后选择原设备 会弹出 点击添加 找到你的bak文件选择 这时弹出 完成...
PHP 2014-11-29 00:40:38 -
SQL Server 2012 将数据导出为sql脚本详细图解
本文为大家讲解的是sql server 2012下把数据导出为sql脚本的详细方法,sql server数据库导出为sql脚本好处:占内存小(一般只有几百kb)、方便修改、不限制sql server的版本!,感兴趣的同学参考下。 sql server 即 microsoft sql server ...
PHP 2014-11-29 00:39:22 -
php连接 Sql Server失败问题及解决办法
本文为大家讲解了php链接sql server失败的问题原因分析和解决方法,感兴趣的同学参考下. 本人在链接sql2005的时候遇到的问题,经过仔细排查和搜索找到解决办法,希望对大家有用。 1、确认数据库服务开启状态 2、php.ini配置中的扩展打开 3、检查数据库相关的版本 (1)Sql2000此时要检查php目录和apache的bin目录下的ntwdblib.dll文件的版本是否符合,右键点击ntwdblib.dll看文件属性就可以看见版本...
PHP 2014-11-29 00:38:15 -
SQL连表查询:内连接、左联接、右连接、全连接、交叉连接讲解
本文为大家讲解的是sql的连表查询:SQL连接可以分为内连接、左联接、右连接、全连接、交叉连接的用法,mysql,sql server,access等关系型数据库语法其实都差不多,本文是以sql server为示例进行的讲解,感兴趣的同学参考下。 数据库数据: book表 stu表 1.内连接 1.1.等值连接:...
PHP 2014-11-29 00:34:13 -
安装MS SQL Server 2008 提示“性能计数器注册表配置单元一致性”失败的解决办法
本文为大家讲解的是在安装SQL Server 2008数据库时提示“性能计数器注册表配置单元一致性”错误的解决方法,感兴趣的同学参考下。 安装SQL Server 2008出现问题,在安装前检测时,安装程序报错,“性能计数器注册表配置单元一致性”,点击错误连接时,会提示,查看文章,URL地址:http://support.microsoft.com/kb/300956...
PHP 2014-11-29 00:31:00