学习啦 > 学习电脑 > 网络知识 > 网络技术 >

Linux如何使用locate命令查找数据搜索数据库

时间: 加城1195 分享

  通常在Linux查找数据库我们都使用find,那么除了find命令我们还可以用locate命令,可以在搜寻数据库时快速找到档案,具体怎么使用呢?下面小编就给大家详细介绍下locate命令的用法。

  Linux如何使用locate命令查找数据

  1.命令格式:

  Locate [选择参数] [样式]

  2.命令功能:

  locate命令可以在搜寻数据库时快速找到档案,数据库由updatedb程序来更新,updatedb是由cron daemon周期性建立的,locate命令在搜寻数据库时比由整个由硬盘资料来搜寻资料来得快,但较差劲的是locate所找到的档案若是最近才建立或 刚更名的,可能会找不到,在内定值中,updatedb每天会跑一次,可以由修改crontab来更新设定值。(etc/crontab)

  locate指定用在搜寻符合条件的档案,它会去储存档案与目录名称的数据库内,寻找合乎范本样式条件的档案或目录录,可以使用特殊字元(如”*” 或”?”等)来指定范本样式,如指定范本为kcpa*ner, locate会找出所有起始字串为kcpa且结尾为ner的档案或目录,如名称为kcpartner若目录录名称为kcpa_ner则会列出该目录下包括 子目录在内的所有档案。

  locate指令和find找寻档案的功能类似,但locate是透过update程序将硬盘中的所有档案和目录资料先建立一个索引数据库,在 执行loacte时直接找该索引,查询速度会较快,索引数据库一般是由操作系统管理,但也可以直接下达update强迫系统立即修改索引数据库。

  3.命令参数:

  -e 将排除在寻找的范围之外。

  -1 如果 是 1.则启动安全模式。在安全模式下,使用者不会看到权限无法看到 的档案。这会始速度减慢,因为 locate 必须至实际的档案系统中取得档案的 权限资料。

  -f 将特定的档案系统排除在外,例如我们没有到理要把 proc 档案系统中的档案 放在资料库中。

  -q 安静模式,不会显示任何错误讯息。

  -n 至多显示 n个输出。

  -r 使用正规运算式 做寻找的条件。

  -o 指定资料库存的名称。

  -d 指定资料库的路径

  -h 显示辅助讯息

  -V 显示程式的版本讯息

  4.使用实例:

  实例1:查找和pwd相关的所有文件

  命令:

  locate pwd

  输出:

  代码如下:

  peida-VirtualBox ~ # locate pwd

  /bin/pwd

  /etc/.pwd.lock

  /sbin/unix_chkpwd

  /usr/bin/pwdx

  /usr/include/pwd.h

  /usr/lib/python2.7/dist-packages/twisted/python/fakepwd.py

  /usr/lib/python2.7/dist-packages/twisted/python/fakepwd.pyc

  /usr/lib/python2.7/dist-packages/twisted/python/test/test_fakepwd.py

  /usr/lib/python2.7/dist-packages/twisted/python/test/test_fakepwd.pyc

  /usr/lib/syslinux/pwd.c32

  /usr/share/help/C/empathy/irc-join-pwd.page

  /usr/share/help/ca/empathy/irc-join-pwd.page

  /usr/share/help/cs/empathy/irc-join-pwd.page

  /usr/share/help/de/empathy/irc-join-pwd.page

  /usr/share/help/el/empathy/irc-join-pwd.page

  实例2: 搜索etc目录下所有以sh开头的文件

  命令:

  locate /etc/sh

  输出:

  代码如下:

  peida-VirtualBox ~ # locate /etc/sh

  /etc/shadow

  /etc/shadow-

  /etc/shells

  peida-VirtualBox ~ #

  补充:MySQL 数据库常用命令

  create database name; 创建数据库

  use databasename; 进入数据库

  drop database name 直接删除数据库,不提醒

  show tables; 显示表

  describe tablename; 查看表的结构

  select 中加上distinct去除重复字段

  mysqladmin drop databasename 删除数据库前,有提示。

  显示当前mysql版本和当前日期

  select version(),current_date;

  数据库维护方法

  在MySQL使用的过程中,在系统运行一段时间后,可能会产生碎片,造成空间的浪费,所以有必要定期的对MySQL进行碎片整理。

  当删除id=2的记录时候,发生的现象

  这个时候发现磁盘的空间并没有减少。这种现象就叫做碎片化(有一部分的磁盘空间在数据删除以后(空),还是无法被操作系统所使用。)

  常见的优化:

  # alter table xxx engine myisam;

  # optimize table t1;

  注意: 在实际开发的过程中,上面两个语句尽量少使用,因为在使用的过程中,MySQL的表的结构会整体全部重新整理,需要消耗很多的资源,建议在凌晨两三点钟的时候执行。(在linux下有定时器脚本可以执行,crontab)


4015157