1.知道一个字段名,怎样查到它在数据库里的哪张表里?

USE Information_schema;
SELECT TABLE_NAME FROM COLUMNS WHERE COLUMN_NAME='字段名称';

MySQL中查看库表字段信息都在information_schemal中,获取数据字典等信息都要通过这个视图。

如:

select table_name from columns where column_name='user_id';

2. 如何查看建表语句?

show create table tablename;

要查看tb1表结构的命令:

show create table tb1;

注意,不用加引号。

3.如何查看表结构?

desc tablename;

要查看tb1表结构的命令:

desc tb1;

4.如何查看一个表的表结构修改记录?

MySQL不支持直接查看,只能通过日志文件查看。

Oracle和SQL Server可以。

6.Mysql更改列名和数据类型

只修改列的数据类型的方法:
 alter table 表名 modify column 列名 新的列的类型
例如:student表中列sname的类型是char(20),现在要修改为varchar(20),SQL语句如下
alter table student modify column sname varchar(20);

只修改列名,或者同时修改列名和列的数据类型的方法:
 alter table 表名 change column 旧列名 新列名 (原先的类型)新的列类型
例如:student表中列sname的类型是char(20),现在要修改为stuname varchar(20),SQL语句如下
alter table student change column sname stuname varchar(20);

7.This version of MySQL doesn't yet support 'LIMIT & IN/ALL/ANY/SOME subquery'的意思是,

这版本的 MySQL 不支持使用 LIMIT 子句的 IN/ALL/ANY/SOME 子查询,即是支持非 IN/ALL/ANY/SOME 子查询的 LIMIT 子查询。

也就是说,这样的语句是不能正确执行的。 
select * from table where id in (select id from table limit 10)

但是,只要你再来一层就行。。如: 
select * from table where id in (select t.id from (select * from table limit 10)as t)

8.使用SQL语句查询某记录的前后N条数据

id是指当前数据tb_id参数

方法一:

string preSql = "select top 1 * from table where tb_id < " + id + " order by tb_id DESC"string nextSql = "select top 1 * from table where tb_id > " + id + " order by tb_id ASC"

方法二:

string preSql = "select * from [table] where tb_id = (select MAX(tb_id) from [table] where tb_id<"+ id + ")";
string nextSql = "select * from [table] where tb_id = (select MIN(tb_id) from [table] where tb_id>"+ id + ")";

将查询结果union即可。

9. 三张表join操作

三张表:A (id,xxx) B(id,xxx) C(id,xxx) 要根据相同的id显示三张表,做Left Join。
SELECT XXX 
FROM ((A LEFT JOIN B ON A.id = B.id) 
LEFT JOIN C ON A.id = C.id) 
WHERE B.id Is Not Null

From条件后面的括号不能忘了。

A连接B B连接C的实现
select * from A inner join B on A.id=A.id inner join C on B.id=C.id

10.union 与union all 的区别

数据库中,UNION和UNION ALL都是将两个结果集合并为一个,但这两者从使用和效率上来说都有所不同。

UNION在进行表链接后会筛选掉重复的记录,所以在表链接后会对所产生的结果集进行排序运算,删除重复的记录再返回结果。实际大部分应用中是不会产生重复的记录,最常见的是过程表与历史表UNION。如:

select * from users1 union select * from user2 

这个SQL在运行时先取出两个表的结果,再用排序空间进行排序删除重复的记录,最后返回结果集,如果表数据量大的话可能会导致用磁盘进行排序。

而UNION ALL只是简单的将两个结果合并后就返回。这样,如果返回的两个结果集中有重复的数据,那么返回的结果集就会包含重复的数据了。 
从效率上说,UNION ALL 要比UNION快很多,所以,如果可以确认合并的两个结果集中不包含重复的数据的话,那么就使用UNION ALL,如下:

select * from user1 union all select * from user2

11.MySQL日常操作

启动:net start mySql;
进入:mysql -u root -p/mysql -h localhost -u root -p databaseName;
列出数据库:show databases;
选择数据库:use databaseName;
列出表格:show tables;
显示表格列的属性:show columns from tableName;
建立数据库:source fileName.txt;
匹配字符:可以用通配符_代表任何一个字符,%代表任何字符串;
增加一个字段:alter table tabelName add column fieldName dateType;
增加多个字段:alter table tabelName add column fieldName1 dateType,add columns fieldName2 dateType;
多行命令输入:注意不能将单词断开;当插入或更改数据时,不能将字段的字符串展开到多行里,否则硬回车将被储存到数据中;
增加一个管理员帐户:grant all on *.* to user@localhost identified by "password";
每条语句输入完毕后要在末尾填加分号';',或者填加'\g'也可以;
查询时间:select now();
查询当前用户:select user();
查询数据库版本:select version();
查询当前使用的数据库:select database();

(1)删除student_course数据库中的students数据表:
rm -f student_course/students.*

(2)备份数据库:(将数据库test备份)
mysqldump -u root -p test>c:\test.txt
备份表格:(备份test数据库下的mytable表格)
mysqldump -u root -p test mytable>c:\test.txt
将备份数据导入到数据库:(导回test数据库)
mysql -u root -p test<c:\test.txt

(3)创建临时表:(建立临时表zengchao)
create temporary table zengchao(name varchar(10));

(4)创建表是先判断表是否存在
create table if not exists students(……);

(5)从已经有的表中复制表的结构
create table table2 select * from table1 where 1<>1;

(6)复制表
create table table2 select * from table1;

(7)对表重新命名
alter table table1 rename as table2;

(8)修改列的类型
alter table table1 modify id int unsigned;//修改列id的类型为int unsigned
alter table table1 change id sid int unsigned;//修改列id的名字为sid,而且把属性修改为int unsigned

(9)创建索引
alter table table1 add index ind_id (id);
create index ind_id on table1 (id);
create unique index ind_id on table1 (id);//建立唯一性索引

(10)删除索引
drop index idx_id on table1;
alter table table1 drop index ind_id;

(11)联合字符或者多个列(将列id与":"和列name和"="连接)
select concat(id,':',name,'=') from students;

(12)limit(选出10到20条)<第一个记录集的编号是0>
select * from students order by id limit 9,10;

(13)MySQL不支持的功能
事务,视图,外键和引用完整性,存储过程和触发器

(14)MySQL会使用索引的操作符号
<,<=,>=,>,=,between,in,不带%或者_开头的like

(15)使用索引的缺点
1)减慢增删改数据的速度;
2)占用磁盘空间;
3)增加查询优化器的负担;
当查询优化器生成执行计划时,会考虑索引,太多的索引会给查询优化器增加工作量,导致无法选择最优的查询方案;

(16)分析索引效率
方法:在一般的SQL语句前加上explain;
分析结果的含义:
1)table:表名;
2)type:连接的类型,(ALL/Range/Ref)。其中ref是最理想的;
3)possible_keys:查询可以利用的索引名;
4)key:实际使用的索引;
5)key_len:索引中被使用部分的长度(字节);
6)ref:显示列名字或者"const"(不明白什么意思);
7)rows:显示MySQL认为在找到正确结果之前必须扫描的行数;
8)extra:MySQL的建议;

(17)使用较短的定长列
1)尽可能使用较短的数据类型;
2)尽可能使用定长数据类型;
a)用char代替varchar,固定长度的数据处理比变长的快些;
b)对于频繁修改的表,磁盘容易形成碎片,从而影响数据库的整体性能;
c)万一出现数据表崩溃,使用固定长度数据行的表更容易重新构造。使用固定长度的数据行,每个记录的开始位置都是固定记录长度的倍数,可以很容易被检测到,但是使用可变长度的数据行就不一定了;
d)对于MyISAM类型的数据表,虽然转换成固定长度的数据列可以提高性能,但是占据的空间也大;

(18)使用not null和enum
尽量将列定义为not null,这样可使数据的出来更快,所需的空间更少,而且在查询时,MySQL不需要检查是否存在特例,即null值,从而优化查询;
如果一列只含有有限数目的特定值,如性别,是否有效或者入学年份等,在这种情况下应该考虑将其转换为enum列的值,MySQL处理的更快,因为所有的enum值在系统内都是以标识数值来表示的;

(19)使用optimize table
对于经常修改的表,容易产生碎片,使在查询数据库时必须读取更多的磁盘块,降低查询性能。具有可变长的表都存在磁盘碎片问题,这个问题对blob数据类型更为突出,因为其尺寸变化非常大。可以通过使用optimize table来整理碎片,保证数据库性能不下降,优化那些受碎片影响的数据表。 optimize table可以用于MyISAM和BDB类型的数据表。实际上任何碎片整理方法都是用mysqldump来转存数据表,然后使用转存后的文件并重新建数据表;

(20)使用procedure analyse()
可以使用procedure analyse()显示最佳类型的建议,使用很简单,在select语句后面加上procedure analyse()就可以了;例如:
select * from students procedure analyse();
select * from students procedure analyse(16,256);
第二条语句要求procedure analyse()不要建议含有多于16个值,或者含有多于256字节的enum类型,如果没有限制,输出可能会很长;

(21)使用查询缓存
1)查询缓存的工作方式:
第一次执行某条select语句时,服务器记住该查询的文本内容和查询结果,存储在缓存中,下次碰到这个语句时,直接从缓存中返回结果;当更新数据表后,该数据表的任何缓存查询都变成无效的,并且会被丢弃。
2)配置缓存参数:
变量:query_cache _type,查询缓存的操作模式。有3中模式,0:不缓存;1:缓存查询,除非与select sql_no_cache开头;2:根据需要只缓存那些以select sql_cache开头的查询;query_cache_size:设置查询缓存的最大结果集的大小,比这个值大的不会被缓存。

本文转自邴越博客园博客,原文链接:http://www.cnblogs.com/binyue/p/4056959.html,如需转载请自行联系原作者

MySQL日常应用操作记录相关推荐

  1. 利用mk-table-checksum监测Mysql主从数据一致性操作记录

    前面已经提到了mysql主从环境下数据一致性检查:mysql主从同步(3)-percona-toolkit工具(数据一致性监测.延迟监控)使用梳理 今天这里再介绍另一种Mysql数据一致性自动检测工具 ...

  2. mysql数据库主从操作记录

    master数据库已投入生产一段时间后,做主从复制的操作记录 环境: master库:172.18.237.13 slave库:172.18.237.14 mysql版本说明: master:mysq ...

  3. MySQL : MySQL如何查看操作记录

    文章目录 1.美图 2.背景 3.概述 4.文件方式 5.table方式 6.注意点 1.美图 2.背景 突然发现自己测试的库,突然某个字段全部改变了,因为这个只有我用,但是感觉应该是有人修改了,但是 ...

  4. Mysql如何查看操作记录

    分为文件记录日志和数据库记录日志两种方式,效果相同 一 .文件记录数据库操作日志 首先进入mysql输入指令 show variables like 'gen%'; general_log是开启还是关 ...

  5. MySQL useSSS_Mysql 常用操作记录

    1.查看数据库: mysql>show databases;+--------------------+ | Database | +--------------------+ | inform ...

  6. mysql---mysql查看数据库操作记录

    mysql查看数据库操作记录 MySQL的查询日志记录了所有MySQL数据库请求的信息.无论这些请求是否得到了正确的执行.默认文件名为hostname.log.默认情况下MySQL查询日志是关闭的.生 ...

  7. mysql 数据修改记录日志_mysql对数据的更新操作记录在哪个日志中?

    mysql对数据的更新操作记录在通用查询日志和二进制日志中.通用查询日志用来记录用户的所有操作,包括启动和关闭 MySQL 服务.更新语句和查询语句等:二进制日志会以二进制的形式记录数据库的各种操作, ...

  8. mysql+keepalived必须要lvs吗_MySQL 双主热备 + LVS + Keepalived 高可用操作记录

    MySQL复制能够保证数据的冗余的同时可以做读写分离来分担系统压力,如果是主主复制还可以很好的避免主节点的单点故障.然而MySQL主主复制存在一些问题无法满足我们的实际需要:未提供统一访问入口来实现负 ...

  9. mysql维护 运维_MySQL运维之--日常维护操作

    MySQL运维之--日常维护操作 http://blog.csdn.net/guoyjoe/article/details/46697825 一.Linux内核和发行版本 uname -a cat / ...

最新文章

  1. 2021云栖大会,打卡IoT最全攻略
  2. ubuntu16.04 关闭防火墙的方法
  3. 面试的问题 及回答
  4. 工业交换机如何预防雷电?
  5. 第8章 硬盘和显卡的访问与控制
  6. ajax读取文本无响应,如何获得jQuery$.ajax错误响应文本?
  7. 数据库优化常用的途径(方法)
  8. c语言可以设计系统嘛,C语言自主学习系统设计与实现.doc
  9. Actran助力汽车全频率段声学响应预测与优化
  10. Java垃圾回收机制知识点总结
  11. Win7删除GRUB For DOS启动项
  12. 数据到物联网服务器作用,物联网数据分析是什么?物联网数据分析如何操作?...
  13. XJOI 9864 金字塔
  14. 阿里入职培训,针不搓
  15. 第一节课 opencv图像处理,对图片进行叠加处理
  16. android 即时通讯技术,基于Android即时通讯系统的设计与实现
  17. MTK Android Driver:PMIC
  18. 总谐波失真80_总谐波失真怎么计算啊
  19. redis命令之set和zset的操作
  20. 2022山东艾灸展,济南中医艾灸展,艾制品展,中国艾灸仪器展

热门文章

  1. 初学JAVA,javaoo小结
  2. 计算机基础知识上机操作excer,《计算机应用基础》Excel上机操作练习题.doc
  3. 【C语言进阶】 宏定义实现字符串引用
  4. linux获取文件的md5,linux shell 获取文件md5的命令linux操作系统 -电脑资料
  5. api网关 android,如何通过Android上的retrofit2使用Cognito Credentials调用API网关?
  6. android 5. 蓝牙 mesh,蓝牙mesh组网
  7. 登和平视显示无法连接服务器,提醒信息的推送方法和装置、平视显示器HUD及服务器...
  8. 线性分组码c语言实验报告,C语言线性分组码(附注释).doc
  9. 计算机网络把许多什么连接在一起,计算机网络技术基础知识汇总习题
  10. 小学计算机教师育人案例,台屯小学青年教师李春秀育人案例