I always get the error:
CREATE DATABASE bundesliga ERRORCODE 1007 CANT CREATE DATABASE bundesliga, database exists
Here is my code:
CREATE DATABASE bundesliga;
DROP TABLE IF EXISTS Liga;
CREATE TABLE Liga (
);
DROP TABLE IF EXISTS Spiel;
CREATE TABLE Spiel ();
dur
15.7k25 gold badges80 silver badges125 bronze badges
asked May 23, 2014 at 19:33
3
Your Database Bundesliga already exists.
you have to drop your database first and then recreate it.
DROP DATABASE bundesliga;
CREATE DATABASE bundesliga;
DROP TABLE IF EXISTS Liga;
CREATE TABLE Liga (
);
DROP TABLE IF EXISTS Spiel;
CREATE TABLE Spiel ();
or use this
CREATE DATABASE IF NOT EXISTS bundesliga;
and to check if database exist.
SHOW DATABASES LIKE 'bundesliga';
answered May 23, 2014 at 19:37
echo_Meecho_Me
37.1k5 gold badges58 silver badges78 bronze badges
You can use an IF NOT EXISTS
clause to prevent the error:
CREATE DATABASE IF NOT EXISTS bundesliga;
If the database already exists, this does nothing. If it doesn’t exist, it will be created.
answered May 23, 2014 at 19:37
BarmarBarmar
744k53 gold badges503 silver badges615 bronze badges
Your database already exists. See error code 1007 here.
answered May 23, 2014 at 19:35
Coda17Coda17
5846 silver badges19 bronze badges
Your Database Bundesliga already exists. If you want to recrate you have to drop this before.
answered May 23, 2014 at 19:36
JensJens
67.9k15 gold badges99 silver badges113 bronze badges
1. Introduction to MySQL database
MySQL is a kind of relational database management system. Relational database stores data in different tables instead of putting all data in one big warehouse, which increases speed and improves flexibility. The SQL language used by MySQL is the most commonly used standardized language for accessing databases.
Relational Database Management System (RDBMS) is a system that organizes data into related rows and columns. The computer software for managing RDBMS is RDBMS.
Databases are generally divided into the following two types:
-
Relational database;
- Non relational database.
Common relational database software includes MySQL, Mariadb, Oracle, SQL Server, PostgreSQL, DB2, etc.
The commonly used non relational database software are Redis, memcached and MongoDB.
At present, there are free versions and paid versions of MySQL. Most companies use free versions of MySQL.
Mariadb database is a fully open source version of MySQL database developed independently by the original team.
1.1 MySQL engine
There are many MySQL engines, including myisam and innodb.
1.1.1 MyISAM
The main emphasis is on performance. Its execution speed is faster than that of InnoDB type, but it does not provide transaction support and foreign keys. If a large number of select operations are performed, MyISAM is a better choice and supports table locking. MyISAM engine has high query performance.
1.1.2 InnoDB
It provides transactions, supports transaction, foreign key, row level lock and other advanced database functions, and can execute a large number of insert s or update s. InnoDB engine has high write performance.
1.2 MySQL database installation
There are two ways to install MySQL, one is to install yum/rpm, and the other is to install tar source code.
1.2.1 MySQL yum installation
The yum installation method is very simple. Execute the following command:
1.2.1.1 CentOS 6 yum installation
[root@node01 ~]#yum install –y mysql-server mysql-devel mysql
1.2.1.2 CentOS 7 yum installation
[root@node01 ~]# yum install -y mariadb mariadb-devel mariadb-server
1.2.1.3 query the content of yum installation
[root@node01 ~]# rpm -qa|grep mariadb mariadb-libs-5.5.65-1.el7.x86_64 mariadb-devel-5.5.65-1.el7.x86_64 mariadb-server-5.5.65-1.el7.x86_64 mariadb-5.5.65-1.el7.x86_64 [root@node01 ~]#
1.2.1.4 yum install mariadb program
Main configuration directory of mariadb / var/lib/mysql
mariadb data directory / var/lib/mysql
mariadb command directory / usr/bin
mariadb default configuration file / etc/my.cnf
mariadb startup file / usr/bin
mariadb log file / var/log/mariadb
Note: the command and configuration of Mariadb and mysql database software are similar.
1.2.2 MySQL source code installation version 5.7
1.2.2.1 preparation for source code compilation and installation
- Because the CentOS system comes with mariadb, we need to uninstall it first.
[root@node02 ~]# rpm -qa|grep mariadb mariadb-server-5.5.60-1.el7_5.x86_64 mariadb-libs-5.5.60-1.el7_5.x86_64 mariadb-5.5.60-1.el7_5.x86_64 [root@node02 ~]# [root@node02 ~]# yum -y remove mariadb mariadb-server mariadb-libs
- Create user
[root@node02 ~]# useradd -s /sbin/nologin -M mysql #Prompt that mysql already exists. You can ignore this step
- Create a directory and modify permissions
[root@node02 ~]# mkdir -p /data/mysql [root@node02 ~]# chown -R mysql.mysql /data
- Install MySQL dependent packages
[root@node02 ~]# yum install -y gcc gcc-devel gcc-c++ gcc-c++-devel libaio* autoconf* automake* zlib* libxml* ncurses-devel ncurses libgcrypt* libtool* cmake openssl openssl-devel bison bison-devel perl-Data_Dumper boost boost-doc boost-devel
- Download the source code and unzip it
[root@node02 ~]# cd /usr/src/ [root@node02 src]# wget http://mirrors.163.com/mysql/Downloads/MySQL-5.7/mysql-5.7.30.tar.gz [root@node02 src]# ls debug kernels mysql-5.7.30.tar.gz [root@node02 src]# tar xf mysql-5.7.30.tar.gz [root@node02 src]# cd mysql-5.7.30/ [root@node02 mysql-5.7.30]#
- Download boost (there are many changes after the update of version 5.7. For example, the boost library must be installed for installation now)
[root@node02 mysql-5.7.30]# mkdir ./boost [root@node02 mysql-5.7.30]# cd ./boost [root@node02 boost]# wget http://nchc.dl.sourceforge.net/project/boost/boost/1.59.0/boost_1_59_0.tar.gz
Decompression and other operations when compiling the program will do, here only need to download or copy the package here
1.2.2.2 source code compilation and installation
- compile
[root@node02 boost]# cd ../ [root@node02 mysql-5.7.30]# cmake -DBUILD_CONFIG=mysql_release -DCMAKE_BUILD_TYPE=RelWithDebInfo -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/data/mysql -DSYSCONFDIR=/etc -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DSYSTEMD_PID_DIR=/data/mysql -DMYSQL_USER=mysql -DWITH_SYSTEMD=1 -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DMYSQL_TCP_PORT=3306 -DENABLED_LOCAL_INFILE=1 -DENABLE_DOWNLOADS=1 -DWITH_PARTITION_STORAGE_ENGINE=1 -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_DEBUG=0 -DMYSQL_MAINTAINER_MODE=0 -DWITH_SSL:STRING=system -DWITH_ZLIB:STRING=bundled -DDOWNLOAD_BOOST=1 -DWITH_BOOST=./boost
- Introduction to compilation parameters
cmake -DBUILD_CONFIG=mysql_release #This option configures the source distribution using the same build options used by Oracle to generate a binary distribution of the official MySQL version. -DCMAKE_BUILD_TYPE=RelWithDebInfo #Build type to build = enable optimization and generate debug information. This is the default MySQL build type. -DCMAKE_INSTALL_PREFIX=/usr/local/mysql #Option represents the base installation directory. -DMYSQL_DATADIR=/data/mysql #Location of the MySQL data directory. -DSYSCONFDIR=/etc #default my.cnf Options file directory. -DMYSQL_UNIX_ADDR=/tmp/mysql.sock #The Unix socket file path to which the server listens for socket connections. This must be an absolute pathname. The default is / tmp/mysql.sock . -DSYSTEMD_PID_DIR=/usr/local/mysql #The name of the directory where PID files are created when MySQL is managed by systemd. The default is / var/run/mysqld; this may be based on install_ The layout value changes implicitly. -DMYSQL_USER=mysql #Specifies the start user of MySQL -DWITH_SYSTEMD=1 #Install systemd support files -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DMYSQL_TCP_PORT=3306 #Configure the port number for MySQL listening -DENABLED_LOCAL_INFILE=1 #The mysql client has the function of load data infile, which has security risks. The load data infile statement reads a table from a text file at a high speed -DENABLE_DOWNLOADS=1 #The path to the Google mock distribution for unit testing based on Google Test. =1. CMake will download the distribution from GitHub. -DWITH_PARTITION_STORAGE_ENGINE=1 -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 #Server character set -DDEFAULT_COLLATION=utf8_general_ci #Server collation -DWITH_DEBUG=0 #Debugging support is not included. -DMYSQL_MAINTAINER_MODE=0 #Whether to enable MySQL maintainer specific development environment. If enabled, this option causes compiler warnings to become errors. -DWITH_SSL:STRING=system -DWITH_ZLIB:STRING=bundled -DDOWNLOAD_BOOST=1 #Whether to download the Boost library. The default is OFF. -DWITH_BOOST=./boost #Specify the Boost library directory location.
- Check whether there are exceptions in the compilation
[root@node02 mysql-5.7.30]# echo $? #The return result is 0, indicating that there is no exception in the compilation
- Source code installation
[root@node02 mysql-5.7.30]# make && make install
This process is quite long. Please wait
- Check whether the installation is abnormal
[root@node02 mysql-5.7.30]# echo $? #The return result is 0, indicating that there is no exception in the compilation
1.2.2.4 configuration after source installation
- Add systemd service control
[root@node02 mysql-5.7.30]# cp ./scripts/mysqld.service /usr/lib/systemd/system
- Add environment variable
[root@node02 mysql-5.7.30]# cat > /etc/profile.d/mysql.sh << EOF PATH=/usr/local/mysql/bin:$PATH export PATH EOF [root@node02 mysql-5.7.30]# source /etc/profile
- Null password initialization database
[root@node02 mysql-5.7.30]# /usr/local/mysql/bin/mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql
- Configure to start MySQL
[root@node02 mysql-5.7.30]# systemctl enable mysqld.service [root@node02 mysql-5.7.30]# systemctl daemon-reload [root@node02 mysql-5.7.30]# systemctl start mysqld.service [root@node02 mysql-5.7.30]# systemctl status mysqld.service
1.3 log in to the database server
1.3.1 connecting via unix socket
1.3.1.1 log in directly through mysql to view the connection status
[root@node02 ~]# mysql Welcome to the MySQL monitor. Commands end with ; or g. Your MySQL connection id is 2 Server version: 5.7.30 MySQL Community Server (GPL) Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or 'h' for help. Type 'c' to clear the current input statement. mysql> mysql> status -------------- mysql Ver 14.14 Distrib 5.7.30, for Linux (x86_64) using EditLine wrapper Connection id: 5 Current database: Current user: root@localhost SSL: Not in use Current pager: stdout Using outfile: '' Using delimiter: ; Server version: 5.7.30 MySQL Community Server (GPL) Protocol version: 10 Connection: Localhost via UNIX socket Server characterset: utf8 Db characterset: utf8 Client characterset: utf8 Conn. characterset: utf8 UNIX socket: /tmp/mysql.sock Uptime: 33 min 25 sec Threads: 1 Questions: 17 Slow queries: 0 Opens: 105 Flush tables: 1 Open tables: 98 Queries per second avg: 0.008 -------------- mysql>
1.3.1.2 mysql -uroot -p login to view the connection status
[root@node02 ~]# mysql -uroot -p Enter password: Welcome to the MySQL monitor. Commands end with ; or g. Your MySQL connection id is 3 Server version: 5.7.30 MySQL Community Server (GPL) Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or 'h' for help. Type 'c' to clear the current input statement. mysql> mysql> status -------------- mysql Ver 14.14 Distrib 5.7.30, for Linux (x86_64) using EditLine wrapper Connection id: 3 Current database: #The database currently used is not empty Current user: root@localhost SSL: Not in use #Do you want to use encryption Current pager: stdout Using outfile: '' Using delimiter: ; #The ending character is a semicolon Server version: 5.7.30 MySQL Community Server (GPL) Protocol version: 10 Connection: Localhost via UNIX socket #Connection mode, local socket Server characterset: utf8 Db characterset: utf8 Client characterset: utf8 Conn. characterset: utf8 UNIX socket: /tmp/mysql.sock Uptime: 17 min 33 sec Threads: 1 Questions: 7 Slow queries: 0 Opens: 105 Flush tables: 1 Open tables: 98 Queries per second avg: 0.006 -------------- mysql>
1.3.2 connection via tcp socket
1.3.2.1 log in to the server through mysql -h127.0.0.1 to view the status
[root@node02 ~]# mysql -h127.0.0.1 Welcome to the MySQL monitor. Commands end with ; or g. Your MySQL connection id is 4 Server version: 5.7.30 MySQL Community Server (GPL) Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or 'h' for help. Type 'c' to clear the current input statement. mysql> status -------------- mysql Ver 14.14 Distrib 5.7.30, for Linux (x86_64) using EditLine wrapper Connection id: 4 Current database: Current user: root@localhost SSL: Cipher in use is DHE-RSA-AES128-GCM-SHA256 Current pager: stdout Using outfile: '' Using delimiter: ; Server version: 5.7.30 MySQL Community Server (GPL) Protocol version: 10 Connection: 127.0.0.1 via TCP/IP Server characterset: utf8 Db characterset: utf8 Client characterset: utf8 Conn. characterset: utf8 TCP port: 3306 Uptime: 31 min 40 sec Threads: 1 Questions: 12 Slow queries: 0 Opens: 105 Flush tables: 1 Open tables: 98 Queries per second avg: 0.006 -------------- mysql>
Socket / ip socket can also be used for different communication. If you sometimes encounter a failure to connect through a local socket, you can use the specified server ip connection.
1.4 common command operation
1.4.1 database operation command
#Query database:
mysql> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | mysql | | performance_schema | | sys | +--------------------+ 4 rows in set (0.01 sec) mysql>
After initialization, there are four databases by default:
-
information_schema: information database. It mainly stores information about all other databases maintained by MySQL server, such as database name, database table, data type and access rights of table column. Through show databases;, the database information is also from the schema table in the database.
-
mysql: the core database of mysql. It is mainly responsible for storing database users, permission settings, keywords and other control and management information that mysql needs to use.
-
performance_schema: database for performance optimization.
#To view the database creation statement:
mysql> show create database mysql; +----------+----------------------------------------------------------------+ | Database | Create Database | +----------+----------------------------------------------------------------+ | mysql | CREATE DATABASE `mysql` /*!40100 DEFAULT CHARACTER SET utf8 */ | +----------+----------------------------------------------------------------+ 1 row in set (0.00 sec) mysql>
mysql is the database name.
#View character set command:
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 | | utf16le | UTF-16LE Unicode | utf16le_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 | | gb18030 | China National Standard GB18030 | gb18030_chinese_ci | 4 | +----------+---------------------------------+---------------------+--------+ 41 rows in set (0.00 sec) mysql>
#Create database zabbix, character set bit gbk;
mysql> create database zabbix default character set gbk; Query OK, 1 row affected (0.00 sec) mysql> mysql> show create database zabbix; +----------+----------------------------------------------------------------+ | Database | Create Database | +----------+----------------------------------------------------------------+ | zabbix | CREATE DATABASE `zabbix` /*!40100 DEFAULT CHARACTER SET gbk */ | +----------+----------------------------------------------------------------+ 1 row in set (0.00 sec) mysql>
#To modify the character set of the database:
mysql> alter database zabbix default character set utf8; Query OK, 1 row affected (0.00 sec) mysql> mysql> show create database zabbix; +----------+-----------------------------------------------------------------+ | Database | Create Database | +----------+-----------------------------------------------------------------+ | zabbix | CREATE DATABASE `zabbix` /*!40100 DEFAULT CHARACTER SET utf8 */ | +----------+-----------------------------------------------------------------+ 1 row in set (0.00 sec) mysql>
#Create database:
mysql> create database zabbix charset=utf8; ERROR 1007 (HY000): Can't create database 'zabbix'; database exists mysql> mysql> create database if not exists zabbix charset=gbk; Query OK, 1 row affected, 1 warning (0.00 sec) mysql>
Use the second command above to create a database. If the database already exists, no error will be reported.
#View warning:
mysql> show warnings; +-------+------+-------------------------------------------------+ | Level | Code | Message | +-------+------+-------------------------------------------------+ | Error | 1007 | Can't create database 'zabbix'; database exists | +-------+------+-------------------------------------------------+ 1 row in set (0.00 sec) mysql>
#Delete database:
mysql> drop database zabbix; mysql>
Or:
mysql> drop database zabbix; ERROR 1008 (HY000): Can't drop database 'zabbix'; database doesn't exist mysql> mysql> drop database if exists zabbix; Query OK, 0 rows affected, 1 warning (0.00 sec) mysql>
Delete the database in the second way above. If the database does not exist, there will be no error.
1.4.2 create table command
mysql> create table t1(id int(10) auto_increment primary key,name varchar(20),job varchar(10)); Query OK, 0 rows affected (0.01 sec) mysql>
1.4.3 view table structure related commands
To view all tables:
mysql> use mysql; Database changed mysql> mysql> show tables; +---------------------------+ | Tables_in_mysql | +---------------------------+ | columns_priv | | db | | engine_cost | | event | | func | | general_log | | gtid_executed | | help_category | | help_keyword | | help_relation | | help_topic | | innodb_index_stats | | innodb_table_stats | | ndb_binlog_index | | plugin | | proc | | procs_priv | | proxies_priv | | server_cost | | servers | | slave_master_info | | slave_relay_log_info | | slave_worker_info | | slow_log | | t1 | | tables_priv | | time_zone | | time_zone_leap_second | | time_zone_name | | time_zone_transition | | time_zone_transition_type | | user | +---------------------------+ 32 rows in set (0.00 sec) mysql>
perhaps
mysql> show tables from mysql; +---------------------------+ | Tables_in_mysql | +---------------------------+ | columns_priv | | db | | engine_cost | | event | | func | | general_log | | gtid_executed | | help_category | | help_keyword | | help_relation | | help_topic | | innodb_index_stats | | innodb_table_stats | | ndb_binlog_index | | plugin | | proc | | procs_priv | | proxies_priv | | server_cost | | servers | | slave_master_info | | slave_relay_log_info | | slave_worker_info | | slow_log | | t1 | | tables_priv | | time_zone | | time_zone_leap_second | | time_zone_name | | time_zone_transition | | time_zone_transition_type | | user | +---------------------------+ 32 rows in set (0.00 sec) mysql>
To view the details of all tables:
use mysql;
show table statusG
perhaps
show table status from mysqlG
To view the details of a table:
mysql> use mysql; Database changed mysql> mysql> show table status like "user"G *************************** 1. row *************************** Name: user Engine: MyISAM Version: 10 Row_format: Dynamic Rows: 3 Avg_row_length: 113 Data_length: 340 Max_data_length: 281474976710655 Index_length: 4096 Data_free: 0 Auto_increment: NULL Create_time: 2020-06-01 14:58:34 Update_time: 2020-06-01 14:58:35 Check_time: NULL Collation: utf8_bin Checksum: NULL Create_options: Comment: Users and global privileges 1 row in set (0.00 sec) mysql>
perhaps
mysql> show table status from mysql like "user"G *************************** 1. row *************************** Name: user Engine: MyISAM Version: 10 Row_format: Dynamic Rows: 3 Avg_row_length: 113 Data_length: 340 Max_data_length: 281474976710655 Index_length: 4096 Data_free: 0 Auto_increment: NULL Create_time: 2020-06-01 14:58:34 Update_time: 2020-06-01 14:58:35 Check_time: NULL Collation: utf8_bin Checksum: NULL Create_options: Comment: Users and global privileges 1 row in set (0.00 sec) mysql>
To view the table structure:
mysql> desc mysql.user; +------------------------+-----------------------------------+------+-----+-----------------------+-------+ | Field | Type | Null | Key | Default | Extra | +------------------------+-----------------------------------+------+-----+-----------------------+-------+ | Host | char(60) | NO | PRI | | | | User | char(32) | NO | PRI | | | | Select_priv | enum('N','Y') | NO | | N | | | Insert_priv | enum('N','Y') | NO | | N | | | Update_priv | enum('N','Y') | NO | | N | | | Delete_priv | enum('N','Y') | NO | | N | | | Create_priv | enum('N','Y') | NO | | N | | | Drop_priv | enum('N','Y') | NO | | N | | | Reload_priv | enum('N','Y') | NO | | N | | | Shutdown_priv | enum('N','Y') | NO | | N | | | Process_priv | enum('N','Y') | NO | | N | | | File_priv | enum('N','Y') | NO | | N | | | Grant_priv | enum('N','Y') | NO | | N | | | References_priv | enum('N','Y') | NO | | N | | | Index_priv | enum('N','Y') | NO | | N | | | Alter_priv | enum('N','Y') | NO | | N | | | Show_db_priv | enum('N','Y') | NO | | N | | | Super_priv | enum('N','Y') | NO | | N | | | Create_tmp_table_priv | enum('N','Y') | NO | | N | | | Lock_tables_priv | enum('N','Y') | NO | | N | | | Execute_priv | enum('N','Y') | NO | | N | | | Repl_slave_priv | enum('N','Y') | NO | | N | | | Repl_client_priv | enum('N','Y') | NO | | N | | | Create_view_priv | enum('N','Y') | NO | | N | | | Show_view_priv | enum('N','Y') | NO | | N | | | Create_routine_priv | enum('N','Y') | NO | | N | | | Alter_routine_priv | enum('N','Y') | NO | | N | | | Create_user_priv | enum('N','Y') | NO | | N | | | Event_priv | enum('N','Y') | NO | | N | | | Trigger_priv | enum('N','Y') | NO | | N | | | Create_tablespace_priv | enum('N','Y') | NO | | N | | | ssl_type | enum('','ANY','X509','SPECIFIED') | NO | | | | | ssl_cipher | blob | NO | | NULL | | | x509_issuer | blob | NO | | NULL | | | x509_subject | blob | NO | | NULL | | | max_questions | int(11) unsigned | NO | | 0 | | | max_updates | int(11) unsigned | NO | | 0 | | | max_connections | int(11) unsigned | NO | | 0 | | | max_user_connections | int(11) unsigned | NO | | 0 | | | plugin | char(64) | NO | | mysql_native_password | | | authentication_string | text | YES | | NULL | | | password_expired | enum('N','Y') | NO | | N | | | password_last_changed | timestamp | YES | | NULL | | | password_lifetime | smallint(5) unsigned | YES | | NULL | | | account_locked | enum('N','Y') | NO | | N | | +------------------------+-----------------------------------+------+-----+-----------------------+-------+ 45 rows in set (0.00 sec) mysql>
To view the sql statement that creates the table:
mysql> show create table mysql.userG *************************** 1. row *************************** Table: user Create Table: CREATE TABLE `user` ( `Host` char(60) COLLATE utf8_bin NOT NULL DEFAULT '', `User` char(32) COLLATE utf8_bin NOT NULL DEFAULT '', `Select_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Insert_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Update_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Delete_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Create_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Drop_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Reload_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Shutdown_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Process_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `File_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Grant_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `References_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Index_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Alter_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Show_db_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Super_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Create_tmp_table_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Lock_tables_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Execute_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Repl_slave_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Repl_client_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Create_view_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Show_view_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Create_routine_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Alter_routine_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Create_user_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Event_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Trigger_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `Create_tablespace_priv` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `ssl_type` enum('','ANY','X509','SPECIFIED') CHARACTER SET utf8 NOT NULL DEFAULT '', `ssl_cipher` blob NOT NULL, `x509_issuer` blob NOT NULL, `x509_subject` blob NOT NULL, `max_questions` int(11) unsigned NOT NULL DEFAULT '0', `max_updates` int(11) unsigned NOT NULL DEFAULT '0', `max_connections` int(11) unsigned NOT NULL DEFAULT '0', `max_user_connections` int(11) unsigned NOT NULL DEFAULT '0', `plugin` char(64) COLLATE utf8_bin NOT NULL DEFAULT 'mysql_native_password', `authentication_string` text COLLATE utf8_bin, `password_expired` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', `password_last_changed` timestamp NULL DEFAULT NULL, `password_lifetime` smallint(5) unsigned DEFAULT NULL, `account_locked` enum('N','Y') CHARACTER SET utf8 NOT NULL DEFAULT 'N', PRIMARY KEY (`Host`,`User`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='Users and global privileges' 1 row in set (0.00 sec) mysql>
1.4.4 commands related to modifying table structure
Add table field:
mysql> alter table t1 add job1 varchar(20); Query OK, 0 rows affected (0.00 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql>
It is added after by default. If you want to add it to the first column or after a field, you can specify:
#Add to the first column
mysql> alter table t1 add job2 varchar(20) first; Query OK, 0 rows affected (0.00 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> mysql> desc t1; +-------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+-------------+------+-----+---------+----------------+ | job2 | varchar(20) | YES | | NULL | | | id | int(10) | NO | PRI | NULL | auto_increment | | name | varchar(20) | YES | | NULL | | | job | varchar(10) | YES | | NULL | | | job1 | varchar(20) | YES | | NULL | | +-------+-------------+------+-----+---------+----------------+ 5 rows in set (0.01 sec) mysql>
#Add after the name field:
mysql> alter table t1 add job3 varchar(20) after name; Query OK, 0 rows affected (0.00 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> mysql> desc t1; +-------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+-------------+------+-----+---------+----------------+ | job2 | varchar(20) | YES | | NULL | | | id | int(10) | NO | PRI | NULL | auto_increment | | name | varchar(20) | YES | | NULL | | | job3 | varchar(20) | YES | | NULL | | | job | varchar(10) | YES | | NULL | | | job1 | varchar(20) | YES | | NULL | | +-------+-------------+------+-----+---------+----------------+ 6 rows in set (0.00 sec) mysql>
To modify a table field name, you need to write all the field properties:
mysql> alter table t1 change id age int(5); Query OK, 0 rows affected (0.02 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> mysql> desc t1; +-------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+-------------+------+-----+---------+-------+ | job2 | varchar(20) | YES | | NULL | | | age | int(5) | NO | PRI | NULL | | | name | varchar(20) | YES | | NULL | | | job3 | varchar(20) | YES | | NULL | | | job | varchar(10) | YES | | NULL | | | job1 | varchar(20) | YES | | NULL | | +-------+-------------+------+-----+---------+-------+ 6 rows in set (0.00 sec) mysql>
id: original field
age: new field
To modify the properties or locations of table fields:
#Change the order of the fields and put job3 in the first column:
mysql> alter table t1 modify job3 varchar(20) first; Query OK, 0 rows affected (0.01 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> mysql> desc t1; +-------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+-------------+------+-----+---------+-------+ | job3 | varchar(20) | YES | | NULL | | | job2 | varchar(20) | YES | | NULL | | | age | int(5) | NO | PRI | NULL | | | name | varchar(20) | YES | | NULL | | | job | varchar(10) | YES | | NULL | | | job1 | varchar(20) | YES | | NULL | | +-------+-------------+------+-----+---------+-------+ 6 rows in set (0.00 sec) mysql>
To delete a table field:
mysql> alter table t1 drop job3; Query OK, 0 rows affected (0.01 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> mysql> desc t1; +-------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+-------------+------+-----+---------+-------+ | job2 | varchar(20) | YES | | NULL | | | age | int(5) | NO | PRI | NULL | | | name | varchar(20) | YES | | NULL | | | job | varchar(10) | YES | | NULL | | | job1 | varchar(20) | YES | | NULL | | +-------+-------------+------+-----+---------+-------+ 5 rows in set (0.00 sec) mysql>
1.4.5 add, delete, modify and check
1.4.5.1 increase
#Add data in full field:
mysql> insert into t1 values(1,"xiaoming","it"); Query OK, 1 row affected (0.00 sec) mysql>
perhaps
mysql> insert t1 values(2,"xiaohua","student"); Query OK, 1 row affected (0.00 sec) mysql>
perhaps
mysql> insert t1 set name="xiaoming",job="teacher"; Query OK, 1 row affected (0.00 sec) mysql>
#Add data to the specified field:
mysql> insert into t1(name) value("xiaoqiang"),("xiaowang"); Query OK, 2 rows affected (0.00 sec) Records: 2 Duplicates: 0 Warnings: 0 mysql>
1.4.5.2 by deleting
#Physical deletion, there is no data
mysql> delete from t1 where id=4; Query OK, 1 row affected (0.00 sec) mysql> mysql> select * from t1; +----+----------+---------+ | id | name | job | +----+----------+---------+ | 2 | xiaohua | student | | 3 | xiaoming | teacher | | 5 | xiaowang | NULL | +----+----------+---------+ 3 rows in set (0.00 sec) mysql>
#For logical deletion, a field needs to be added. The default setting is 0:
mysql> alter table t1 add isdelete bit default 0; Query OK, 0 rows affected (0.04 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> mysql> select * from t1; +----+----------+---------+----------+ | id | name | job | isdelete | +----+----------+---------+----------+ | 2 | xiaohua | student | | | 3 | xiaoming | teacher | | | 5 | xiaowang | NULL | | +----+----------+---------+----------+ 3 rows in set (0.00 sec) mysql>
#Set the isdelete field to 1:
mysql> update t1 set isdelete=1 where id=3; Query OK, 1 row affected (0.01 sec) Rows matched: 1 Changed: 1 Warnings: 0 mysql> mysql> select * from t1; +----+----------+---------+----------+ | id | name | job | isdelete | +----+----------+---------+----------+ | 2 | xiaohua | student | | | 3 | xiaoming | teacher | | | 5 | xiaowang | NULL | | +----+----------+---------+----------+ 3 rows in set (0.00 sec) mysql>
#Then find the data whose isdelete field is 0 to filter
mysql> select * from t1 where isdelete=0; +----+----------+---------+----------+ | id | name | job | isdelete | +----+----------+---------+----------+ | 2 | xiaohua | student | | | 5 | xiaowang | NULL | | +----+----------+---------+----------+ 2 rows in set (0.00 sec) mysql>
1.4.5.3 change
#To modify the data in the table without adding rows, insert into will add rows: update t1 set name=»xiaoxiao» where id=6; t1 is the table name,
Name is the field name,
where is followed by a conditional statement. If not, the entire table has to be modified. Be careful!
#Modify multiple fields separated by commas:
mysql> update t1 set name="xiaoqiang",job="engineer" where id=3 ; Query OK, 1 row affected (0.00 sec) Rows matched: 1 Changed: 1 Warnings: 0 mysql> mysql> mysql> select * from t1; +----+-----------+----------+----------+ | id | name | job | isdelete | +----+-----------+----------+----------+ | 2 | xiaohua | student | | | 3 | xiaoqiang | engineer | | | 5 | xiaowang | NULL | | +----+-----------+----------+----------+ 3 rows in set (0.00 sec) mysql>
1.4.5.4 check
Full field search, not recommended:
mysql> select * from t1; +----+-----------+----------+----------+ | id | name | job | isdelete | +----+-----------+----------+----------+ | 2 | xiaohua | student | | | 3 | xiaoqiang | engineer | | | 5 | xiaowang | NULL | | +----+-----------+----------+----------+ 3 rows in set (0.00 sec) mysql>
Find the specified field:
mysql> select name,job from t1; +-----------+----------+ | name | job | +-----------+----------+ | xiaohua | student | | xiaoqiang | engineer | | xiaowang | NULL | +-----------+----------+ 3 rows in set (0.00 sec) mysql>
1.4.9 find by operator
>=Greater than or equal to
=Equal to
>Greater than
< less than
< = less than or equal to
! = not equal to
Search for user id, user name and job with id greater than or equal to 4:
mysql> select id,name,job from t1 where id >=4; +----+----------+------+ | id | name | job | +----+----------+------+ | 5 | xiaowang | NULL | +----+----------+------+ 1 row in set (0.00 sec) mysql>
Multiple conditions are satisfied at the same time
If one of the conditions is satisfied
Look for data whose id is greater than or equal to 3 and which is not marked for deletion
mysql> select id,name,job,isdelete from t1 where id>=3 and isdelete=0; +----+----------+------+----------+ | id | name | job | isdelete | +----+----------+------+----------+ | 5 | xiaowang | NULL | | +----+----------+------+----------+ 1 row in set (0.00 sec) mysql>
1.4.10 fuzzy search
like fuzzy search
%Match any number of characters
A kind of Single character matching
To find data with the character xiao in the name:
mysql> select id,name,job from t1 where name like "xiao%"; +----+-----------+----------+ | id | name | job | +----+-----------+----------+ | 2 | xiaohua | student | | 3 | xiaoqiang | engineer | | 5 | xiaowang | NULL | +----+-----------+----------+ 3 rows in set (0.00 sec) mysql>
Insert a piece of data to find data with a name containing xiao followed by a single character
mysql> insert t1(name) value("xiaom"); Query OK, 1 row affected (0.01 sec) mysql> mysql> select id,name,job from t1 where name like "xiao_"; +----+-------+------+ | id | name | job | +----+-------+------+ | 6 | xiaom | NULL | +----+-------+------+ 1 row in set (0.00 sec) mysql>
1.4.11 range search
in stands for the discontinuous range
between A and B denotes a continuous range
not in a condition
Look for data with id equal to 2, 3, or 6
mysql> select id,name,job from t1 where id in(2,3,6); +----+-----------+----------+ | id | name | job | +----+-----------+----------+ | 2 | xiaohua | student | | 3 | xiaoqiang | engineer | | 6 | xiaom | NULL | +----+-----------+----------+ 3 rows in set (0.00 sec) mysql>
Look for data with IDS between 3 and 6 (including 3 and 6)
mysql> select id,name,job from t1 where id between 3 and 6; +----+-----------+----------+ | id | name | job | +----+-----------+----------+ | 3 | xiaoqiang | engineer | | 5 | xiaowang | NULL | | 6 | xiaom | NULL | +----+-----------+----------+ 3 rows in set (0.00 sec) mysql>
Search for data with id not equal to 3,6:
mysql> select id,name,job from t1 where id not in (3,6); +----+----------+---------+ | id | name | job | +----+----------+---------+ | 2 | xiaohua | student | | 5 | xiaowang | NULL | +----+----------+---------+ 2 rows in set (0.00 sec) mysql>
1.4.12 null value search
is null find null
mysql> select id,name,job from t1 where job is null; +----+----------+------+ | id | name | job | +----+----------+------+ | 5 | xiaowang | NULL | | 6 | xiaom | NULL | +----+----------+------+ 2 rows in set (0.00 sec) mysql>
Polymerization
mysql> select max(age) from t1; +----------+ | max(age) | +----------+ | 15 | +----------+ 1 row in set (0.01 sec) mysql> mysql> select min(age) from t1; +----------+ | min(age) | +----------+ | 6 | +----------+ 1 row in set (0.00 sec) mysql> mysql> select count(*) from t1 where isdelete=0; +----------+ | count(*) | +----------+ | 3 | +----------+ 1 row in set (0.00 sec) mysql>
Sorting
The order by field asc is sorted from small to large according to the «column»
Sort from small to large according to id:
mysql> select * from t1 order by id asc; +----+-----------+------+----------+----------+ | id | name | age | job | isdelete | +----+-----------+------+----------+----------+ | 2 | xiaohua | 10 | student | | | 3 | xiaoqiang | 6 | engineer | | | 5 | xiaowang | 15 | NULL | | | 6 | xiaom | 11 | NULL | | +----+-----------+------+----------+----------+ 4 rows in set (0.00 sec) mysql>
The order by field desc is sorted from large to small according to the «column»
Sort from large to small according to id:
mysql> select * from t1 order by id desc; +----+-----------+------+----------+----------+ | id | name | age | job | isdelete | +----+-----------+------+----------+----------+ | 6 | xiaom | 11 | NULL | | | 5 | xiaowang | 15 | NULL | | | 3 | xiaoqiang | 6 | engineer | | | 2 | xiaohua | 10 | student | | +----+-----------+------+----------+----------+ 4 rows in set (0.00 sec) mysql>
Grouping
group by field
#According to the name group, count the number of the same name:
mysql> select count(*),name from t1 group by name; +----------+-----------+ | count(*) | name | +----------+-----------+ | 1 | xiaohua | | 1 | xiaom | | 1 | xiaoqiang | | 2 | xiaowang | +----------+-----------+ 4 rows in set (0.00 sec) mysql>
1.4.16 limitations
limit n; displays the first n lines
#Show the first three lines
mysql> select * from t1 limit 3; +----+-----------+------+----------+----------+ | id | name | age | job | isdelete | +----+-----------+------+----------+----------+ | 2 | xiaohua | 10 | student | | | 3 | xiaoqiang | 6 | engineer | | | 5 | xiaowang | 15 | NULL | | +----+-----------+------+----------+----------+ 3 rows in set (0.00 sec) mysql>
#Display 3 lines from line 3;
mysql> select * from t1 limit 3,3; +----+----------+------+-------+----------+ | id | name | age | job | isdelete | +----+----------+------+-------+----------+ | 6 | xiaom | 11 | NULL | | | 9 | xiaowang | 18 | sales | | +----+----------+------+-------+----------+ 2 rows in set (0.00 sec) mysql>
#Show 4 lines from line 3
mysql> select * from t1 limit 4 offset 3; +----+----------+------+-------+----------+ | id | name | age | job | isdelete | +----+----------+------+-------+----------+ | 6 | xiaom | 11 | NULL | | | 9 | xiaowang | 18 | sales | | +----+----------+------+-------+----------+ 2 rows in set (0.00 sec) mysql>
1.5 view related operations
The view is not a real table. It mainly integrates the commonly used fields or data into a «table».
1.5.1 create view
#Create the table first:
mysql> create table t2(id int(10) not null auto_increment primary key,name varchar(20),job varchar(10)); Query OK, 0 rows affected (0.01 sec) mysql>
#Insert data:
mysql> insert t2 set name="xiaoming",job="it"; Query OK, 1 row affected (0.00 sec) mysql> mysql> insert t2 set name="xiaowang",job="student"; Query OK, 1 row affected (0.00 sec) mysql> mysql> insert t2 set name="xiaohong",job="teacher"; Query OK, 1 row affected (0.00 sec) mysql>
#To create a view:
mysql> create view v1 as select name,job from t1; Query OK, 0 rows affected (0.00 sec) mysql> mysql> create view v2 as select * from t2 where id >= 2; Query OK, 0 rows affected (0.00 sec) mysql>
1.5.2 view view
#View all views:
mysql> select * from information_schema.views where table_schema="mysql"G *************************** 1. row *************************** TABLE_CATALOG: def TABLE_SCHEMA: mysql TABLE_NAME: v1 VIEW_DEFINITION: select `mysql`.`t1`.`name` AS `name`,`mysql`.`t1`.`job` AS `job` from `mysql`.`t1` CHECK_OPTION: NONE IS_UPDATABLE: YES DEFINER: root@localhost SECURITY_TYPE: DEFINER CHARACTER_SET_CLIENT: utf8 COLLATION_CONNECTION: utf8_general_ci *************************** 2. row *************************** TABLE_CATALOG: def TABLE_SCHEMA: mysql TABLE_NAME: v2 VIEW_DEFINITION: select `mysql`.`t2`.`id` AS `id`,`mysql`.`t2`.`name` AS `name`,`mysql`.`t2`.`job` AS `job` from `mysql`.`t2` where (`mysql`.`t2`.`id` >= 2) CHECK_OPTION: NONE IS_UPDATABLE: YES DEFINER: root@localhost SECURITY_TYPE: DEFINER CHARACTER_SET_CLIENT: utf8 COLLATION_CONNECTION: utf8_general_ci 2 rows in set (0.00 sec) mysql>
#To view a view structure:
mysql> desc v2; +-------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+-------------+------+-----+---------+-------+ | id | int(10) | NO | | 0 | | | name | varchar(20) | YES | | NULL | | | job | varchar(10) | YES | | NULL | | +-------+-------------+------+-----+---------+-------+ 3 rows in set (0.01 sec) mysql>
#To view the contents of the view:
mysql> select * from v2; +----+----------+---------+ | id | name | job | +----+----------+---------+ | 2 | xiaowang | student | | 3 | xiaohong | teacher | +----+----------+---------+ 2 rows in set (0.00 sec) mysql>
1.5.3 delete view
mysql> drop view v2; Query OK, 0 rows affected (0.00 sec) mysql>
perhaps
mysql> drop view if exists v2; Query OK, 0 rows affected, 1 warning (0.00 sec) mysql>
1.5.4 modify view
alter view v1 as select id,job from t1;
mysql> alter view v1 as select id,job from t1; Query OK, 0 rows affected (0.00 sec) mysql>
1.6 change password
1.6.1 the password is empty or the current password is known
Method 1: use the SET PASSWORD command
First log in to MySQL.
Format: MySQL > set password for user name @ localhost = password(‘New password ‘);
example:
mysql> set password for root@localhost=password('123'); Query OK, 0 rows affected, 1 warning (0.00 sec) mysql>
Method 2: execute in the shell terminal
[root@node02 ~]# mysql -uroot -p -e "set password for root@localhost=password('123456');" Enter password: ------Enter the original password here [root@node02 ~]#
ps: pay attention to double quotation marks and single quotation marks!!!
Method 3: use mysqladmin in shell terminal
Format: mysqladmin -u user name — p old password password new password
example:
[root@node02 ~]# mysqladmin -uroot -p123 password 123456 mysqladmin: [Warning] Using a password on the command line interface can be insecure. Warning: Since password will be sent to server in plain text, use ssl connection to ensure password safety. [root@node02 ~]#
Method 4: directly edit the user table with UPDATE. First log in to MySQL.
mysql> use mysql; mysql 5.7 Previous versions mysql> update user set password=password('123') where user='root' and host='localhost'; Query OK, 1 row affected, 1 warning (0.00 sec) Rows matched: 1 Changed: 1 Warnings: 1 mysql> mysql 5.7 Later version mysql> update user set authentication_string=password('123') where user='root' and host='localhost'; Query OK, 1 row affected, 1 warning (0.00 sec) Rows matched: 1 Changed: 1 Warnings: 1 mysql>
1.6.2 forget password
1.6.2.1 mysql 5.5
- Executable use / usr / bin / mysqld_ safe —user=mysql —skip-grant-tables &
[root@node01 ~]# /usr/bin/mysqld_safe --user=mysql --skip-grant-tables & [1] 16638 [root@node01 ~]# 200603 06:27:49 mysqld_safe Logging to '/var/log/mariadb/mariadb.log'. 200603 06:27:49 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql [root@node01 ~]#
- Then use the mysql command to change the password:
[root@node01 ~]# mysql Welcome to the MariaDB monitor. Commands end with ; or g. Your MariaDB connection id is 1 Server version: 5.5.65-MariaDB MariaDB Server Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others. Type 'help;' or 'h' for help. Type 'c' to clear the current input statement. MariaDB [(none)]> update mysql.user set passwrod=password('') where user="root" and host="localhost"; ERROR 1054 (42S22): Unknown column 'passwrod' in 'field list' MariaDB [(none)]> MariaDB [(none)]> use mysql; Reading table information for completion of table and column names You can turn off this feature to get a quicker startup with -A Database changed MariaDB [mysql]> update user set password=password('123') where user='root' and host='localhost'; Query OK, 1 row affected (0.01 sec) Rows matched: 1 Changed: 1 Warnings: 0 MariaDB [mysql]> MariaDB [mysql]> flush privileges; Query OK, 0 rows affected (0.00 sec) MariaDB [mysql]>
1.6.2.2 mysql 5.7
- Edit / etc/my.cnf
[root@node02 ~]# vim /etc/my.cnf
- Add in [mysqld]
skip-grant-tables
For example:
[mysqld]
skip-grant-tables
datadir=/data/mysql
socket=/temp/mysql.sock
- Restart mysql
[root@node02 ~]# systemctl restart mysqld.service
- User login without password
[root@node02 ~]# mysql -uroot -p (click enter directly, password is empty)
- Select database
mysql> use mysql; Reading table information for completion of table and column names You can turn off this feature to get a quicker startup with -A Database changed mysql>
- Change root password
mysql> update mysql.user set authentication_string=password('1qaz.#EDC') where user='root'; Query OK, 0 rows affected, 1 warning (0.00 sec) Rows matched: 1 Changed: 0 Warnings: 1 mysql>
- implement
mysql> flush privileges; Query OK, 0 rows affected (0.00 sec) mysql>
- Exit mysql
mysql> quit Bye [root@node02 ~]#
- Edit / etc/my.cnf
Delete skip grant tables save exit
- Restart mysql
[root@node02 ~]# systemctl restart mysqld.service [root@node02 ~]#
1.7 security settings
After installing mysql, it is better to execute MySQL if it is used in production environment_ secure_ Installation to do some general security settings.
1.7.1 set password complexity strategy and password;
[root@node02 ~]# mysql_secure_installation Securing the MySQL server deployment. Connecting to MySQL using a blank password. VALIDATE PASSWORD PLUGIN can be used to test passwords and improve security. It checks the strength of password and allows the users to set only those passwords which are secure enough. Would you like to setup VALIDATE PASSWORD plugin? Press y|Y for Yes, any other key for No: Y There are three levels of password validation policy: LOW Length >= 8 MEDIUM Length >= 8, numeric, mixed case, and special characters STRONG Length >= 8, numeric, mixed case, special characters and dictionary file Please enter 0 = LOW, 1 = MEDIUM and 2 = STRONG: 2 Please set the password for root here. New password: Re-enter new password:
1.7.2 delete anonymous users;
Estimated strength of the password: 100 Do you wish to continue with the password provided?(Press y|Y for Yes, any other key for No) : Y By default, a MySQL installation has an anonymous user, allowing anyone to log into MySQL 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? (Press y|Y for Yes, any other key for No) : Y Success.
1.7.3 remote login is not allowed;
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? (Press y|Y for Yes, any other key for No) : Y Success.
1.7.4 delete the test database;
By default, MySQL 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? (Press y|Y for Yes, any other key for No) : Y - Dropping test database... Success. - Removing privileges on test database... Success.
1.7.5 refresh MySQL system permission related tables.
Reloading the privilege tables will ensure that all changes made so far will take effect immediately. Reload privilege tables now? (Press y|Y for Yes, any other key for No) : Y Success. All done!
Posted by presidentccj
at Sep 23, 2020 — 6:52 AM
Tag:
CentOS
Java
Linux
Database
MySQL
Today I was working on my TestMakerFree Angular app, which I used as a sample app for my ASP.NET Core 2 and Angular 5 book: specifically, I was looking for a way to programmatically check if the SQL database existed or not. The reason of that is simple: the DbContext.Database.Migrate() method, which can be used in an ASP.NET Core application (when using EF Core with migrations) to ensure the database is created and all migrations are applied, will throw an exception when used against a Database which is not identical to the one it created and migrated from the very beginning.
Here’s a typical implementation of the DbContext.Database.Migrate() method in an ASP.NET Core application:
var host = BuildWebHost(args); using (var scope = host.Services.CreateScope()) { var dbContext = scope.ServiceProvider.GetService<ApplicationDbContext>(); var roleManager = scope.ServiceProvider.GetService<RoleManager<IdentityRole>>(); var userManager = scope.ServiceProvider.GetService<UserManager<ApplicationUser>>(); // Create the Database if it doesn’t exist and applies any pending migration. dbContext.Database.Migrate(); // Seed the Database DbSeeder.Seed(dbContext, roleManager, userManager); } host.Run(); |
This piece of code is usually put inside the Main() method of the Program.cs file and will ensure that the DB is not only present, but also up-to-date and perfectly matching the migrations present in the actual code.
The issue
Although this is indeed a good thing, that method might either pose performance issues and/or raise unexpected exceptions in our code. The former will occur whenever there aren’t new migrations to apply, while the latter will be thrown whenever the Database — despite being up-to-date — has been created using different migrations, such as from a different development machine: as a matter of fact, the Migrate() method will fail (and throw a SqlException) whenever it doesn’t find all the expected migrations in the __EFMigrationsHistory SQL table.
Here’s a typical SqlException that you would see while attempting to do that:
Application startup exception: System.Data.SqlClient.SqlException (0x80131904): Database ‘MyDatabaseName’ already exists. Choose a different database name.
The fix
Before start talking about the fix, there’s an important thing that we need to understand: the migration pattern is an excellent way to ensure that all the Databases we’re working on (and we’ll use to connect our app with) will have a consistent and up-to-date structure in any given environment — testing, stage, production, DR and so on; if we choose to use it, the best thing we can do is to stick to the pattern best practices and ensure that the Migrate() method is called whenever we need to.
That said, if you want to use the Migrate() method solely to create your database on the first run and you don’t need to programmatically (and automatically) keep track of any further migration, the best thing you can do is to wrap the Migrate() method inside a conditional block:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
if (!dbContext.Database.GetService<IRelationalDatabaseCreator>().Exists()) { var host = BuildWebHost(args); using (var scope = host.Services.CreateScope()) { var dbContext = scope.ServiceProvider.GetService<ApplicationDbContext>(); var roleManager = scope.ServiceProvider.GetService<RoleManager<IdentityRole>>(); var userManager = scope.ServiceProvider.GetService<UserManager<ApplicationUser>>(); // Create the Db if it doesn’t exist and applies any pending migration. dbContext.Database.Migrate(); // Seed the Db DbSeeder.Seed(dbContext, roleManager, userManager); } host.Run(); } |
That way you will ensure that the Migrate() method will be programmatically executed only if the Database doesn’t exists yet: that would be perfect for testing environments, where you can just drop and recreate the Database everytime without having to worry about losing actual data, and/or for any other context where you prefer to manually update your Database — for example using the dotnet ef powershell command. That’s good for performance and also to avoid the SqlException from the Migrate() method, as it will only run whenever there is no Database to begin with, thus preventing the chance of finding wrong or outdated migrations data.
If you’re curious about what the Exists() method actually does behind the curtains, you can easily check it out by looking at the in the SqlServer.Storage/Internal/SqlServerDatabaseCreator.cs class within the EF Core’s official GitHub repository: you will see that there’s no actual magic — just an attempt to open the connection and either catch the SqlException and return false or return true. Probably not the best thing you can hope to find there, yet still better than nothing (at least it does the job).
If you want to know more about .NET Core and Angular check out the ASP.NET Core 2 and Angular 5 book, available in paperback and/or digital format. Promo Code: ASPCA50 to get it with a 50% discount! The book’s latest edition, updated to ASP.NET Core 5 and Angular 11, is available here.
Страницы 1
Чтобы отправить ответ, вы должны войти или зарегистрироваться
1 2008-11-24 10:00:55
- arbr
- Редкий гость
- Неактивен
- Зарегистрирован: 2008-11-24
- Сообщений: 11
Тема: Выдаёт ошибку при импорте localhost.sql
Я сделал резервную копия базы данных, все удалил , захажу в phpMyAdmin ( версия у меня — 2.11.9.1), нажимаю импорт — в списке файлов выбераю файл localhost.sql, все остальные настройки оставляю по умолчания — нажимаю ок — и мне пишет вот такую ошибку:
Ошибка
SQL-запрос:
—
— База данных: `arbrspb_forum`
—
CREATE DATABASE `arbrspb_forum` DEFAULT CHARACTER SET latin1 COLLATE latin1_swedish_ci;
Ответ MySQL:
#1044 — Access denied for user ‘arbrspb’@’localhost’ to database ‘arbrspb_forum’
_____________________
[size=15] Что делать? Как импортировать резервную копию базы данных? [/size]
2 Ответ от Hanut 2008-11-24 15:39:47
- Hanut
- Модератор
- Неактивен
- Откуда: Рига, Латвия
- Зарегистрирован: 2006-07-02
- Сообщений: 9,726
Re: Выдаёт ошибку при импорте localhost.sql
arbr
Пользователь, которым вы подключаетесь, не имеет прав на указанную БД.
Если есть доступ к конфигурационному файлу phpMyAdmin, попробуйте установить подключение под root.
Иначе, Сперва создайте БД с именем arbrspb_forum и назначьте права пользователя. Также, в дампе необходимо будет убрать строку на создание БД — CREATE DATABASE `arbrspb_forum`…
3 Ответ от arbr 2008-11-24 19:26:03
- arbr
- Редкий гость
- Неактивен
- Зарегистрирован: 2008-11-24
- Сообщений: 11
Re: Выдаёт ошибку при импорте localhost.sql
Сделал как вы все написали , теперь выдает вот такую ошибку:
Ошибка
SQL-запрос:
—
— База данных: `arbrspb_forum`
—
CREATE DATABASE `arbrspb_forum` DEFAULT CHARACTER SET latin1 COLLATE latin1_swedish_ci;
Ответ MySQL:
#1007 — Can’t create database ‘arbrspb_forum’; database exists
4 Ответ от Hanut 2008-11-25 01:08:14
- Hanut
- Модератор
- Неактивен
- Откуда: Рига, Латвия
- Зарегистрирован: 2006-07-02
- Сообщений: 9,726
Re: Выдаёт ошибку при импорте localhost.sql
arbr
Выше я указал, что при создании БД вручную, необходимо удалить запрос на ее создание в дампе. Иначе происходит попытка создать БД, которая уже существует.
5 Ответ от arbr 2008-11-25 17:16:43
- arbr
- Редкий гость
- Неактивен
- Зарегистрирован: 2008-11-24
- Сообщений: 11
Re: Выдаёт ошибку при импорте localhost.sql
Я создаю базу с помощью Мастер баз данных MySQL , конкретно скажите мне пожалуйста какие привилегии выбрать а какие нет , пробовал вообще ничего не выбрать , все равно пишет «#1007 — Can’t create database ‘arbrspb_forum’; database exists» .
6 Ответ от Hanut 2008-11-26 14:42:50
- Hanut
- Модератор
- Неактивен
- Откуда: Рига, Латвия
- Зарегистрирован: 2006-07-02
- Сообщений: 9,726
Re: Выдаёт ошибку при импорте localhost.sql
arbr
Требуемые скриптом привилегии обычно указываются в документации. Как правило достаточно установить все галочки, кроме FILE, в блоке «Данные». Если этого окажется недостаточно, то можно выставить все галочки в блоке «Структура».
Ваша ошибка говорит о том, что при импорте дампа происходит попытка создания БД, которую вы уже создали вручную. Убрать ошибку можно только отредактировав дамп в текстовом редакторе, убрав в нем строку на создание БД.
Но можно вручную БД не создавать. Удалите ее, установите указанные выше галочки привилегий в блоке «Данные» и обязательно все в «Структура», затем импортируйте дамп.
7 Ответ от arbr 2008-11-26 17:49:38
- arbr
- Редкий гость
- Неактивен
- Зарегистрирован: 2008-11-24
- Сообщений: 11
Re: Выдаёт ошибку при импорте localhost.sql
У меня все получилось! , я просто из файла localhost убрал строчку на создание базы данных ( + пользователь) :
CREATE DATABASE `arbrspb_test` DEFAULT CHARACTER SET latin1 COLLATE latin1_swedish_ci;
USE `arbrspb_arbr`;
8 Ответ от zgordan.vv 2014-03-17 12:57:34
- zgordan.vv
- Новичок
- Неактивен
- Зарегистрирован: 2014-03-17
- Сообщений: 1
Re: Выдаёт ошибку при импорте localhost.sql
Всем спасибо, тоже убрал строку, получилось!
Страницы 1
Чтобы отправить ответ, вы должны войти или зарегистрироваться
Error No. : #1008
Error Type : Server Error
Error Code : SSQLSTATE: HY000 (ER_DB_DROP_EXISTS)
Error Message: Can't drop database '%s'; database doesn't exist Server Error
MySQL 1008 Error DROP
This is again a very Trivial MySQL error. The Server returns error code 1008 i.e. ER_DB_DROP_EXISTS when you try to execute a DROP Command to delete a database that does not exist.
SQL query:
drop database mydb
MySQL said: Documentation
#1008 - Can't drop database 'mydb'; database doesn't exist
If you have a script that contains DROP command check if its getting executed twice or the database really exists.