一、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] ...