一.安装

ubuntu上安装MySQL非常简单只需要几条命令就可以完成。

  1. sudo apt-get install mysql-server
 
  2. apt-get isntall mysql-client
 

  3.  sudo apt-get install libmysqlclient-dev

 
  安装过程中会提示设置密码什么的,注意设置了不要忘了,安装完成之后可以使用如下命令来检查是否安装成功:
 
  sudo netstat -tap | grep mysql
 
  通过上述命令检查之后,如果看到有mysql 的socket处于 listen 状态则表示安装成功。
 
  登陆mysql数据库可以通过如下命令:
 
  mysql -u root -p 
 
  -u 表示选择登陆的用户名, -p 表示登陆的用户密码,上面命令输入之后会提示输入密码,此时输入密码就可以登录到mysql。
 
  然后通过 show databases; 就可以查看当前的数据库。
 
  我们选择 mysql数据库就行下一步操作,使用use mysql 命令,显示当前数据库的表单:show tables 
 
二.MySQL c语言函数
 
  来自:http://blog.csdn.net/jlfzhz/article/details/5839072
 
              1.mysql_affected_rows()                //返回上次UPDATE、DELETE或INSERT查询更改/删除/插入的行数

  •  2.mysql_autocommit()			               //切换 autocommit模式,ON/OFF。
  •  3.mysql_change_user()			              //更改打开连接上的用户和数据库。
  •  4.mysql_charset_name()			              //返回用于连接的默认字符集的名称。
  •  5.mysql_close()					              //关闭服务器连接。
  •  6.mysql_commit()				              //提交事务。
  •  7.mysql_data_seek()				             //在查询结果集中查找属性行编号。
  •  8.mysql_debug()					      //用给定的字符串执行DBUG_PUSH。
  •  9.mysql_dump_debug_info()			      //让服务器将调试信息写入日志。
  • 10.mysql_errno()					      //返回上次调用的MySQL函数的错误编号。
  • 11.mysql_escape_string()			              //为了用在SQL语句中,对特殊字符进行转义处理。
  • 12.mysql_fetch_field()				      //返回下一个表字段的类型。
  • 13.mysql_fetch_field_direct()		              //给定字段编号,返回表字段的类型。
  • 14.mysql_fetch_fields()			              //返回所有字段结构的数组。
  • 15.mysql_fetch_lengths()			              //返回当前行中所有列的长度。
  • 16.mysql_fetch_row()			              //从结果集中获取下一行
  • 17.mysql_field_seek()			              //将列光标置于指定的列。
  • 18.mysql_field_count()			              //返回上次执行语句的结果列的数目。
  • 19.mysql_field_tell()				              //返回上次mysql_fetch_field()所使用字段光标的位置。
  • 20.mysql_free_result()				      //释放结果集使用的内存。
  • 21.mysql_get_client_info()			      //以字符串形式返回客户端版本信息。
  • 22.mysql_get_client_version()		              //以整数形式返回客户端版本信息。
  • 23.mysql_get_host_info()			              //返回描述连接的字符串。
  • 24.mysql_get_server_version()		              //以整数形式返回服务器的版本号。
  • 25.mysql_get_proto_info()			      //返回连接所使用的协议版本。
  • 26.mysql_get_server_info()			      //返回服务器的版本号。
  • 27.mysql_info()						      //返回关于最近所执行查询的信息。
  • 28.mysql_init()						      //获取或初始化MYSQL结构。
  • 29.mysql_insert_id()				              //返回上一个查询为AUTO_INCREMENT列生成的ID。
  • 30.mysql_kill()						      //杀死给定的线程。
  • 31.mysql_library_end()				      //最终确定MySQL C API库。
  • 32.mysql_library_init()				      //初始化MySQL C API库。
  • 33.mysql_list_dbs()					      //返回与简单正则表达式匹配的数据库名称。
  • 34.mysql_list_fields()				              //返回与简单正则表达式匹配的字段名称。
  • 35.mysql_list_processes()			              //返回当前服务器线程的列表。
  • 36.mysql_list_tables()				      //返回与简单正则表达式匹配的表名。
  • 37.mysql_more_results()				//检查是否还存在其他结果。
  • 38.mysql_next_result()				//在多语句执行过程中返回/初始化下一个结果。
  • 39.mysql_num_fields()				//返回结果集中的列数。
  • 40.mysql_num_rows()					//返回结果集中的行数。
  • 41.mysql_options()					//为mysql_connect()设置连接选项。
  • 42.mysql_ping()						//检查与服务器的连接是否工作,如有必要重新连接。
  • 43.mysql_query()					//执行指定为“以Null终结的字符串”的SQL查询。
  • 44.mysql_real_connect()				//连接到MySQL服务器。
  • 45.mysql_real_escape_string()		//考虑到连接的当前字符集,为了在SQL语句中使用,对字符串中的特殊字符进行转义处理。
  • 46.mysql_real_query()				//执行指定为计数字符串的SQL查询。
  • 47.mysql_refresh()					//刷新或复位表和高速缓冲。
  • 48.mysql_reload()					//通知服务器再次加载授权表。
  • 49.mysql_rollback()					//回滚事务。
  • 50.mysql_row_seek()					//使用从mysql_row_tell()返回的值,查找结果集中的行偏移。
  • 51.mysql_row_tell()					//返回行光标位置。
  • 52.mysql_select_db()				//选择数据库。
  • 53.mysql_server_end()				//最终确定嵌入式服务器库。
  • 54.mysql_server_init()				//初始化嵌入式服务器库。
  • 55.mysql_set_server_option()		//为连接设置选项(如多语句)。
  • 56.mysql_sqlstate()					//返回关于上一个错误的SQLSTATE错误代码。
  • 57.mysql_shutdown()					//关闭数据库服务器。
  • 58.mysql_stat()						//以字符串形式返回服务器状态。
  • 59.mysql_store_result()				//检索完整的结果集至客户端。
  • 60.mysql_thread_id()				//返回当前线程ID。
  • 61.mysql_thread_safe()				//如果客户端已编译为线程安全的,返回1。
  • 62.mysql_use_result()				//初始化逐行的结果集检索。
  • 63.mysql_warning_count()			//返回上一个SQL语句的告警数。
 
三.基本操作
 来自:http://blog.csdn.net/lxh090821/article/details/9410943 

1       登录数据库

格式: MySQL -h主机地址 -u用户名 -p用户密码–P端口 –D数据库–e “SQL 内容”

>mysql -uroot -p 数据库名称

2       修改密码

修改在本机root用户下的mysql密码

shell>mysql -u root -p

mysql>set password for 'root'@'localhost' = password("新密码");

mysql> update user setpassword=password(”123″) where user=’root’;

3       添加用户

格式:grant select on 数据库.* to 用户名@登录主机 identified by \"密码\"

例1、增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入MySQL,然后键入以下命令:

grant select,insert,update,deleteon *.* to test2@localhost identified by\"abc\";

如果你不想test2有密码,可以再打一个命令将密码消掉。

grantselect,insert,update,delete on mydb.* to test2@localhostidentified by \"\";

4       创建数据库

create databasename; 创建数据库

usedatabasename; 选择数据库

5       备份/恢复数据库

shell>mysqldump -h host -u root -p dbname >dbname_backup.sql

shell>mysqladmin -h myhost -u root -p create dbname

shell>mysqldump -h host -u root -p dbname < dbname_backup.sql

如果只想卸出建表指令,则命令如下:

shell>mysqladmin -u root -p -d databasename > a.sql

mysqldump -uroot -p test mytable>./test.txt

将备份数据导入到数据库:(导回test数据库)

备份数据库staffer

mysqldump -uroot-proot staffer > staffer.sql

得到的staffer.sql是一个sql脚本,不包括建库的语句,所以你需要手工

创建数据库才可以导入

恢复数据库staffer,需要创建一个空库staffer

mysql -uroot-proot staffer<staffer.sql

如果不希望后来手工创建staffer,可以

mysqldump -uroot-proot --databases staffer> staffer.sql

mysql -uroot-proot > staffer.sql

但这样的话系统种就不能存在staffer库,且无法导入其他名字的数据库,

当然你可以手工修改staffer.sql文件

如果只想卸出插入数据的sql命令,而不需要建表命令,则命令如下:

shell>mysqladmin -u root -p -t databasename > a.sql

那么如果我只想要数据,而不想要什么sql命令时,应该如何操作呢?

mysqldump -T./phptest driver

其中,只有指定了-T参数才可以卸出纯文本文件,表示卸出数据的目录,./表示当前目录,即与mysqldump同一目录。如果不指定driver 表,则将卸出整个数据库的数据。每个表会生成两个文件,一个为.sql文件,包含建表执行。另一个为.txt文件,只包含数据,且没有sql指令。

可将查询存储在一个文件中并告诉mysql从文件中读取查询而不是等待键盘输入。可利用外壳程序键入重定向实用程序来完成这项工作。

6       导入.sql文件命令(例如D:/mysql.sql)

mysql>use database;

mysql>source /home/mysql.sql;

UPDATE以新的值更新现存表中行的列。SET 子句指出要修改哪个列和他们应该给定的值。WHERE

子句如果被给出,指定哪个记录行应该被更新。否则,所有的记录行被更新。如果 ORDER BY 子句被指定,记录行将被以指定的次序更新。

如果你指定关键词LOW_PRIORITY,UPDATE 的执行将被延迟,直到没有其它的客户端正在读取表。

如果你指定关键词IGNORE,该更新语句将不会异常中止,即使在更新过程中出现重复键错误。导致冲突的记录行将不会被更新。

如果在一个表达式中从tbl_name 中访问一个列,UPDATE 使用列的当前值。举例来说,下面的语句设置 age 列值为它的当前值加 1 :

mysql> UPDATE persondata SETage=age+1;

UPDATE赋值是从左到右计算的。举例来说,下列语句将 age 列设置为它的两倍,然后再加 1 :

mysql> UPDATE persondata SETage=age*2, age=age+1;

如果你设置列为其当前的值,MySQL 注意到这点,并不更新它。

UPDATE返回实际被改变的记录行数目。在 MySQL 3.22 或更新的版本中,C API 函数 mysql_info()

返回被匹配并更新的记录行数目,以及在 UPDATE 期间发生的警告的数目。

在 MySQL3.23 中,你可以使用 LIMIT # 来确保只有给定的记录行数目被更改。

如果一个 ORDER BY 子句被使用(从 MySQL4.0.0 开始支持),记录行将以指定的次序被更新。这实际上只有连同 LIMIT

一起才有用。

从 MySQL 4.0.4 开始,你也可以执行一个包含多个表的UPDATE 的操作:

UPDATE items,month SETitems.price=month.price

WHERE items.id=month.id;

注意:多表 UPDATE 不可以使用 ORDER BY 或LIMIT。

关键字: mysql

启动:net start mySql;

进入:mysql -u root -p/mysql -hlocalhost -u root -p databaseName;

列出数据库:show databases;

选择数据库:use databaseName;

列出表格:show tables;

显示表格列的属性:show columns fromtableName;

建立数据库:source fileName.txt;

匹配字符:可以用通配符_代表任何一个字符,%代表任何字符串;

7       用文本方式将数据装入数据库表中(例如D:/mysql.txt)

mysql> LOAD DATA LOCAL INFILE/“D:/mysql.txt" INTO TABLE MYTABLE;

8       删除数据库

drop database name 直接删除数据库

mysqladmin drop database name 删除数据库前,有提示

9       数据库授权

GRANT ALL PRIVILEGES ON bdc.* TObdc@'%' IDENTIFIEDBY 'bdc123' WITH GRANT OPTION;

flush privileges

授权访问bdc 的所有表 用户为bdc 任何主机 ,密码为bdc@123

创建一个用户custom在特定客户端it363.com登录,可访问特定数据库fangchandb

mysql >grant select, insert,update, delete, create,drop on fangchandb.* to custom@it363.com identified by ‘passwd’

10    删除授权:

mysql> revoke all privilegeson *.* from root@”%”;

mysql> delete from user whereuser=”root” and host=”%”;

mysql> flush privileges;

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

selectversion(),current_date;

查询时间:select now();

查询当前用户:select user();

查询数据库版本:select version();

查询当前使用的数据库:select database();

12    查询所有数据表

>show tables;

13    查询表的字段信息

>desc 表名称;

14    创建表

create table s_position

(

id int not null auto_increment,

name varchar(20) not nulldefault '经理', #设定默认值

description varchar(100),

primary key PK_positon (id) #设定主键

);

create table department

(

id int not null auto_increment,

name varchar(20) not nulldefault '系统部', #设定默认值

description varchar(100),

primary key PK_department (id) #设定主键

);

create table depart_pos

(

department_id int not null,

position_id int not null,

primary key PK_depart_pos(department_id,position_id) #设定复和主键

);

create table staffer

(

id int not null auto_incrementprimary key, #设定主键

name varchar(20) not nulldefault '无名氏', #设定默认值

department_id int not null,

position_id int not null,

unique (department_id,position_id)#设定唯一值

);

15    修改结构

mysql>

#表position增加列test

alter tableposition add(test char(10));

#表position修改列test

alter tableposition modify test char(20) not null;

#表position修改列test默认值

alter tableposition alter test set default 'system';

#表position去掉test默认值

alter tableposition alter test drop default;

#表position去掉列test

alter tableposition drop column test;

#表depart_pos删除主键

alter tabledepart_pos drop primary key;

#表depart_pos增加主键

alter tabledepart_pos add primary key PK_depart_pos (department_id,position_id);

16    操作数据

#插入表department

insert into department(name,description)values('系统部','系统部');

insert into department(name,description)values('公关部','公关部');

insert into department(name,description)values('客服部','客服部');

insert into department(name,description)values('财务部','财务部');

insert into department(name,description)values('测试部','测试部');

#插入表s_position

insert into s_position(name,description)values('总监','总监');

insert into s_position(name,description)values('经理','经理');

insert into s_position(name,description)values('普通员工','普通员工');

#插入表depart_pos

insert intodepart_pos(department_id,position_id)

select a.id department_id,b.id postion_id

from department a,s_position b;

#插入表staffer

insert intostaffer(name,department_id,position_id) values('陈达治',1,1);

insert into staffer(name,department_id,position_id)values('李文宾',1,2);

insert intostaffer(name,department_id,position_id) values('马佳',1,3);

insert intostaffer(name,department_id,position_id) values('亢志强',5,1);

insert intostaffer(name,department_id,position_id) values('杨玉茹',4,1);

17    查询及删除操作

#显示系统部的人员和职位

selecta.name,b.name department_name,c.name position_name

from staffera,department b,s_position c

wherea.department_id=b.id and a.position_id=c.id and b.name='系统部';

#显示系统部的人数

select count(*)from staffer a,department b

wherea.department_id=b.id and b.name='系统部'

#显示各部门的人数

select count(*)cou,b.name from staffer a,department b

wherea.department_id=b.idgroup by b.name;

#删除客服部

delete fromdepartment where name='客服部';

#将财务部修改为财务一部

updatedepartment set name='财务一部' wherename='财务部';

18    删除表

mysql>drop TABLE MYTABLE;

19    清空表

mysql>delete from MYTABLE;

20    添加表字段

alter tabletable1 add transactor varchar(10) not Null;

alter tabletable1 add id int unsigned not Null auto_increment primary key

21    修改某个表的字段类型及指定为空或非空

>alter table 表名称 change 字段名称 字段名称 字段类型 [是否允许非空];
> alter table 表名称 modify 字段名称 字段类型 [是否允许非空];

>alter table 表名称 modify 字段名称 字段类型 [是否允许非空];

22    如果要删除某一字段,可用命令:

ALTER TABLEmytable DROP 字段名;

23    添加唯一键

ALTER TABLE`test2` ADD UNIQUE ( `userid`)

24    修改主键

ALTER TABLE`test2` DROP PRIMARY KEY ,ADD PRIMARY KEY ( `id` )

alter tableversion_template drop primary key ,add primary key version,role,type);

25    增加索引

ALTER TABLE`test2` ADD INDEX ( `id` )

alter tabletable1 add index ind_id (id);

create indexind_id on table1 (id);

create uniqueindex ind_id on table1 (id);//建立唯一性索引

26    删除索引

drop indexidx_id on table1;

alter tabletable1 drop index ind_id;

27    重命名表:

alter table t1 rename t2;

28    增加一个字段:

alter tabletabelName add column fieldName dateType;

29    增加多个字段

alter tabletabelName add column fieldName1 dateType,add columns fieldName2 dateType;

多行命令输入:注意不能将单词断开;当插入或更改数据时,不能将字段的字符串展开到多行里,否则硬回车将被储存到数据中;

增加一个管理员帐户:grant all on *.* to user@localhost identified by"password";

每条语句输入完毕后要在末尾填加分号';',或者填加'\g'也可以;

30    创建临时表:

create temporarytable zengchao(name varchar(10));

31    创建表是先判断表是否存在

create table ifnot exists students(……);

32    从已经有的表中复制表的结构

create tabletable2 select * from table1 where 1<>1;

33    复制表

create tabletable2 select * from table1;

34    对表重新命名

alter table table1 rename astable2;

35    修改列的类型

alter table table1 modify id intunsigned;//修改列id的类型为int unsigned

alter table table1 change id sidint unsigned;//修改列id的名字为sid,而且把属性修改为int unsigned

36    联合字符或者多个列(将列id与":"和列name和"="连接)

select concat(id,':',name,'=')from students;

37    limit(选出10到20条)<第一个记录集的编号是0>

select * from students order byid limit 9,10;

38    MySQL会使用索引的操作符号

<,<=,>=,>,=,between,in,不带%或者_开头的like

39    存储过程

1)查看存储过程

select name from mysql.proc where db=’数据库名’;

或者

select routine_name frominformation_schema.routines where routine_schema='数据库名';

或者

show procedure status where db='数据库名';

40    MySQL存储过程的修改

ALTER PROCEDURE

更改用CREATEPROCEDURE 建立的预先指定的存储过程,其不会影响相关存储过程或存储功能。

41     MySQL存储过程的删除

删除一个存储过程比较简单,和删除表一样:

DROP PROCEDURE

从MySQL的表格中删除一个或多个存储过程。

42    存储过程基本函数

(1).字符串类

CHARSET(str) //返回字串字符集
CONCAT (string2 [,... ]) //连接字串
INSTR (string ,substring ) //返回substring首次在string中出现的位置,不存在返回0
LCASE (string2 ) //转换成小写
LEFT (string2 ,length ) //从string2中的左边起取length个字符
LENGTH (string ) //string长度
LOAD_FILE (file_name ) //从文件读取内容
LOCATE (substring , string[,start_position ] ) 同INSTR,但可指定开始位置
LPAD (string2 ,length ,pad ) //重复用pad加在string开头,直到字串长度为length
LTRIM (string2 ) //去除前端空格
REPEAT (string2 ,count ) //重复count次
REPLACE (str ,search_str ,replace_str) //在str中用replace_str替换search_str
RPAD (string2 ,length ,pad) //在str后用pad补充,直到长度为length
RTRIM (string2 ) //去除后端空格
STRCMP (string1 ,string2 ) //逐字符比较两字串大小,
SUBSTRING (str , position [,length ]) //从str的position开始,取length个字符,
注:mysql中处理字符串时,默认第一个字符下标为1,即参数position必须大于等于1

mysql> select substring('abcd',0,2);

+-----------------------+

| substring('abcd',0,2) |

+-----------------------+

|                       |

+-----------------------+

1 row in set (0.00 sec)

mysql> select substring('abcd',1,2);

+-----------------------+

| substring('abcd',1,2) |

+-----------------------+

|     ab                |

+-----------------------+

1 row in set (0.02 sec)

TRIM([[BOTH|LEADING|TRAILING] [padding] FROM]string2) //去除指定位置的指定字符
UCASE (string2 ) //转换成大写
RIGHT(string2,length) //取string2最后length个字符
SPACE(count) //生成count个空格

(2).数学类

ABS (number2 ) //绝对值
BIN (decimal_number ) //十进制转二进制
CEILING (number2 ) //向上取整
CONV(number2,from_base,to_base) //进制转换
FLOOR (number2 ) //向下取整
FORMAT (number,decimal_places ) //保留小数位数
HEX (DecimalNumber ) //转十六进制
注:HEX()中可传入字符串,则返回其ASC-11码,如HEX('DEF')返回4142143
也可以传入十进制整数,返回其十六进制编码,如HEX(25)返回19
LEAST (number , number2 [,..]) //求最小值
MOD (numerator ,denominator ) //求余
POWER (number ,power ) //求指数
RAND([seed]) //随机数
ROUND (number [,decimals ]) //四舍五入,decimals为小数位数]

注:返回类型并非均为整数,如:
(1)默认变为整形值

mysql> select round(1.23);

+-------------+

| round(1.23) |

+-------------+

|           1 |

+-------------+

1 row in set (0.00 sec)

mysql> select round(1.56);

+-------------+

| round(1.56) |

+-------------+

|           2 |

+-------------+

1 row in set (0.00 sec)

(2)可以设定小数位数,返回浮点型数据

mysql> select round(1.567,2);

+----------------+

| round(1.567,2) |

+----------------+

|           1.57 |

+----------------+

1 row in set (0.00 sec)

SIGN (number2 ) //

 

(3).日期时间类

ADDTIME (date2 ,time_interval )//将time_interval加到date2
CONVERT_TZ (datetime2 ,fromTZ ,toTZ ) //转换时区
CURRENT_DATE ( ) //当前日期
CURRENT_TIME ( ) //当前时间
CURRENT_TIMESTAMP ( ) //当前时间戳
DATE (datetime ) //返回datetime的日期部分
DATE_ADD (date2 , INTERVAL d_value d_type ) //在date2中加上日期或时间
DATE_FORMAT (datetime ,FormatCodes ) //使用formatcodes格式显示datetime
DATE_SUB (date2 , INTERVAL d_value d_type ) //在date2上减去一个时间
DATEDIFF (date1 ,date2 ) //两个日期差
DAY (date ) //返回日期的天
DAYNAME (date ) //英文星期
DAYOFWEEK (date ) //星期(1-7) ,1为星期天
DAYOFYEAR (date ) //一年中的第几天
EXTRACT (interval_name FROM date ) //从date中提取日期的指定部分
MAKEDATE (year ,day ) //给出年及年中的第几天,生成日期串
MAKETIME (hour ,minute ,second ) //生成时间串
MONTHNAME (date ) //英文月份名
NOW ( ) //当前时间
SEC_TO_TIME (seconds ) //秒数转成时间
STR_TO_DATE (string ,format ) //字串转成时间,以format格式显示
TIMEDIFF (datetime1 ,datetime2 ) //两个时间差
TIME_TO_SEC (time ) //时间转秒数]
WEEK (date_time [,start_of_week ]) //第几周
YEAR (datetime ) //年份
DAYOFMONTH(datetime) //月的第几天
HOUR(datetime) //小时
LAST_DAY(date) //date的月的最后日期
MICROSECOND(datetime) //微秒
MONTH(datetime) //月
MINUTE(datetime) //分返回符号,正负或0
SQRT(number2) //开平方

43    使用索引的缺点

1)  增删改数据的速度;

2)占用磁盘空间;

3)增加查询优化器的负担;

当查询优化器生成执行计划时,会考虑索引,太多的索引会给查询优化器增加

44    分析索引效率

方法:在一般的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的建议;

45    使用较短的定长列

1)尽可能使用较短的数据类型;

2)尽可能使用定长数据类型;

a)用char代替varchar,固定长度的数据处理比变长的快些;

b)对于频繁修改的表,磁盘容易形成碎片,从而影响数据库的整体性能;

c)万一出现数据表崩溃,使用固定长度数据行的表更容易重新构造。使用固定长度的数据行,每个记录的开始位置都是固定记录长度的倍数,可以很容易被检测到,但是使用可变长度的数据行就不一定了;

d)对于MyISAM类型的数据表,虽然转换成固定长度的数据列可以提高性能,但是占据的空间也大;

46    使用not null和enum

尽量将列定义为notnull,这样可使数据的出来更快,所需的空间更少,而且在查询时,MySQL不需要检查是否存在特例,即null值,从而优化查询;

如果一列只含有有限数目的特定值,如性别,是否有效或者入学年份等,在这种情况下应该考虑将其转换为enum列的值,MySQL处理的更快,因为所有的enum值在系统内都是以标识数值来表示的;

47    使用optimize table

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

48    使用procedure analyse()

可以使用procedure analyse()显示最佳类型的建议,使用很简单,在select语句后面加上procedureanalyse()就可以了;例如:

select * from students procedureanalyse();

select * from students procedureanalyse(16,256);

第二条语句要求procedure analyse()不要建议含有多于16个值,或者含有多于256字节的enum类型,如果没有限制,输出可能会很长;

49    使用查询缓存

1)查询缓存的工作方式:

第一次执行某条select语句时,服务器记住该查询的文本内容和查询结果,存储在缓存中,下次碰到这个语句时,直接从缓存中返回结果;当更新数据表后,该数据表的任何缓存查询都变成无效的,并且会被丢弃。

2)配置缓存参数:

变量:query_cache_type,查询缓存的操作模式。有3中模式,0:不缓存;1:缓存查询,除非与 select sql_no_cache开头;2:根据需要只缓存那些以select sql_cache开头的查询; query_cache_size:设置查询缓存的最大结果集的大小,比这个值大的不会被缓存。

50    调整硬件

1)在机器上装更多的内存;

2)增加更快的硬盘以减少I/O等待时间;

寻道时间是决定性能的主要因素,逐字地移动磁头是最慢的,一旦磁头定位,从磁道读则很快;

3)在不同的物理硬盘设备上重新分配磁盘活动;

如果可能,应将最繁忙的数据库存放在不同的物理设备上,这跟使用同一物理设备的不同分区是不同的,因为它们将争用相同的物理资源(磁头)。

 

MySQL数据库在linux的安装,编程与操作的更多相关文章

  1. mysql数据库在Linux下安装与配置

      mysql是一种开放源代码的关系型数据库系统(RDBMS),使用最常用的数据库管理语言--结构化查询语句(SQL)进行数据库管理. 由于mysql的开源,因此任何人都可以在General Publ ...

  2. mysql数据库基于linux的安装步骤及数据库操作

    一.数据库安装 Ubuntu上安装MySQL非常简单只需要几条命令就可以完成. sudo apt-get install mysql-server sudo apt-get isntall mysql ...

  3. MySQL入门——在Linux下安装和卸载MySQL

    MySQL入门——在Linux下安装和卸载MySQL 摘要:本文主要学习了如何在Linux系统中安装和卸载MySQL数据库. 查看有没有安装过MySQL 使用命令查看有没有安装过: [root@loc ...

  4. MySQL入门——在Linux下安装和卸载MariaDB

    MySQL入门——在Linux下安装和卸载MariaDB 摘要:本文主要学习了如何在Linux系统中安装和卸载MariaDB数据库. 查看有没有安装过MariaDB 使用命令查看有没有安装过: [ro ...

  5. MySQL数据库的卸载与安装

    MySQL数据库的卸载与安装 MySQL的完全卸载 因为不知道什么原因,电脑里同时存在两个版本的mysql,所以决定卸载重新安装,但是大家都说MySQL很难清除干净,所以特地查找完全卸载MySQL的方 ...

  6. Linux C高级编程——文件操作之系统调用

    Linux C高级编程文件操作之系统调用 宗旨:技术的学习是有限的,分享的精神是无限的.           库函数是一些完毕特定功能的函数.一般由某个标准组织制作公布,并形成一定的标准.使用库函数编 ...

  7. Linux下安装MySQL数据库以及用C语言编程存取数据库

    ubuntu下安装软件相当简单,一条简单的 apt-get install 就可以解决,相比源码安装方式唯一的缺点就是,你无法自定义软件的安装目录.不过这也不是什么太大的缺点.下面我们就用 apt-g ...

  8. 【MySql】在Linux下安装MySql数据库

    [参数环境] 1.Host OS:Win7 64bit 2.VM: VMware 11.1.0 3.Client OS:CentOS 6 4.系统中已安装的openssl版本: openssl-1.0 ...

  9. MySQL数据库起步 linux安装(更新中...)

    卸载mysql! [root@localhost usr]# yum remove mysql mysql-server mysql-libs compat-mysql51 [root@localho ...

随机推荐

  1. Windows Store App JavaScript 开发:选取文件和文件夹

    前面提到过,文件打开选取器由FileOpenPicker类表示,用于选取或打开文件,而文件夹选取器由FolderPicker类表示,用来选取文件夹.在FileOpenPicker类中,pickSing ...

  2. nginx、Apache、IIS服务器解决 413 Request Entity Too Large问题方法汇总

    一.nginx服务器 nginx出现这个问题的原因是请求实体太长了.一般出现种情况是Post请求时Body内容Post的数据太大了,如上传大文件过大.POST数据比较多. 处理方法 在nginx.co ...

  3. qt越来越好了

    qml中所有的商业控件都开源了,详见: import QtQuick.Extras 1.4 以前自己实现的时候实现了半天.

  4. vs 中统计代码行数

    ------解决方案--------------------b*[^:b#/]+.*$^b*[^:b#/]+.*$ ctrl + shift + F 查找选项勾选 正则表达式

  5. μC/OS-Ⅲ系统的源代码文件组织结构

  6. Haskell Tuple相关总结

    一.相关操作 zip:将两个List合并成一个元组序对的List. fst:返回元组序对第一个元素. snd:返回元组序对第二个元素. PS:元组序对是元组中只有两个元素的元组. 二.与List的比较 ...

  7. xcode意外退出

    完全不明所以的频繁退出 第一种 排除SVN冲突 在团队开发中,SVN冲突是最常见的了,程序异常时查看SVN文件冲突基本上成了本能. 排除SVN冲突 首先,右键主项目文件即xcodeproj文件,显示包 ...

  8. Git进行代码管理的心得

    git从网上下载安装后 直接可在开始菜单中找到 打开可以看到一个类似命令窗口的东西 用代码进行用户名和邮箱的设置 虽然不知道为什么但是教程叫我这么做 (ˇˍˇ) 然后似乎就可以用了 进入文件夹 输入对 ...

  9. JPA 各种基本用法

    查询部分属性 通常来说,都是针对 Entity 类的查询,返回的也是被查询的 Entity 类的实体.J P QL 也允许我们直接查询返回我们需要的属性,而不是返回整个 Entity .在一些 Ent ...

  10. Caliburn.Micro学习笔记目录——li-peng

    Caliburn.Micro学习笔记(一)----引导类和命名匹配规则 Caliburn.Micro学习笔记(二)----Actions Caliburn.Micro学习笔记(三)----事件聚合IE ...