一、python-mysql环境准备:

武沛齐博客:http://www.cnblogs.com/wupeiqi/articles/4938499.html


windows版本:

1、安装Mysql
2、安装Python操作mysql的模块,http://www.codegood.com/archives/129
3、安装mysql图形界面
4、验证:import MySQLdb成功

linux版本:

1、安装Mysql
参考:http://jingyan.baidu.com/article/a378c9609eb652b3282830fd.html
注意:./scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data/mysql
2、安装Python操作mysql的模块,MySQL-python-1.2.5.tar.gz
3、验证:import MySQLdb成功


二、python-mysql-API

mysql:http://www.cnblogs.com/wupeiqi/articles/5095821.html

1、查询数据

>>> import MySQLdb
>>>
>>> conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='root',db='swconfig')
>>> cur = conn.cursor()
>>> reCount=cur.execute('select * from devinfors')
>>> reCount=cur.execute('select * from devinfors')
>>> data=cur.fetchall()
>>> print data
((1L, 'BF50SW19-B3', '80.97.35.19', '101', '102', 'BF50SW20-B3', '80.97.35.20', '101', '102', 'B3', '11D', 'A3', '07', 0L), (2L, 'BF50SW03-B5', '80.97.3.19', '107', '108', 'BF50SW04-B5', '80.97.3.20', '107', '108', 'B3', '21F', 'B2', '04', 0L), (3L, 'BF50SW21-B3', '80.97.35.21', '103', '104', 'BF50SW22-B3', '80.97.35.22', '103', '104', 'B3', '21B', 'C4', '01', 0L), (7L, 'BF50SW19-B3', '80.97.35.19', '105', '106', 'BF50SW20-B3', '80.97.35.20', '105', '106', 'B3', '11D', 'A3', '07', 0L), (9L, 'BF50SW21-B3', '80.97.35.21', '107', '108', 'BF50SW22-B3', '80.97.35.22', '107', '108', 'B3', '21A', 'D2', '07', 0L), (10L, 'BF50SW21-B3', '80.97.35.21', '109', '110', 'BF50SW22-B3', '80.97.35.22', '109', '110', 'B3', '21A', 'D2', '07', 0L))
>>> print reCount
6
>>> cur.close()
>>> conn.close()


2、插入数据

>>> conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='root',db='swconfig')
>>> cur=conn.cursor()
>>> sql="insert into vlaninfos values(1,%s,%s,%s)"
>>> params=("80.2.238.0","802","B3")
>>> reCount=cur.execute(sql,params)
>>> conn.commit()


3、修改数据

>>> sql="update vlaninfos set vlan=%s,vlanid=%s where id=1"
>>> params=("80.4.238.0","800")
>>> reCount=cur.execute(sql,params)
>>> conn.commit()


4、删除数据

>>> sql="delete from vlaninfos where id=%s"
>>> params=(1,)
>>> reCount=cur.execute(sql,params)
>>> conn.commit()



三、socket

http://www.cnblogs.com/wupeiqi/articles/5040823.html

[root@localhost demo]# cat server.py 
#!/usr/bin/python27
#coding:utf-8

import socket
s=socket.socket()
ip_port=('127.0.0.1',8888)
s.bind(ip_port)
s.listen(5)
while True:
    conn,address=s.accept()
    conn.send('hello.')
    flag=True
    while flag:
        data=conn.recv(1024)
        print data
        if data=='exit':
            flag=False
        conn.send('welcome to python socket')
    conn.close()

[root@localhost demo]# cat client.py 
#!/usr/bin/python27
#coding:utf-8

import socket
client=socket.socket()
ip_port=('127.0.0.1',8888)
client.connect(ip_port)
while True:
    data=client.recv(1024)
    print data
    input_str=raw_input('clent:')
    client.send(input_str)
    if input_str=='exit':
        break

[root@localhost demo]#




四、html和javascript

http://www.cnblogs.com/wupeiqi/articles/4457274.html


jquery:

http://www.bootcss.com/

http://v3.bootcss.com/


http://www.jeasyui.net/


rgb颜色对照表

http://www.114la.com/other/rgb.htm






源码编译MySQL-5.5


一、安装cmake


cmake的重要特性之一是其独立于源码(out-of-source)的编译功能,即编译工作可以在另一个指定的目录中而非源码目录中进行,这可以保证源码目录不受任何一次编译的影响,因此在同一个源码树上可以进行多次不同的编译,如针对于不同平台编译。

跨平台编译器

# tar xf cmake-2.8.8.tar.gz
# cd cmake-2.8.8
# ./bootstrap
# make 
# make install


指定安装文件的安装路径时常用的选项:

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql
-DMYSQL_DATADIR=/mydata/data
-DSYSCONFDIR=/etc



默认编译的存储引擎包括:csv、myisam、myisammrg和heap。若要安装其它存储引擎,可以使用类似如下编译选项:

-DWITH_INNOBASE_STORAGE_ENGINE=1
-DWITH_ARCHIVE_STORAGE_ENGINE=1
-DWITH_BLACKHOLE_STORAGE_ENGINE=1
-DWITH_FEDERATED_STORAGE_ENGINE=1


若要明确指定不编译某存储引擎,可以使用类似如下的选项:

-DWITHOUT__STORAGE_ENGINE=1
-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1
-DWITHOUT_FEDERATED_STORAGE_ENGINE=1
-DWITHOUT_PARTITION_STORAGE_ENGINE=1


如若要编译进其它功能,如SSL等,则可使用类似如下选项来实现编译时使用某库或不使用某库:

-DWITH_READLINE=1
-DWITH_SSL=system
-DWITH_ZLIB=system
-DWITH_LIBWRAP=0


其它常用的选项:

-DMYSQL_TCP_PORT=3306
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock
-DENABLED_LOCAL_INFILE=1
-DEXTRA_CHARSETS=all
-DDEFAULT_CHARSET=utf8
-DDEFAULT_COLLATION=utf8_general_ci
-DWITH_DEBUG=0
-DENABLE_PROFILING=1


如果想清理此前的编译所生成的文件,则需要使用如下命令:
//make clean
rm CMakeCache.txt


二、卸载原有MySQL

[root@localhost ~]# yum list | grep My
MySQL-client.x86_64                            5.5.37-1.el6                 installed
MySQL-devel.x86_64                             5.5.37-1.el6                 installed
MySQL-shared.x86_64                            5.5.37-1.el6                 installed
MySQL-zrm.noarch                               3.0-6.el6                    epel
openscada-DB-MySQL.x86_64                      0.7.2-1.el6                  epel
perl-DateTime-Format-MySQL.noarch              0.04-8.el6                   epel
perl-Time-Piece-MySQL.noarch                   0.05-8.el6                   epel
php-ZendFramework-Db-Adapter-Mysqli.noarch     1.12.20-1.el6                epel
php-ZendFramework-Db-Adapter-Pdo-Mysql.noarch  1.12.20-1.el6                epel
phpMyAdmin.noarch                              4.0.10.19-1.el6              epel
[root@localhost ~]# rpm -e MySQL-client-5.5.37-1.el6.x86_64
[root@localhost ~]# rpm -e MySQL-shared-5.5.37-1.el6.x86_64
[root@localhost ~]# rpm -e MySQL-devel-5.5.37-1.el6.x86_64

[root@localhost ~]# service mysql stop   --- 暂停Mysql服务
Shutting down MySQL.... SUCCESS!
[root@localhost ~]# find / -name mysql  --- 删除mysql安装目录及配置文件
/etc/rc.d/init.d/mysql
/var/lib/mysql
/usr/lib64/mysql
/usr/share/mysql
/usr/local/mysql
/usr/local/mysql/data/mysql
/usr/local/mysql/data/mysql/mysql
/usr/local/mysql/include/mysql
/usr/local/mysql/bin/mysql
/usr/local/bin/mysql
[root@localhost ~]# 
[root@localhost ~]# rm -rf /var/lib/mysql
[root@localhost ~]# rm -rf /usr/lib64/mysql
[root@localhost ~]# rm -rf /usr/local/mysql
[root@localhost ~]# 
[root@localhost ~]# find / -name mysql
/etc/rc.d/init.d/mysql
/usr/share/mysql
/usr/local/bin/mysql
[root@localhost ~]# rm -rf /usr/local/bin/mysql
[root@localhost ~]# rm -rf /usr/share/mysql
[root@localhost ~]# rm -rf /etc/rc.d/init.d/mysql
[root@localhost ~]# find / -name mysql
[root@localhost ~]#




三、官方下载Mariadb源码及编译

https://mariadb.org/download/


编译过程,参考:http://www.cnblogs.com/yangjinjin/p/3158226.html

[root@localhost ~]# tar xf mariadb-5.5.44.tar.gz
[root@localhost ~]# cd mariadb-5.5.44
[root@localhost mariadb-5.5.44]# ls
BUILD        CMakeLists.txt   COPYING         Docs               INSTALL-SOURCE      libmysqld    mysys      README   sql-bench   support-files  VERSION
BUILD-CMAKE  cmd-line-utils   COPYING.LESSER  EXCEPTIONS-CLIENT  INSTALL-WIN-SOURCE  libservices  packaging  regex    sql-common  tests          vio
client       config.h.cmake   dbug            extra              KNOWN_BUGS.txt      man          plugin     scripts  storage     unittest       win
cmake        configure.cmake  debian          include            libmysql            mysql-test   randgen    sql      strings     util           zlib
[root@localhost mariadb-5.5.44]#


cmake编译

# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mariadb -DMYSQL_DATADIR=/mydata/data  -DSYSCONFDIR=/etc -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DWITH_ZLIB=system -DWITH_LIBWRAP=0 -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_SSL=system

编译报错,中止:

-- Looking for include file netdb.h - found
-- Looking for include file security/pam_appl.h
-- Looking for include file security/pam_appl.h - not found.
-- Looking for strndup
-- Looking for strndup - found
-- Looking for event.h
-- Looking for event.h - not found
-- Configuring incomplete, errors occurred!
# make 
# make install



[root@localhost mysql]# scripts/mysql_install_db --user=mysql --datadir=/usr/local/mysql/data/mysql/
Installing MariaDB/MySQL system tables in '/usr/local/mysql/data/mysql/' ...
170531  9:01:16 [Note] ./bin/mysqld (mysqld 5.5.44-MariaDB) starting as process 58960 ...
OK
Filling help tables...
170531  9:01:16 [Note] ./bin/mysqld (mysqld 5.5.44-MariaDB) starting as process 58970 ...
OK

To start mysqld at boot time you have to copy
support-files/mysql.server to the right place for your system

PLEASE REMEMBER TO SET A PASSWORD FOR THE MariaDB root USER !
To do so, start the server, then issue the following commands:

'./bin/mysqladmin' -u root password 'new-password'
'./bin/mysqladmin' -u root -h localhost password 'new-password'

Alternatively you can run:
'./bin/mysql_secure_installation'

which will also give you the option of removing the test
databases and anonymous user created by default.  This is
strongly recommended for production servers.

See the MariaDB Knowledgebase at http://mariadb.com/kb or the
MySQL manual for more instructions.

You can start the MariaDB daemon with:
cd '.' ; ./bin/mysqld_safe --datadir='/usr/local/mysql/data/mysql/'

You can test the MariaDB daemon with mysql-test-run.pl
cd './mysql-test' ; perl mysql-test-run.pl

Please report any problems at http://mariadb.org/jira

The latest information about MariaDB is available at http://mariadb.org/.
You can find additional information about the MySQL part at:
http://dev.mysql.com
Support MariaDB development by buying support/new features from MariaDB
Corporation Ab. You can contact us about this at [email protected].
Alternatively consider joining our community based development effort:
http://mariadb.com/kb/en/contributing-to-the-mariadb-project/

[root@localhost mysql]# ls /usr/local/mysql/data/mysql/
aria_log.00000001  aria_log_control  mysql  performance_schema  test
[root@localhost mysql]# cp support-files/my-large.cnf /etc/mysql/my.cnf
cp: cannot create regular file `/etc/mysql/my.cnf': No such file or directory
[root@localhost mysql]# mkdir /etc/mysql
[root@localhost mysql]# cp support-files/my-large.cnf /etc/mysql/my.cnf
[root@localhost mysql]# vim /etc/mysql/my.cnf
[root@localhost mysql]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld
[root@localhost mysql]# chmod +x /etc/rc.d/init.d/mysqld
[root@localhost mysql]# chkconfig --add mysqld
[root@localhost mysql]# service mysqld start
Starting MySQL.. ERROR! 
[root@localhost mysql]# ss -tnlp
State       Recv-Q Send-Q                                             Local Address:Port                                               Peer Address:Port 
LISTEN      0      128                                                           :::22                                                           :::*      users:(("sshd",1972,4))
LISTEN      0      128                                                            *:22                                                            *:*      users:(("sshd",1972,3))
LISTEN      0      128                                                    127.0.0.1:631                                                           *:*      users:(("cupsd",1857,7))
LISTEN      0      128                                                          ::1:631                                                          :::*      users:(("cupsd",1857,6))
LISTEN      0      100                                                          ::1:25                                                           :::*      users:(("master",2131,13))
LISTEN      0      100                                                    127.0.0.1:25                                                            *:*      users:(("master",2131,12))
LISTEN      0      1                                               ::ffff:127.0.0.1:8005                                                         :::*      users:(("java",19771,52))
LISTEN      0      50                                                            :::8009                                                         :::*      users:(("java",19771,50))
LISTEN      0      100                                                           :::8080                                                         :::*      users:(("java",19771,41))
[root@localhost mysql]# catalina.sh stop
Using CATALINA_BASE:   /usr/local/tomcat
Using CATALINA_HOME:   /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME:        /usr/java/latest
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar
[root@localhost mysql]# ss -tnlp
State       Recv-Q Send-Q                                             Local Address:Port                                               Peer Address:Port 
LISTEN      0      128                                                           :::22                                                           :::*      users:(("sshd",1972,4))
LISTEN      0      128                                                            *:22                                                            *:*      users:(("sshd",1972,3))
LISTEN      0      128                                                    127.0.0.1:631                                                           *:*      users:(("cupsd",1857,7))
LISTEN      0      128                                                          ::1:631                                                          :::*      users:(("cupsd",1857,6))
LISTEN      0      100                                                          ::1:25                                                           :::*      users:(("master",2131,13))
LISTEN      0      100                                                    127.0.0.1:25                                                            *:*      users:(("master",2131,12))
[root@localhost mysql]# 
[root@localhost mysql]# 
[root@localhost mysql]# /usr/local/mysql/bin/mysql_secure_installation 
/usr/local/mysql/bin/mysql_secure_installation: line 379: find_mysql_client: command not found

NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MariaDB
      SERVERS IN PRODUCTION USE!  PLEASE READ EACH STEP CAREFULLY!

In order to log into MariaDB to secure it, we'll need the current
password for the root user.  If you've just installed MariaDB, and
you haven't set the root password yet, the password will be blank,
so you should just press enter here.

Enter current password for root (enter for none): 
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
Enter current password for root (enter for none): 
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
Enter current password for root (enter for none): 
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
Enter current password for root (enter for none): 
Aborting!

Cleaning up...
[root@localhost mysql]# 
[root@localhost mysql]# 
[root@localhost mysql]# vim /etc/mysql/my.cnf

socket          = /tmp/mysql.sock

# Here follows entries for some specific programs

# The MariaDB server
[mysqld]
port            = 3306
socket          = /tmp/mysql.sock
skip-external-locking
key_buffer_size = 256M
max_allowed_packet = 1M
table_open_cache = 256
sort_buffer_size = 1M
read_buffer_size = 1M
read_rnd_buffer_size = 4M
myisam_sort_buffer_size = 64M
thread_cache_size = 8
query_cache_size= 16M
# Try number of CPU's*2 for thread_concurrency
thread_concurrency = 8
datadir=/usr/local/mysql/data/mysql
innodb_file_per_table = ON
skip_name_resole = ON


报错:event.h not found

[root@localhost mysql]# service mysqld start
Starting MySQL.. SUCCESS! 
[root@localhost mysql]# ss -tnlp
State      Recv-Q Send-Q                                             Local Address:Port                                               Peer Address:Port 
LISTEN     0      128                                                           :::22                                                           :::*      users:(("sshd",1972,4))
LISTEN     0      128                                                            *:22                                                            *:*      users:(("sshd",1972,3))
LISTEN     0      128                                                    127.0.0.1:631                                                           *:*      users:(("cupsd",1857,7))
LISTEN     0      128                                                          ::1:631                                                          :::*      users:(("cupsd",1857,6))
LISTEN     0      100                                                          ::1:25                                                           :::*      users:(("master",2131,13))
LISTEN     0      100                                                    127.0.0.1:25                                                            *:*      users:(("master",2131,12))
LISTEN     0      50                                                             *:3306                                                          *:*      users:(("mysqld",76025,15))
[root@localhost mysql]# ls log/




通过二进制格式安装Mariadb


一、准备数据库目录

mkdir /mydata/data


二、配置mariadb

[root@localhost ~]# tar xf mariadb-5.5.44-linux-x86_64.tar.gz -C /usr/local/
[root@localhost ~]# ll /usr/local/
total 72
drwxr-xr-x.  9 root root 4096 May 29 05:44 apache-tomcat-6.0.53
drwxr-xr-x.  2 root root 4096 May 31 08:33 bin
drwxr-xr-x.  3 root root 4096 May 31 07:50 doc
drwxr-xr-x.  2 root root 4096 Mar 26 16:01 etc
drwxr-xr-x.  2 root root 4096 Jun 28  2011 games
drwxr-xr-x.  2 root root 4096 Mar 26 12:14 gcc
drwxr-xr-x.  3 root root 4096 Mar 26 10:34 include
drwxr-xr-x.  2 root root 4096 Mar 26 10:34 info
drwxr-xr-x.  2 root root 4096 May 31 08:33 lib
drwxr-xr-x.  2 root root 4096 Jun 28  2011 lib64
drwxr-xr-x.  2 root root 4096 Jun 28  2011 libexec
drwxr-xr-x.  4 root root 4096 May 31 07:50 man
drwxr-xr-x. 12 root root 4096 Jun  4 00:10 mariadb-5.5.44-linux-x86_64
drwxr-xr-x.  6 root root 4096 Mar 26 17:52 python27
drwxr-xr-x.  2 root root 4096 Jun 28  2011 sbin
drwxr-xr-x. 10 root root 4096 May 31 08:33 share
drwxr-xr-x.  2 root root 4096 Jun 28  2011 src
lrwxrwxrwx.  1 root root   20 May 29 05:12 tomcat -> apache-tomcat-6.0.53
drwxr-xr-x.  3 root root 4096 May 29 09:08 tree-1.7.0
[root@localhost ~]# cd /usr/local/
[root@localhost local]# ln -sv mariadb-5.5.44-linux-x86_64 mysql
`mysql' -> `mariadb-5.5.44-linux-x86_64'
[root@localhost local]# cd mysql/
[root@localhost mysql]# ll
total 220
drwxr-xr-x.  2 root   root     4096 Jun  4 00:10 bin
-rw-r--r--.  1 cxiong cxiong  17987 Jun  9  2015 COPYING
-rw-r--r--.  1 cxiong cxiong  26545 Jun  9  2015 COPYING.LESSER
drwxr-xr-x.  3 root   root     4096 Jun  4 00:10 data
-rw-r--r--.  1 cxiong cxiong   8245 Jun  9  2015 EXCEPTIONS-CLIENT
drwxr-xr-x.  3 root   root     4096 Jun  4 00:10 include
-rw-r--r--.  1 cxiong cxiong   8694 Jun  9  2015 INSTALL-BINARY
drwxr-xr-x.  3 root   root     4096 Jun  4 00:10 lib
drwxr-xr-x.  4 root   root     4096 Jun  4 00:10 man
drwxr-xr-x. 11 root   root     4096 Jun  4 00:10 mysql-test
-rw-r--r--.  1 cxiong cxiong 108813 Jun  9  2015 README
drwxr-xr-x.  2 root   root     4096 Jun  4 00:10 scripts
drwxr-xr-x. 27 root   root     4096 Jun  4 00:10 share
drwxr-xr-x.  4 root   root     4096 Jun  4 00:10 sql-bench
drwxr-xr-x.  3 root   root     4096 Jun  4 00:10 support-files
[root@localhost mysql]# chown -R root:mysql ./*
[root@localhost mysql]# ll
total 220
drwxr-xr-x.  2 root mysql   4096 Jun  4 00:10 bin
-rw-r--r--.  1 root mysql  17987 Jun  9  2015 COPYING
-rw-r--r--.  1 root mysql  26545 Jun  9  2015 COPYING.LESSER
drwxr-xr-x.  3 root mysql   4096 Jun  4 00:10 data
-rw-r--r--.  1 root mysql   8245 Jun  9  2015 EXCEPTIONS-CLIENT
drwxr-xr-x.  3 root mysql   4096 Jun  4 00:10 include
-rw-r--r--.  1 root mysql   8694 Jun  9  2015 INSTALL-BINARY
drwxr-xr-x.  3 root mysql   4096 Jun  4 00:10 lib
drwxr-xr-x.  4 root mysql   4096 Jun  4 00:10 man
drwxr-xr-x. 11 root mysql   4096 Jun  4 00:10 mysql-test
-rw-r--r--.  1 root mysql 108813 Jun  9  2015 README
drwxr-xr-x.  2 root mysql   4096 Jun  4 00:10 scripts
drwxr-xr-x. 27 root mysql   4096 Jun  4 00:10 share
drwxr-xr-x.  4 root mysql   4096 Jun  4 00:10 sql-bench
drwxr-xr-x.  3 root mysql   4096 Jun  4 00:10 support-files
[root@localhost mysql]# ls /
bin  boot  dev  etc  hello.py  home  lib  lib64  lost+found  media  mnt  opt  proc  root  sbin  selinux  srv  swconfig  sys  tmp  usr  var
[root@localhost mysql]# mkdir /mydata/data
mkdir: cannot create directory `/mydata/data': No such file or directory
[root@localhost mysql]# mkdir /mydata
[root@localhost mysql]# cd /mydata
[root@localhost mydata]# mkdir data
[root@localhost mydata]# chown mysql.mysql data
[root@localhost mydata]# ll
total 4
drwxr-xr-x. 2 mysql mysql 4096 Jun  4 00:14 data
[root@localhost mydata]# cd /usr/local/mysql/
[root@localhost mysql]# ls scripts/
mysql_install_db
[root@localhost mysql]# scripts/mysql_install_db --help
Usage: scripts/mysql_install_db [OPTIONS]
  --basedir=path       The path to the MariaDB installation directory.
  --builddir=path      If using --srcdir with out-of-directory builds, you
                       will need to set this to the location of the build
                       directory where built files reside.
  --cross-bootstrap    For internal use.  Used when building the MariaDB system
                       tables on a different host than the target.
  --datadir=path       The path to the MariaDB data directory.
  --defaults-extra-file=name
                       Read this file after the global files are read.
  --defaults-file=name Only read default options from the given file name.
  --force              Causes mysql_install_db to run even if DNS does not
                       work.  In that case, grant table entries that
                       normally use hostnames will use IP addresses.
  --help               Display this help and exit.                     
  --ldata=path         The path to the MariaDB data directory. Same as
                       --datadir.
  --no-defaults        Don't read default options from any option file.
  --defaults-file=path Read only this configuration file.
  --rpm                For internal use.  This option is used by RPM files
                       during the MariaDB installation process.
  --skip-name-resolve  Use IP addresses rather than hostnames when creating
                       grant table entries.  This option can be useful if
                       your DNS does not work.
  --srcdir=path        The path to the MariaDB source directory.  This option
                       uses the compiled binaries and support files within the
                       source tree, useful for if you don't want to install
                       MariaDB yet and just want to create the system tables.
  --user=user_name     The login username to use for running mysqld.  Files
                       and directories created by mysqld will be owned by this
                       user.  You must be root to use this option.  By default
                       mysqld runs using your current login name and files and
                       directories that it creates will be owned by you.

All other options are passed to the mysqld program

[root@localhost mysql]# scripts/mysql_install_db --user=mysql --datadir=/mydata/data/
Installing MariaDB/MySQL system tables in '/mydata/data/' ...
170604  0:16:38 [Note] ./bin/mysqld (mysqld 5.5.44-MariaDB) starting as process 69141 ...
OK
Filling help tables...
170604  0:16:38 [Note] ./bin/mysqld (mysqld 5.5.44-MariaDB) starting as process 69150 ...
OK

To start mysqld at boot time you have to copy
support-files/mysql.server to the right place for your system

PLEASE REMEMBER TO SET A PASSWORD FOR THE MariaDB root USER !
To do so, start the server, then issue the following commands:

'./bin/mysqladmin' -u root password 'new-password'
'./bin/mysqladmin' -u root -h localhost password 'new-password'

Alternatively you can run:
'./bin/mysql_secure_installation'

which will also give you the option of removing the test
databases and anonymous user created by default.  This is
strongly recommended for production servers.

See the MariaDB Knowledgebase at http://mariadb.com/kb or the
MySQL manual for more instructions.

You can start the MariaDB daemon with:
cd '.' ; ./bin/mysqld_safe --datadir='/mydata/data/'

You can test the MariaDB daemon with mysql-test-run.pl
cd './mysql-test' ; perl mysql-test-run.pl

Please report any problems at http://mariadb.org/jira

The latest information about MariaDB is available at http://mariadb.org/.
You can find additional information about the MySQL part at:
http://dev.mysql.com
Support MariaDB development by buying support/new features from MariaDB
Corporation Ab. You can contact us about this at [email protected].
Alternatively consider joining our community based development effort:
http://mariadb.com/kb/en/contributing-to-the-mariadb-project/

[root@localhost mysql]# ls /mydata/data/
aria_log.00000001  aria_log_control  mysql  performance_schema  test
[root@localhost mysql]# ls support-files/
binary-configure  my-huge.cnf             my-large.cnf   my-small.cnf         mysql-log-rotate  SELinux
magic             my-innodb-heavy-4G.cnf  my-medium.cnf  mysqld_multi.server  mysql.server
[root@localhost mysql]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld
cp: overwrite `/etc/rc.d/init.d/mysqld'? y
[root@localhost mysql]# chkconfig --add mysqld
[root@localhost mysql]# chkconfig --list mysqld
mysqld         0:off1:off2:on3:on4:on5:on6:off


三、准备配置文件

配置文件查找路径

/etc/my.cnf   -->  /etc/mysql/my.cnf  -->defautl-extra-file=/path/to/conf_file  -->  ~/.mycnf

[root@localhost mysql]# mkdir /etc/mysql
[root@localhost mysql]# pwd
/usr/local/mysql
[root@localhost mysql]# ls support-files/
binary-configure  my-huge.cnf             my-large.cnf   my-small.cnf         mysql-log-rotate  SELinux
magic             my-innodb-heavy-4G.cnf  my-medium.cnf  mysqld_multi.server  mysql.server
[root@localhost mysql]# cp support-files/my-large.cnf /etc/mysql/my.cnf
[root@localhost mysql]# vim /etc/my
my.cnf  mysql/  
[root@localhost mysql]# vim /etc/mysql/my.cnf

[mysqld]
port  = 3306
socket  = /tmp/mysql.sock
skip-external-locking
key_buffer_size = 256M
max_allowed_packet = 1M
table_open_cache = 256
sort_buffer_size = 1M
read_buffer_size = 1M
read_rnd_buffer_size = 4M
myisam_sort_buffer_size = 64M
thread_cache_size = 8
query_cache_size= 16M
# Try number of CPU's*2 for thread_concurrency
thread_concurrency = 8
datadir = /mydata/data
innodb_file_per_table = on
character_set_server = utf8
#skip_
log-error = /usr/local/mysql/log/error.log
general-log-file = /usr/local/mysql/log/mysql.log

 
[root@localhost mysql]# service mysqld start
Starting MySQL.. SUCCESS! 
[root@localhost mysql]# ss -tnlp
State      Recv-Q Send-Q                                             Local Address:Port                                               Peer Address:Port 
LISTEN     0      128                                                           :::22                                                           :::*      users:(("sshd",1972,4))
LISTEN     0      128                                                            *:22                                                            *:*      users:(("sshd",1972,3))
LISTEN     0      128                                                    127.0.0.1:631                                                           *:*      users:(("cupsd",1857,7))
LISTEN     0      128                                                          ::1:631                                                          :::*      users:(("cupsd",1857,6))
LISTEN     0      100                                                          ::1:25                                                           :::*      users:(("master",2131,13))
LISTEN     0      100                                                    127.0.0.1:25                                                            *:*      users:(("master",2131,12))
LISTEN     0      50                                                             *:3306                                                          *:*      users:(("mysqld",76025,15))
[root@localhost mysql]# ls log/






mysql基础:


MariaDB程序的组成:

C:Client

mysql:CLI交互式客户端程序;

mysqldump:备份工具;

mysqladmin:管理工具;

mysqlbinlog:

...

S:Server

mysqld

mysqld_safe:建议运行服务端程序;

mysqld_multi:多实例;


三类套接字地址:

IPv4, 3306/tcp

Unix Sock:/var/lib/mysql/mysql.sock, /tmp/mysql.sock

C <--> S: localhost, 127.0.0.1

命令行交互式客户端程序:mysql

mysql 

mysql [OPTIONS] [database]

常用选项:

-uUSERNAME:用户名,默认为root;

-hHOST:远程主机(即mysql服务器)地址,默认为localhost; 

-p[PASSWORD]:USERNAME所表示的用户的密码; 默认为空;



注意:mysql的用户账号由两部分组成:'USERNAME'@'HOST'; 其中HOST用于限制此用户可通过哪些远程主机连接当前的mysql服务;

HOST的表示方式,支持使用通配符:

%:匹配任意长度的任意字符;

172.16.%.%,  172.16.0.0/16

_:匹配任意单个字符;

-Ddb_name:连接到服务器端之后,设定其处指明的数据库为默认数据库;

-e 'SQL COMMAND;':连接至服务器并让其执行此命令后直接返回;

[root@localhost ~]# /usr/local/mysql/bin/mysql  
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 2
Server version: 5.5.44-MariaDB-log MariaDB Server

Copyright (c) 2000, 2015, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> 
MariaDB [(none)]> use mysql
Database changed
MariaDB [mysql]> select User,Host,Password from user;
+------+-----------+----------+
| User | Host      | Password |
+------+-----------+----------+
| root | localhost |          |
| root | 127.0.0.1 |          |
| root | ::1       |          |
|      | localhost |          |
+------+-----------+----------+
4 rows in set (0.01 sec)

MariaDB [mysql]> 

[root@localhost ~]# /usr/local/mysql/bin/mysql_secure_installation  --- mysql安全初始化
/usr/local/mysql/bin/mysql_secure_installation: line 379: find_mysql_client: command not found

NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MariaDB
      SERVERS IN PRODUCTION USE!  PLEASE READ EACH STEP CAREFULLY!

In order to log into MariaDB to secure it, we'll need the current
password for the root user.  If you've just installed MariaDB, and
you haven't set the root password yet, the password will be blank,
so you should just press enter here.

Enter current password for root (enter for none): 
OK, successfully used password, moving on...

Setting the root password ensures that nobody can log into the MariaDB
root user without the proper authorisation.

Set root password? [Y/n] y
New password: 
Re-enter new password: 
Password updated successfully!
Reloading privilege tables..
 ... Success!


By default, a MariaDB installation has an anonymous user, allowing anyone
to log into MariaDB without having to have a user account created for
them.  This is intended only for testing, and to make the installation
go a bit smoother.  You should remove them before moving into a
production environment.

Remove anonymous users? [Y/n] y     --- 删除匿名用户
 ... Success!

Normally, root should only be allowed to connect from 'localhost'.  This
ensures that someone cannot guess at the root password from the network.

Disallow root login remotely? [Y/n] n   --- 远程登陆,建议删除
 ... skipping.

By default, MariaDB comes with a database named 'test' that anyone can
access.  This is also intended only for testing, and should be removed
before moving into a production environment.

Remove test database and access to it? [Y/n] 
 - Dropping test database...
 ... Success!
 - Removing privileges on test database...
 ... Success!

Reloading the privilege tables will ensure that all changes made so far
will take effect immediately.

Reload privilege tables now? [Y/n] y
 ... Success!

Cleaning up...

All done!  If you've completed all of the above steps, your MariaDB
installation should now be secure.

Thanks for using MariaDB!
[root@localhost ~]# /usr/local/mysql/bin/mysql
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)
[root@localhost ~]# /usr/local/mysql/bin/mysql -u root -p
Enter password: 
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 11
Server version: 5.5.44-MariaDB-log MariaDB Server

Copyright (c) 2000, 2015, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> use mysql
Database changed
MariaDB [mysql]> select User,Host,Password from user;
+------+-----------+-------------------------------------------+
| User | Host      | Password                                  |
+------+-----------+-------------------------------------------+
| root | localhost | *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B |
| root | 127.0.0.1 | *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B |
| root | ::1       | *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B |
+------+-----------+-------------------------------------------+
3 rows in set (0.00 sec)

MariaDB [mysql]>




mysql:

命令:

客户端命令:本地执行

mysql> help

\u db_name:设定哪个库为默认数据库

\q:退出;

\d CHAR:设定新的语句结束符;

\g:语句结束标记;

\G:语句结束标记,结果竖排方式显式;

\s:

MariaDB [mysql]> help

General information about MariaDB can be found at
http://mariadb.org

List of all MySQL commands:
Note that all text commands must be first on line and end with ';'
?         (\?) Synonym for `help'.
clear     (\c) Clear the current input statement.
connect   (\r) Reconnect to the server. Optional arguments are db and host.
delimiter (\d) Set statement delimiter.
edit      (\e) Edit command with $EDITOR.
ego       (\G) Send command to mysql server, display result vertically.
exit      (\q) Exit mysql. Same as quit.
go        (\g) Send command to mysql server.
help      (\h) Display this help.
nopager   (\n) Disable pager, print to stdout.
notee     (\t) Don't write into outfile.
pager     (\P) Set PAGER [to_pager]. Print the query results via PAGER.
print     (\p) Print current command.
prompt    (\R) Change your mysql prompt.
quit      (\q) Quit mysql.
rehash    (\#) Rebuild completion hash.
source    (\.) Execute an SQL script file. Takes a file name as an argument.
status    (\s) Get status information from the server.
system    (\!) Execute a system shell command.
tee       (\T) Set outfile [to_outfile]. Append everything into given outfile.
use       (\u) Use another database. Takes database name as argument.
charset   (\C) Switch to another charset. Might be needed for processing binlog with multi-byte charsets.
warnings  (\W) Show warnings after every statement.
nowarning (\w) Don't show warnings after every statement.

For server side help, type 'help contents'



服务端命令:通过mysql连接发往服务器执行并取回结果;

DDL, DML, DCL 

注意:每个语句必须有语句结束符,默认为分号(;)

MariaDB [mysql]> select version()
    -> 
    -> ;
+--------------------+
| version()          |
+--------------------+
| 5.5.44-MariaDB-log |
+--------------------+
1 row in set (0.00 sec)

MariaDB [mysql]>

关系型数据库常见组件

    数据库:database

    表:table

        行:row

        列:column

    索引:index

    视图:view

    用户:user

    权限:privilege


数据库开发,专业dba使用:

    存储过程:procedure,无返回值,call

    存储函数:function,有返回值,select

    触发器:trigger,显示改变的行结果

    事件调度器:event scheduler



服务器端命令:

DDL:数据定义语言,主要用于管理数据库组件,例如表、索引、视图、用户、存储过程

CREATE、ALTER、DROP

DML:数据操纵语言,主要用管理表中的数据,实现数据的增、删、改、查;

INSERT, DELETE, UPDATE, SELECT

获取命令帮助:

mysql> help  KEYWORD

数据库管理:

创建:

CREATE  {DATABASE | SCHEMA}  [IF NOT EXISTS]  db_name;

[DEFAULT]  CHARACTER SET [=] charset_name

[DEFAULT]  COLLATE [=] collation_name

查看支持的所有字符集:SHOW CHARACTER SET 

查看支持的所有排序规则:SHOW  COLLATION

修改:

ALTER {DATABASE | SCHEMA}  [db_name]

[DEFAULT]  CHARACTER SET [=] charset_name   --- 可以数据库设置字符集

[DEFAULT]  COLLATE [=] collation_name        --- 可以数据库设置排序规则

删除:

DROP {DATABASE | SCHEMA} [IF EXISTS] db_name

查看:

SHOW DATABASES LIKE  ’‘;


MariaDB [mysql]> show character set;   ----  显示所有字符集
+----------+-----------------------------+---------------------+--------+
| Charset  | Description                 | Default collation   | Maxlen |
+----------+-----------------------------+---------------------+--------+
| big5     | Big5 Traditional Chinese    | big5_chinese_ci     |      2 |
| dec8     | DEC West European           | dec8_swedish_ci     |      1 |
| cp850    | DOS West European           | cp850_general_ci    |      1 |
| hp8      | HP West European            | hp8_english_ci      |      1 |
| koi8r    | KOI8-R Relcom Russian       | koi8r_general_ci    |      1 |
| latin1   | cp1252 West European        | latin1_swedish_ci   |      1 |
| latin2   | ISO 8859-2 Central European | latin2_general_ci   |      1 |
| swe7     | 7bit Swedish                | swe7_swedish_ci     |      1 |
| ascii    | US ASCII                    | ascii_general_ci    |      1 |
| ujis     | EUC-JP Japanese             | ujis_japanese_ci    |      3 |
| sjis     | Shift-JIS Japanese          | sjis_japanese_ci    |      2 |
| hebrew   | ISO 8859-8 Hebrew           | hebrew_general_ci   |      1 |
| tis620   | TIS620 Thai                 | tis620_thai_ci      |      1 |
| euckr    | EUC-KR Korean               | euckr_korean_ci     |      2 |
| koi8u    | KOI8-U Ukrainian            | koi8u_general_ci    |      1 |
| gb2312   | GB2312 Simplified Chinese   | gb2312_chinese_ci   |      2 |
| greek    | ISO 8859-7 Greek            | greek_general_ci    |      1 |
| cp1250   | Windows Central European    | cp1250_general_ci   |      1 |
| gbk      | GBK Simplified Chinese      | gbk_chinese_ci      |      2 |
| latin5   | ISO 8859-9 Turkish          | latin5_turkish_ci   |      1 |
| armscii8 | ARMSCII-8 Armenian          | armscii8_general_ci |      1 |
| utf8     | UTF-8 Unicode               | utf8_general_ci     |      3 |
| ucs2     | UCS-2 Unicode               | ucs2_general_ci     |      2 |
| cp866    | DOS Russian                 | cp866_general_ci    |      1 |
| keybcs2  | DOS Kamenicky Czech-Slovak  | keybcs2_general_ci  |      1 |
| macce    | Mac Central European        | macce_general_ci    |      1 |
| macroman | Mac West European           | macroman_general_ci |      1 |
| cp852    | DOS Central European        | cp852_general_ci    |      1 |
| latin7   | ISO 8859-13 Baltic          | latin7_general_ci   |      1 |
| utf8mb4  | UTF-8 Unicode               | utf8mb4_general_ci  |      4 |
| cp1251   | Windows Cyrillic            | cp1251_general_ci   |      1 |
| utf16    | UTF-16 Unicode              | utf16_general_ci    |      4 |
| cp1256   | Windows Arabic              | cp1256_general_ci   |      1 |
| cp1257   | Windows Baltic              | cp1257_general_ci   |      1 |
| utf32    | UTF-32 Unicode              | utf32_general_ci    |      4 |
| binary   | Binary pseudo charset       | binary              |      1 |
| geostd8  | GEOSTD8 Georgian            | geostd8_general_ci  |      1 |
| cp932    | SJIS for Windows Japanese   | cp932_japanese_ci   |      2 |
| eucjpms  | UJIS for Windows Japanese   | eucjpms_japanese_ci |      3 |
+----------+-----------------------------+---------------------+--------+
39 rows in set (0.00 sec)

MariaDB [mysql]> 
MariaDB [mysql]> show collation;   --- 查看排序规则
+--------------------------+----------+-----+---------+----------+---------+
| Collation                | Charset  | Id  | Default | Compiled | Sortlen |
+--------------------------+----------+-----+---------+----------+---------+
| big5_chinese_ci          | big5     |   1 | Yes     | Yes      |       1 |
| big5_bin                 | big5     |  84 |         | Yes      |       1 |
| dec8_swedish_ci          | dec8     |   3 | Yes     | Yes      |       1 |
| dec8_bin                 | dec8     |  69 |         | Yes      |       1 |
| cp850_general_ci         | cp850    |   4 | Yes     | Yes      |       1 |
| cp850_bin                | cp850    |  80 |         | Yes      |       1 |
| hp8_english_ci           | hp8      |   6 | Yes     | Yes      |       1 |
| hp8_bin                  | hp8      |  72 |         | Yes      |       1 |
| koi8r_general_ci         | koi8r    |   7 | Yes     | Yes      |       1 |
| koi8r_bin                | koi8r    |  74 |         | Yes      |       1 |
| latin1_german1_ci        | latin1   |   5 |         | Yes      |       1 |
| latin1_swedish_ci        | latin1   |   8 | Yes     | Yes      |       1 |
| latin1_danish_ci         | latin1   |  15 |         | Yes      |       1 |
| latin1_german2_ci        | latin1   |  31 |         | Yes      |       2 |
| latin1_bin               | latin1   |  47 |         | Yes      |       1 |
| latin1_general_ci        | latin1   |  48 |         | Yes      |       1 |
| latin1_general_cs        | latin1   |  49 |         | Yes      |       1 |
| latin1_spanish_ci        | latin1   |  94 |         | Yes      |       1 |
| latin2_czech_cs          | latin2   |   2 |         | Yes      |       4 |
| latin2_general_ci        | latin2   |   9 | Yes     | Yes      |       1 |
| latin2_hungarian_ci      | latin2   |  21 |         | Yes      |       1 |
| latin2_croatian_ci       | latin2   |  27 |         | Yes      |       1 |
| latin2_bin               | latin2   |  77 |         | Yes      |       1 |
| swe7_swedish_ci          | swe7     |  10 | Yes     | Yes      |       1 |
| swe7_bin                 | swe7     |  82 |         | Yes      |       1 |
| ascii_general_ci         | ascii    |  11 | Yes     | Yes      |       1 |
| ascii_bin                | ascii    |  65 |         | Yes      |       1 |
| ujis_japanese_ci         | ujis     |  12 | Yes     | Yes      |       1 |
| ujis_bin                 | ujis     |  91 |         | Yes      |       1 |
| sjis_japanese_ci         | sjis     |  13 | Yes     | Yes      |       1 |
| sjis_bin                 | sjis     |  88 |         | Yes      |       1 |
| hebrew_general_ci        | hebrew   |  16 | Yes     | Yes      |       1 |
| hebrew_bin               | hebrew   |  71 |         | Yes      |       1 |
| tis620_thai_ci           | tis620   |  18 | Yes     | Yes      |       4 |
| tis620_bin               | tis620   |  89 |         | Yes      |       1 |
| euckr_korean_ci          | euckr    |  19 | Yes     | Yes      |       1 |
| euckr_bin                | euckr    |  85 |         | Yes      |       1 |
| koi8u_general_ci         | koi8u    |  22 | Yes     | Yes      |       1 |
| koi8u_bin                | koi8u    |  75 |         | Yes      |       1 |
| gb2312_chinese_ci        | gb2312   |  24 | Yes     | Yes      |       1 |
| gb2312_bin               | gb2312   |  86 |         | Yes      |       1 |
| greek_general_ci         | greek    |  25 | Yes     | Yes      |       1 |
| greek_bin                | greek    |  70 |         | Yes      |       1 |
| cp1250_general_ci        | cp1250   |  26 | Yes     | Yes      |       1 |
| cp1250_czech_cs          | cp1250   |  34 |         | Yes      |       2 |
| cp1250_croatian_ci       | cp1250   |  44 |         | Yes      |       1 |
| cp1250_bin               | cp1250   |  66 |         | Yes      |       1 |
| cp1250_polish_ci         | cp1250   |  99 |         | Yes      |       1 |
| gbk_chinese_ci           | gbk      |  28 | Yes     | Yes      |       1 |
| gbk_bin                  | gbk      |  87 |         | Yes      |       1 |
| latin5_turkish_ci        | latin5   |  30 | Yes     | Yes      |       1 |
| latin5_bin               | latin5   |  78 |         | Yes      |       1 |
| armscii8_general_ci      | armscii8 |  32 | Yes     | Yes      |       1 |
| armscii8_bin             | armscii8 |  64 |         | Yes      |       1 |
| utf8_general_ci          | utf8     |  33 | Yes     | Yes      |       1 |
| utf8_bin                 | utf8     |  83 |         | Yes      |       1 |
| utf8_unicode_ci          | utf8     | 192 |         | Yes      |       8 |
| utf8_icelandic_ci        | utf8     | 193 |         | Yes      |       8 |
| utf8_latvian_ci          | utf8     | 194 |         | Yes      |       8 |
| utf8_romanian_ci         | utf8     | 195 |         | Yes      |       8 |
| utf8_slovenian_ci        | utf8     | 196 |         | Yes      |       8 |
| utf8_polish_ci           | utf8     | 197 |         | Yes      |       8 |
| utf8_estonian_ci         | utf8     | 198 |         | Yes      |       8 |
| utf8_spanish_ci          | utf8     | 199 |         | Yes      |       8 |
| utf8_swedish_ci          | utf8     | 200 |         | Yes      |       8 |
| utf8_turkish_ci          | utf8     | 201 |         | Yes      |       8 |
| utf8_czech_ci            | utf8     | 202 |         | Yes      |       8 |
| utf8_danish_ci           | utf8     | 203 |         | Yes      |       8 |
| utf8_lithuanian_ci       | utf8     | 204 |         | Yes      |       8 |
| utf8_slovak_ci           | utf8     | 205 |         | Yes      |       8 |
| utf8_spanish2_ci         | utf8     | 206 |         | Yes      |       8 |
| utf8_roman_ci            | utf8     | 207 |         | Yes      |       8 |
| utf8_persian_ci          | utf8     | 208 |         | Yes      |       8 |
| utf8_esperanto_ci        | utf8     | 209 |         | Yes      |       8 |
| utf8_hungarian_ci        | utf8     | 210 |         | Yes      |       8 |
| utf8_sinhala_ci          | utf8     | 211 |         | Yes      |       8 |
| utf8_croatian_ci         | utf8     | 213 |         | Yes      |       8 |
| utf8_general_mysql500_ci | utf8     | 223 |         | Yes      |       1 |
| ucs2_general_ci          | ucs2     |  35 | Yes     | Yes      |       1 |
| ucs2_bin                 | ucs2     |  90 |         | Yes      |       1 |
| ucs2_unicode_ci          | ucs2     | 128 |         | Yes      |       8 |
| ucs2_icelandic_ci        | ucs2     | 129 |         | Yes      |       8 |
| ucs2_latvian_ci          | ucs2     | 130 |         | Yes      |       8 |
| ucs2_romanian_ci         | ucs2     | 131 |         | Yes      |       8 |
| ucs2_slovenian_ci        | ucs2     | 132 |         | Yes      |       8 |
| ucs2_polish_ci           | ucs2     | 133 |         | Yes      |       8 |
| ucs2_estonian_ci         | ucs2     | 134 |         | Yes      |       8 |
| ucs2_spanish_ci          | ucs2     | 135 |         | Yes      |       8 |
| ucs2_swedish_ci          | ucs2     | 136 |         | Yes      |       8 |
| ucs2_turkish_ci          | ucs2     | 137 |         | Yes      |       8 |
| ucs2_czech_ci            | ucs2     | 138 |         | Yes      |       8 |
| ucs2_danish_ci           | ucs2     | 139 |         | Yes      |       8 |
| ucs2_lithuanian_ci       | ucs2     | 140 |         | Yes      |       8 |
| ucs2_slovak_ci           | ucs2     | 141 |         | Yes      |       8 |
| ucs2_spanish2_ci         | ucs2     | 142 |         | Yes      |       8 |
| ucs2_roman_ci            | ucs2     | 143 |         | Yes      |       8 |
| ucs2_persian_ci          | ucs2     | 144 |         | Yes      |       8 |
| ucs2_esperanto_ci        | ucs2     | 145 |         | Yes      |       8 |
| ucs2_hungarian_ci        | ucs2     | 146 |         | Yes      |       8 |
| ucs2_sinhala_ci          | ucs2     | 147 |         | Yes      |       8 |
| ucs2_croatian_ci         | ucs2     | 149 |         | Yes      |       8 |
| ucs2_general_mysql500_ci | ucs2     | 159 |         | Yes      |       1 |
| cp866_general_ci         | cp866    |  36 | Yes     | Yes      |       1 |
| cp866_bin                | cp866    |  68 |         | Yes      |       1 |
| keybcs2_general_ci       | keybcs2  |  37 | Yes     | Yes      |       1 |
| keybcs2_bin              | keybcs2  |  73 |         | Yes      |       1 |
| macce_general_ci         | macce    |  38 | Yes     | Yes      |       1 |
| macce_bin                | macce    |  43 |         | Yes      |       1 |
| macroman_general_ci      | macroman |  39 | Yes     | Yes      |       1 |
| macroman_bin             | macroman |  53 |         | Yes      |       1 |
| cp852_general_ci         | cp852    |  40 | Yes     | Yes      |       1 |
| cp852_bin                | cp852    |  81 |         | Yes      |       1 |
| latin7_estonian_cs       | latin7   |  20 |         | Yes      |       1 |
| latin7_general_ci        | latin7   |  41 | Yes     | Yes      |       1 |
| latin7_general_cs        | latin7   |  42 |         | Yes      |       1 |
| latin7_bin               | latin7   |  79 |         | Yes      |       1 |
| utf8mb4_general_ci       | utf8mb4  |  45 | Yes     | Yes      |       1 |
| utf8mb4_bin              | utf8mb4  |  46 |         | Yes      |       1 |
| utf8mb4_unicode_ci       | utf8mb4  | 224 |         | Yes      |       8 |
| utf8mb4_icelandic_ci     | utf8mb4  | 225 |         | Yes      |       8 |
| utf8mb4_latvian_ci       | utf8mb4  | 226 |         | Yes      |       8 |
| utf8mb4_romanian_ci      | utf8mb4  | 227 |         | Yes      |       8 |
| utf8mb4_slovenian_ci     | utf8mb4  | 228 |         | Yes      |       8 |
| utf8mb4_polish_ci        | utf8mb4  | 229 |         | Yes      |       8 |
| utf8mb4_estonian_ci      | utf8mb4  | 230 |         | Yes      |       8 |
| utf8mb4_spanish_ci       | utf8mb4  | 231 |         | Yes      |       8 |
| utf8mb4_swedish_ci       | utf8mb4  | 232 |         | Yes      |       8 |
| utf8mb4_turkish_ci       | utf8mb4  | 233 |         | Yes      |       8 |
| utf8mb4_czech_ci         | utf8mb4  | 234 |         | Yes      |       8 |
| utf8mb4_danish_ci        | utf8mb4  | 235 |         | Yes      |       8 |
| utf8mb4_lithuanian_ci    | utf8mb4  | 236 |         | Yes      |       8 |
| utf8mb4_slovak_ci        | utf8mb4  | 237 |         | Yes      |       8 |
| utf8mb4_spanish2_ci      | utf8mb4  | 238 |         | Yes      |       8 |
| utf8mb4_roman_ci         | utf8mb4  | 239 |         | Yes      |       8 |
| utf8mb4_persian_ci       | utf8mb4  | 240 |         | Yes      |       8 |
| utf8mb4_esperanto_ci     | utf8mb4  | 241 |         | Yes      |       8 |
| utf8mb4_hungarian_ci     | utf8mb4  | 242 |         | Yes      |       8 |
| utf8mb4_sinhala_ci       | utf8mb4  | 243 |         | Yes      |       8 |
| utf8mb4_croatian_ci      | utf8mb4  | 245 |         | Yes      |       8 |
| cp1251_bulgarian_ci      | cp1251   |  14 |         | Yes      |       1 |
| cp1251_ukrainian_ci      | cp1251   |  23 |         | Yes      |       1 |
| cp1251_bin               | cp1251   |  50 |         | Yes      |       1 |
| cp1251_general_ci        | cp1251   |  51 | Yes     | Yes      |       1 |
| cp1251_general_cs        | cp1251   |  52 |         | Yes      |       1 |
| utf16_general_ci         | utf16    |  54 | Yes     | Yes      |       1 |
| utf16_bin                | utf16    |  55 |         | Yes      |       1 |
| utf16_unicode_ci         | utf16    | 101 |         | Yes      |       8 |
| utf16_icelandic_ci       | utf16    | 102 |         | Yes      |       8 |
| utf16_latvian_ci         | utf16    | 103 |         | Yes      |       8 |
| utf16_romanian_ci        | utf16    | 104 |         | Yes      |       8 |
| utf16_slovenian_ci       | utf16    | 105 |         | Yes      |       8 |
| utf16_polish_ci          | utf16    | 106 |         | Yes      |       8 |
| utf16_estonian_ci        | utf16    | 107 |         | Yes      |       8 |
| utf16_spanish_ci         | utf16    | 108 |         | Yes      |       8 |
| utf16_swedish_ci         | utf16    | 109 |         | Yes      |       8 |
| utf16_turkish_ci         | utf16    | 110 |         | Yes      |       8 |
| utf16_czech_ci           | utf16    | 111 |         | Yes      |       8 |
| utf16_danish_ci          | utf16    | 112 |         | Yes      |       8 |
| utf16_lithuanian_ci      | utf16    | 113 |         | Yes      |       8 |
| utf16_slovak_ci          | utf16    | 114 |         | Yes      |       8 |
| utf16_spanish2_ci        | utf16    | 115 |         | Yes      |       8 |
| utf16_roman_ci           | utf16    | 116 |         | Yes      |       8 |
| utf16_persian_ci         | utf16    | 117 |         | Yes      |       8 |
| utf16_esperanto_ci       | utf16    | 118 |         | Yes      |       8 |
| utf16_hungarian_ci       | utf16    | 119 |         | Yes      |       8 |
| utf16_sinhala_ci         | utf16    | 120 |         | Yes      |       8 |
| utf16_croatian_ci        | utf16    | 215 |         | Yes      |       8 |
| cp1256_general_ci        | cp1256   |  57 | Yes     | Yes      |       1 |
| cp1256_bin               | cp1256   |  67 |         | Yes      |       1 |
| cp1257_lithuanian_ci     | cp1257   |  29 |         | Yes      |       1 |
| cp1257_bin               | cp1257   |  58 |         | Yes      |       1 |
| cp1257_general_ci        | cp1257   |  59 | Yes     | Yes      |       1 |
| utf32_general_ci         | utf32    |  60 | Yes     | Yes      |       1 |
| utf32_bin                | utf32    |  61 |         | Yes      |       1 |
| utf32_unicode_ci         | utf32    | 160 |         | Yes      |       8 |
| utf32_icelandic_ci       | utf32    | 161 |         | Yes      |       8 |
| utf32_latvian_ci         | utf32    | 162 |         | Yes      |       8 |
| utf32_romanian_ci        | utf32    | 163 |         | Yes      |       8 |
| utf32_slovenian_ci       | utf32    | 164 |         | Yes      |       8 |
| utf32_polish_ci          | utf32    | 165 |         | Yes      |       8 |
| utf32_estonian_ci        | utf32    | 166 |         | Yes      |       8 |
| utf32_spanish_ci         | utf32    | 167 |         | Yes      |       8 |
| utf32_swedish_ci         | utf32    | 168 |         | Yes      |       8 |
| utf32_turkish_ci         | utf32    | 169 |         | Yes      |       8 |
| utf32_czech_ci           | utf32    | 170 |         | Yes      |       8 |
| utf32_danish_ci          | utf32    | 171 |         | Yes      |       8 |
| utf32_lithuanian_ci      | utf32    | 172 |         | Yes      |       8 |
| utf32_slovak_ci          | utf32    | 173 |         | Yes      |       8 |
| utf32_spanish2_ci        | utf32    | 174 |         | Yes      |       8 |
| utf32_roman_ci           | utf32    | 175 |         | Yes      |       8 |
| utf32_persian_ci         | utf32    | 176 |         | Yes      |       8 |
| utf32_esperanto_ci       | utf32    | 177 |         | Yes      |       8 |
| utf32_hungarian_ci       | utf32    | 178 |         | Yes      |       8 |
| utf32_sinhala_ci         | utf32    | 179 |         | Yes      |       8 |
| utf32_croatian_ci        | utf32    | 214 |         | Yes      |       8 |
| binary                   | binary   |  63 | Yes     | Yes      |       1 |
| geostd8_general_ci       | geostd8  |  92 | Yes     | Yes      |       1 |
| geostd8_bin              | geostd8  |  93 |         | Yes      |       1 |
| cp932_japanese_ci        | cp932    |  95 | Yes     | Yes      |       1 |
| cp932_bin                | cp932    |  96 |         | Yes      |       1 |
| eucjpms_japanese_ci      | eucjpms  |  97 | Yes     | Yes      |       1 |
| eucjpms_bin              | eucjpms  |  98 |         | Yes      |       1 |
+--------------------------+----------+-----+---------+----------+---------+
202 rows in set (0.00 sec)

MariaDB [mysql]> show engines;   ---- 支持的引擎
+--------------------+---------+----------------------------------------------------------------------------+--------------+------+------------+
| Engine             | Support | Comment                                                                    | Transactions | XA   | Savepoints |
+--------------------+---------+----------------------------------------------------------------------------+--------------+------+------------+
| CSV                | YES     | CSV storage engine                                                         | NO           | NO   | NO         |
| MRG_MYISAM         | YES     | Collection of identical MyISAM tables                                      | NO           | NO   | NO         |
| MEMORY             | YES     | Hash based, stored in memory, useful for temporary tables                  | NO           | NO   | NO         |
| BLACKHOLE          | YES     | /dev/null storage engine (anything you write to it disappears)             | NO           | NO   | NO         |
| MyISAM             | YES     | MyISAM storage engine                                                      | NO           | NO   | NO         |
| InnoDB             | DEFAULT | Percona-XtraDB, Supports transactions, row-level locking, and foreign keys | YES          | YES  | YES        |
| ARCHIVE            | YES     | Archive storage engine                                                     | NO           | NO   | NO         |
| FEDERATED          | YES     | FederatedX pluggable storage engine                                        | YES          | NO   | YES        |
| PERFORMANCE_SCHEMA | YES     | Performance Schema                                                         | NO           | NO   | NO         |
| Aria               | YES     | Crash-safe tables with MyISAM heritage                                     | NO           | NO   | NO         |
+--------------------+---------+----------------------------------------------------------------------------+--------------+------+------------+
10 rows in set (0.00 sec)





表管理:

创建:
CREATE TABLE  [IF NOT EXISTS]  tbl_name  (create_defination)  [table_options]
create_defination:
字段:col_name  data_type
键:
PRIMARY KEY (col1, col2, ...)
UNIQUE KEY  (col1, col2,...)
FOREIGN KEY (column)
索引:
KEY|INDEX  [index_name]  (col1, col2,...)
table_options:
ENGINE [=] engine_name
查看数据库支持的所有存储引擎类型:
mysql> SHOW  ENGINES;
查看某表的存储引擎类型:
mysql> SHOW  TABLES  STATUS  [LIKE  'tbl_name']


修改:

ALTER [ONLINE | OFFLINE] [IGNORE] TABLE tbl_name  [alter_specification [, alter_specification] ...]
alter_specification:
字段:
添加:ADD  [COLUMN]  col_name  data_type  [FIRST | AFTER col_name ]
删除:DROP  [COLUMN] col_name 
修改:
CHANGE [COLUMN] old_col_name new_col_name column_definition  [FIRST|AFTER col_name]
MODIFY [COLUMN] col_name column_definition  [FIRST | AFTER col_name]
键:
添加:ADD  {PRIMARY|UNIQUE|FOREIGN}  KEY (col1, col2,...)
删除:
主键:DROP PRIMARY KEY
外键:DROP FOREIGN KEY fk_symbol
索引:
添加:ADD {INDEX|KEY} [index_name]  (col1, col2,...)
删除:DROP {INDEX|KEY}  index_name
表选项:
ENGINE [=] engine_name
查看表上的索引的信息:
mysql> SHOW INDEXES FROM tbl_name;
删除:
DROP  TABLE  [IF EXISTS]   tbl_name [, tbl_name] ...