日历

2011年十二月
« 7月   1月 »
 1234
567891011
12131415161718
19202122232425
262728293031  

最近评论

    Mysql

    8_2 前缀索引、定点数和浮点数的应用

    08_2_合成索引与前缀索引

    mysql> create table t(id int, content blob, hash_value varchar(40));

    mysql> insert into t select 1,repeat(‘pcedu’,100),md5(repeat(‘pcedu’,100));

    对大的文本字段进行查询的时候要建立前缀索引,来提高查询效率.例如对content建立前缀索引:
    mysql> create index index_content on t(content(10));
    mysql> select * from t where content like ‘pcedu%’;

    建立前缀索引后效率会提高.

    Mysql

    08_1解决大文本数据空洞问题

    1、选择合适的数据类型
    在使用Mysql常见数据库表时,会遇到如何为字段选择合适数据类型的问题。例如:一张员工表用来记录员工的信息。对员工字段应该如何定义,如何挑选合适的数据类型是我们要考虑的问题。
    下面学习字符、数值、日期数据类型的选择原则。
    数据的类型,一定要掌握使用场合和存储需求。

    CHAR 与 VARCHAR
    1、都是用来存储字符串,但他们保存和检索的方式不同。
    1-1)、CHAR属于固定长度的字符类型,所以处理速度要快。其缺点是浪费存储空间,需要程序对行尾空格处理。
    1-2)、VARCHAR属于可变长度的字符类型。
    2、两种类型在不同存储引擎上使用原则也不同:
    2-1MYISAM存储引擎:建议使用固定长度的数据列
    2-2MEMORY存储引擎:两者都作为CHAR类型处理。要考虑性能与速度
    2-3INNODB存储引擎:建议使用VARCHAR类型。事务性,对事务要求准确性高

    Mysql

    07_5Merge存储引擎的使用和各种引擎的使用场合

    1、Merge存储引擎是一组MyISAM表的组合,这些MyISAM标必须结果完全一样,MERGE表本身没有数据,对MERG表可以查询,更新,删除的操作,实际上是对MyISAM标的操作。
    2、对于MERGE类型表的插入操作,是通过INSERT_METHOD子句定于插入的表,有三个不同的值:
    (1)FIRST使插入操作作用在第一个表上
    (2)LAST是插入操作作用在最后一个表上
    (3)NO对MERGE不执行插入操作
    3、MERGE在磁盘上有两个文件:frm文件和MRG包含组合表信息。

    mysql> create table video1(id smallint unsigned auto_increment, name varchar(50),primary key(id)) engine=myisam;
    Query OK, 0 rows affected (0.00 sec)

    mysql> create table video2(id smallint unsigned auto_increment, name varchar(50),primary key(id)) engine=myisam;
    Query OK, 0 rows affected (0.00 sec)
    mysql> create table allvideo(id smallint unsigned auto_increment, name varchar(50),primary key(id)) engine=merge union(video1,video2) insert_method=last;
    建立联合
    mysql> insert into video1 select 0,’java’;
    mysql> insert into video2 select 1,’C++’;
    mysql> […]

    linux/unix基础知识

    CentOS 6.2 发布

    6.1 发布仅一个多星期,6.2就发布了。
    官方已经正式发布 CentOS 6.2,下载地址:

    http://isoredirect.centos.org/centos/6/isos/i386/
    http://isoredirect.centos.org/centos/6/isos/x86_64/

    linux/unix基础知识

    7-4 MEMORY存储引擎

    1、MEMORY存储引擎使用存在内存中的内容来创建。每个MEMORY表只是几对应一个磁盘文件,格式为.frm。MEMORY类型的表访问非常快,因为它的数据是放在内存中的,并且默认使用HASH索引,但是一旦关闭服务,标中的数据全部丢失。
    2、MEMORY类型的存储引擎主要用于哪些内容变化不频繁的代码标,或者作为统计操作的中间结果表,便于高效地对中建表进行分析并得到最终的统计结果。、
    mysql> insert into dept select 0,’a’;
    mysql> insert into dept select 0,’b’;
    mysql> insert into dept select 0,’c’;
    mysql> insert into dept select 0,’d’;

    mysql> create table mem_dept engine=memory select count(*) from dept;
    mysql> select * from mem_dept;
    +———-+
    | count(*) |
    +———-+
    |        4 |
    +———-+
    1 row in set (0.00 sec)
    mysql> show table status like ‘mem_dept’ \G 看一下表的结果,注意,必须用like,不能直接制定表名。
    *************************** 1. row […]

    Mysql

    07_3InnoDB存储引擎的使用

    1、InnoDB提供了具有提交,回滚和崩溃恢复能力的事务安全。但是对比MyISAM的存储引擎,InnoDB写的处理效率差一点,并且会占用更多的磁盘空间以保留数据和索引
    2、InnoDB不同于其他存储引擎的特点:
    (1)自动增长列:
    (1)、自动增长列必须是索引,如果是组合索引也必须是第一列
    (2)、可以手工插入值
    (3)、但插入的值为空或0,则实际插入的是自动增长后的值
    (4)、可以通过alter table auto_table auto_increment=10;修改初值
    (5)、可以使用last_insert_id()查询当前线程最后插入的记录使用的值
    (2)外键约束

    Mysql

    07_2MyISAM存储引擎的使用

    1、MyISAM是Mysql的默认存储引擎。不支持事务也不支持外键,其他优势就是访问速度快
    2、对事务完整性没有要求,以查询、添加为主的应用基本上都可以选择使用这个引擎来创建表
    3、每个MyISAM在磁盘上存储成3个文件,其文件名和表名相同。扩展名分别是:frm(存储表定义),MYD(MYData,存储数据),MYI(MYIndex,存储索引)。
    4、数据文件和索引文件可以放置在不同的目录,平均分布IO,获得更可得速度。

    [root@localhost test]# pwd
    /var/lib/mysql/test
    [root@localhost test]# ll
    total 48
    -rw-rw—- 1 mysql mysql 8614 Dec 20 05:09 employee.frm
    -rw-rw—- 1 mysql mysql    0 Dec 20 05:09 employee.MYD
    -rw-rw—- 1 mysql mysql 1024 Dec 20 05:09 employee.MYI
    -rw-rw—- 1 mysql mysql 8592 Dec 25 02:45 sal.frm表定义文件
    -rw-rw—- 1 mysql mysql   48 Dec 25 02:46 sal.MYD数据存储文件
    -rw-rw—- 1 mysql mysql 1024 Dec 25 04:05 sal.MYI索引存储文件
    -rw-rw—- 1 […]

    Mysql

    7 存储引擎管理

    7存储引擎管理
    表类型(存储引擎)的选择
    mysql的存储引擎有:MyISAM,InnoDB,MEMORY,MERGE
    插件式存储引擎是Mysql数据库最重要的特性之一,用户可以根据应用的需要选择如何存储和索引数据,是否使用事务等。Mysql默认支持多种存储引擎,以适用于不同领域的数据库应用需要。
    Mysql5.0支持的存储引擎包括MyISAM,InnoDB,BDB,MEMORY,MERGE,EXAMPLE,NDB Cluster,ARCHIVE,CSV,BLACKHOLE,FEDERATED,FEDERATED等,其中 InnoDB和DBD提供事务安全表,其他都为非事务安全。

    分析器和优化器好不好,事务型的,非事务性的。

    关于Mysql存储引擎的概述在Mysql手册的第14章。

    只有InnoDB支持外键,其他引擎都不支持外键。

    mysql> show variables like ‘table_type’;
    +—————+——–+
    | Variable_name | Value  |
    +—————+——–+
    | table_type    | MyISAM |
    +—————+——–+

    Mysql

    5日期函数与数值函数的应用

    数值函数:ABS(x) 返回x的绝对值
    CEIL(x) 返回大于x的最小整数值
    FLOOR(x) 返回小于x的最大整数值
    MOD(x,y) 返回x/y的值
    RAND() 返回0-1的随机值
    ROUND(x,y) 返回参数x的四舍五入的有y位小数的值
    TRUNCATE(x,y) 返回数字x截断为y位小数的结果

    Mysql

    MySQL运算符

    1.算术运算符:+,-,*,/,%,mod
    select 0.1+0.22,0.1-0.22,0.1*0.22,0.1/0.22,0.1 mod 0.22
    2.比较运算符:=,!=或<>,<=>null的安全的等于,<,<=,>,>=,between,in,is null,is not null ,Like
    mysql> select 1<=>1,1<=>0,null<=>null;
    +——-+——-+————-+
    | 1<=>1 | 1<=>0 | null<=>null |
    +——-+——-+————-+
    |     1 |     0 |           1 |
    +——-+——-+————-+
    mysql> select 123456 like ‘123%’,123456 like ‘%234%’;
    +——————–+———————+
    | 123456 like ‘123%’ | 123456 like ‘%234%’ |
    +——————–+———————+
    |                  1 |                   1 |
    +——————–+———————+

    Mysql

    txt数据导入到mysql数据库

    今天得到一个txt格式的数据库文件,一直在想怎么导入到mysql数据库中,查了一些资料,mysql手册,终于找到方法了

    mysql> LOAD DATA INFILE ‘data.txt’ INTO TABLE db2.my_table;

    data.txt文件要在mysql的数据库目录下,比如/var/lib/mysql/bbk,将data.txt导入到bbk数据库中的user table:

    mysql> create table user(username varchar(50), password varchar(20));

    mysql> load data infile ‘/var/lib/mysql/bbk/data.txt’ into table bbk.user;

    在这里我使用了绝对路径,虽然mysql默认使用相对路径,mysql会到默认的/var/lib/mysql/bbk目录下查找data.txt数据文本文件,但是总是报错,所以我直接使用了绝对路径,就不报错了。

    Mysql

    3:Mysql的数据类型

    1数值类型
    2日期时间类型
    3字符串类型
    mysql> ? data types;
    You asked for help about help category: “Data Types”
    For more information, type ‘help <item>’, where <item> is one of the following
    topics:
       AUTO_INCREMENT
       BIGINT
       BINARY
       BIT
       BLOB
       BLOB DATA TYPE
       BOOLEAN
       CHAR
       CHAR BYTE
       DATE
       DATETIME
       DEC
       DECIMAL
       DOUBLE
       DOUBLE PRECISION
       ENUM
       FLOAT
       INT
       INTEGER
       LONGBLOB
       LONGTEXT
       MEDIUMBLOB
       MEDIUMINT
       MEDIUMTEXT
       SET DATA TYPE
       […]

    Mysql

    02_3获取mysql的帮助&利用网络资源学习

    mysql> help

    For information about MySQL products and services, visit:
       http://www.mysql.com/
    For developer information, including the MySQL Reference Manual, visit:
       http://dev.mysql.com/
    To buy MySQL Network Support, training, or other products, visit:
       https://shop.mysql.com/

    List of all MySQL commands:
    Note that all text commands must be first on line and end with ‘;’
    ?         (\?) Synonym for `help’.
    clear     (\c) Clear command.
    connect   (\r) Reconnect […]

    Mysql

    02_2MySQL的SQL分类的DML

    DML(Data Manipulation Language)
    插入记录:
    insert into table_name(field1,…) values(value1,…)
    insert into table_name select value1[,value2]
    更新记录:
    update table_name set col1=xx,col2=yy [where xxxx]
    删除记录:
    delete from table [where]
    查询记录:
    select * from table_name

    Mysql

    Mysql笔记1 MySQL的sql简介&Mysql分类

    SQL分类:
    DDL(Data Definition Language) 语句: create,drop,alert
    DML(Data Manipulation Language)语句:insert,delete,update,select
    DCL(Data control language)语句:grant,revoke

    DDL(Data Definition Language)
    数据库的管理:
    显示所有数据库(show databases)
    使用数据库(use databasename)
    数据库创建(create database dbname)
    数据库删除(drop database dbname)

    linux企业应用

    linux 下 wordpress的安装配置

    第一步:安装apache和mysql,
    [root@bogon ~]# yum -y install httpd
    [root@bogon ~]# yum -y install mysql*
    [root@bogon ~]# yum -y install php-mysql

    以上这些都是必须的,当然,上传得时候我使用的是vsftpd,这个也要安装配置的!

    第二步:下载wordpress,http://cn.wordpress.org/releases/,这个连接是wordpress的下载网址,在这里我下载了wordpress3.1。将下载的wordpress3.1上传到linux服务器上
    [root@bogon pub]# pwd
    /var/ftp/pub
    [root@bogon pub]# ll
    total 28676
    -rw——- 1 ftp ftp  3108906 Dec  8 05:02 wordpress-3.1-zh_CN.tar.gz

    [root@bogon pub]# cp wordpress-3.1-zh_CN.tar.gz /var/www/html
    [root@bogon html]# cd /var/www/html
    [root@bogon html]# ll
    total 3044
    -rw——- 1 root root 3108906 Dec 11 00:19 wordpress-3.1-zh_CN.tar.gz
    [root@bogon html]#
    [root@bogon html]# cd /var/www/html
    [root@bogon html]# ll
    total 3044
    -rw——- 1 […]