针锋对决txt未删减:mysql使用show命令以及replace函数批量修改数据

来源:百度文库 编辑:九乡新闻网 时间:2024/10/05 21:32:01

一.mysql的show命令

a. show tables或show tables from database_name; // 显示当前数据库中所有表的名称

b. show databases; // 显示mysql中所有数据库的名称

c. show columns from table_name from database_name; 或show columns from database_name.table_name;   // 显示表中列名称

d. show grants forroot@localhost;   //   显示一个用户的权限,显示结果类似于grant 命令

e. show index from table_name;   // 显示表的索引

f. show status [like ''];   // 显示一些系统特定资源的信息,例如,正在运行的线程数量

g. show [session/global] variables [like '']; // 显示系统变量的名称和值
h. show   processlist; // 显示系统中正在运行的所有进程,也就是当前正在执行的查询。大多数用户可以查看他们自己的进程,但是如果他们拥有process权限,就可以查看所有人的进程,包括密码。

i. show table status; // 显示当前使用或者指定的database中的每个表的信息。信息包括表类型和表的最新更新时间

j. show privileges;   // 显示服务器所支持的不同权限

k. show create database database_name; // 显示create database 语句是否能够创建指定的数据库

l. show create table table_name; // 显示create database 语句是否能够创建指定的数据库

m. show engies bdb logs;   // 显示安装以后可用的存储引擎和默认引擎。

n. show innodb status; // 显示innoDB存储引擎的状态

o. show logs; // 显示BDB存储引擎的日志

p. show warnings; // 显示最后一个执行的语句所产生的错误、警告和通知

q. show errors; // 只显示最后一个执行语句所产生的错误

r. show create table tablename; //显示建表的详细信息及语法和引擎

s. show table status [from database];   //显示本数据库中所有表的详细信息

 

 

二.mysql的replace字符串使用

 

用法1.replace into

replace into table (id,name) values(‘1‘,‘aa‘),(‘2‘,‘bb‘)
此语句的作用是向表table中插入两条记录。
2.replace(object, search,replace)
把object中出现search的全部替换为replaceselect replace(‘www.163.com‘,‘w‘,‘Ww‘)--->WwW wWw.163.com

例:把表table中的name字段中的 aa替换为bbupdate table set name=replace(name,‘aa‘,‘bb‘).

 

 

三.实例:使用show columns和replace替换数据里所有的字符

 

Php代码  
  1. //将数据里所有的掠夺替换成攻击  
  2. function replaceRobToAttack()   
  • {   
  •     //特殊处理的表  
  •     $except_tables = array("mem_state"=>0, "sys_shop" =>0);   
  •   
  •     $tables = sql_fetch_rows("SHOW TABLES");   
  •   
  •    foreach($tables as $table)   
  •    {   
  •        $table = array_values($tables);   
  •        if(substr($table[0],0,4) =="cfg_" || array_key_exists($table[0], $except_tables))   
  •        {   
  •            
  •             $columns = sql_fetch_rows("SHOW COLUMNS FROM {$table[0]}");   
  •             if($columns)   
  •             foreach($columns as $c)   
  •             {   
  •                  sql_query("update {$table[0]} set `{$c["Field"]}` = REPLACE(`{$c["Field"]}`, '掠夺', '攻击')");   
  •             }   
  •         }   
  •    }   
  • }