Links
Serveur
|
sudo mysql
mysql -u root -p
|
|
sudo mariadb-dump -x -e -B db1 -r /var/mariadb/dump/db1.sql
export MYSQL_PWD=mypwd
|
|
Si le mot de passe contient un des caractères suivant * ? [ < > & ; ! | $ ( ) il faut l'encadrer de quotes. |
~/.my.cnf
|
[mysqldump]
user=myuser
password=mypwd
|
Import
|
mysql -u utilisateur -pmot_de_passe -D base_de_données --verbose < fichier.sql > fichier.log
sudo mysql << EOF
use 'MyDb';
truncate MyTable;
source MyFile.sql;
EOF
|
|
use 'base-de-données';
source fichier.sql;
|
Executer une commande
|
mysql -h [ip] -D [database name] -u [user] -p[password] -e "commande mysql" -vvv
mysql -u [user] -p[password] << EOF
commandes mysql
EOF
mysql -u [user] -p'[password]'
|
|
cd /ou/se/trouve/mon/fichier
mysql -u utilisateur -pmot_de_passe -D base_de_données < mon_fichier.sql
|
|
use 'base-de-données';
source mon_fichier.sql
|
Create database and tables
Database
|
show databases;
create database 'db1' character set 'utf8mb4' collate 'utf8mb4_general_ci';
create database if not exists db1;
drop database ma_base_de_donnees;
drop database if exists ma_base_de_donnees;
use ma_base_de_donnees;
|
|
ALTER DATABASE `db1`
CHARACTER SET utf8mb4
COLLATE utf8mb4_unicode_ci;
SELECT default_character_set_name, default_collation_name
FROM information_schema.schemata
WHERE schema_name = "db_name";
|
|
SELECT table_schema AS "Database", SUM(data_length + index_length) / 1024 / 1024 / 1024 AS "Size (GB)" FROM information_schema.TABLES GROUP BY table_schema;
|
Tables
|
show tables;
show tables from MaBdD;
show columns from MyTable;
|
Create
|
create table if not exists user (
id tinyint unsigned auto_increment primary key,
name varchar(10) not null unique,
groupId tinyint unsigned not null references group (Id),
computedColumn int as (GroupId * 5) persistant,
index ux_user_name (name),
constraint fk_user_group_groupId
foreign key (groupId)
references group (id)),
constraint uc_user_name UNIQUE (name),
primary key (Id)
character set 'utf8mb4' collate 'utf8mb4_general_ci';
|
|
Columns with a primary key constraint are implicitly not null and have an index. |
Drop
|
drop table my_table;
select table_name from information_schema.tables
where table_schema = 'MaBdD' and table_name like 'xxx_%';
select group_concat(table_name) from information_schema.tables
where table_schema = 'MaBdD' and table_name like 'xxx_%';
select concat('drop table ', group_concat(table_name), ';')
from information_schema.tables where table_schema = 'MaBdD' and table_name like 'xxx_%';
SET @TABLES = (SELECT GROUP_CONCAT(table_name) FROM information_schema.tables WHERE table_schema = 'MaBdD' and table_name LIKE 'xxx_%');
PREPARE drop_statement FROM 'DROP TABLE @tables';
EXECUTE drop_statement USING @TABLES;
DEALLOCATE PREPARE drop_statement;
|
Alter
|
alter table `ma_table`
add `nouvelle_colonne` varchar(32) not null after `autre_colonne`;
alter table `my_table`
modify `my_column` datetime not null;
rename table `old_name`
to `new_name`;
alter table `my_table`
rename column `current_name` to `new_name`;
alter table `ma_table`
drop `ma_colonne`;
alter table `my_table`
add constraint `uc_my_table_my_column` UNIQUE (`my_column`);
alter table `my_table`
drop constraint `uc_my_table_my_column`;
|
Comptes utilisateur
|
create user 'mon_compte'@'localhost' identified by 'mon_mot_de_passe';
create user 'mon_compte'@'localhost' identified with 'unix_socket';
drop user 'mon_compte'@'localhost';
select host, user, password, plugin from mysql.user;
grant select,insert,update on MyDb.* to 'MyUser'@'localhost';
grant all on ma_base_de_donnees.* to 'mon_compte'@'localhost';
grant all on *.* to 'mon_compte'@'localhost' with grant option;
revoke all privileges on ma_base_de_donnees.* from 'mon_compte'@'localhost';
show grants FOR 'mon_compte'@'localhost';
set password for 'mon_compte'@'localhost' = password('...');
flush privileges;
|
|
Échapper les \ avec un deuxième \ dans les mots de passe. |
|
sc-stop mysql
sudo systemctl set-environment MYSQLD_OPTS="--skip-networking --skip-grant-tables"
sc-start mysql
sudo mysql -u root
mysql
|
|
flush privileges;
set password for 'mon_compte'@'localhost' = password('...');
flush privileges;
exit;
|
|
sudo systemctl unset-environment MYSQLD_OPTS
sudo systemctl revert mysql
sudo killall -u mysql
sudo systemctl restart mysql.service
mysql -u mon_compte -p
|
|
Account with empty username may mask the user you use to login.
You should drop all the account with empty user names. |
Type
|
Bytes
|
Minimum Value
|
Maximum Value
|
TINYINT |
1 |
-128 |
127
|
SMALLINT |
2 |
-32'768 |
32'767
|
MEDIUMINT |
3 |
-8'388'608 |
8'388'607
|
INT |
4 |
-2'147'483'648 |
2'147'483'647
|
BIGINT |
8 |
-9'223'372'036'854'775'808 |
9'223'372'036'854'775'807
|
Data Type
|
“Zero” Value
|
Range
|
DATE |
'0000-00-00' |
'1000-01-01' to '9999-12-31'
|
TIME |
'00:00:00'
|
DATETIME |
'0000-00-00 00:00:00' |
'1000-01-01 00:00:00' to '9999-12-31 23:59:59'
|
TIMESTAMP |
'0000-00-00 00:00:00' |
'1970-01-01 00:00:01' UTC to '2038-01-19 03:14:07' UTC
|
YEAR |
0000
|
|
set @today = NOW();
set @first_day = DATE_FORMAT(@today, '%Y-%m-01');
set @last_day = LAST_DAY(@today);
set @previous_month = @today - INTERVAL 1 MONTH;
set @diff_in_days = DATEDIFF(@date1, @date2);
set @diff_in_days = TIMESTAMPDIFF(DAY, @date2, @date1);
set @formatted_date = DATE_FORMAT(@date1, '%e %b %Y %H:%i');
|
|
create table if not exists table1 (
type Enum('buy', 'sell') not null
);
select *
from table1
where type = 2;
|
|
create table iptable (
ip binary(4) not null
);
insert into iptable (ip)
values (inet6_aton('127.0.0.1'));
select inet6_ntoa(ip)
FROM iptable;
|
Charset et Collation
|
USE MyDb;
SELECT @@character_set_database, @@collation_database;
SHOW TABLE STATUS;
SHOW FULL COLUMNS FROM <table_name>;
ALTER DATABASE <db_name> CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
ALTER TABLE <table_name> CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
ALTER TABLE <table_name> MODIFY <column_name> VARCHAR(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
|
Ajouter / modifier des données
|
insert into my_table (column1, column2)
values ('value1-1', 'value1-2'),
('value2-1', 'value2-2');
insert into table1 (column1, column2)
select
column3,
(
select id
from table3
where name = 'xxx'
) as table3_id
from table2;
insert into table1 (column1, column2)
select 'value1', 'value2'
where not exists
(
select * from table1
where column1 = 'value1'
);
SET @id = LAST_INSERT_ID();
|
|
update my_table
set column1 = 10,
column2 = column2 + 1
where column3 = 0;
update my_table as dest,
(
select Column1, Column2
from AnotherTable
) as src
set dest.Column1 = src.Column1
where dest.Column2 = src.Column2;
// update some rows only, filter with a join to anoter table
update table1
join
(
select t1.id
from table1 as t1
join table2 as t2
on t2.id = t1.id
where t2.col1 = 'value'
group by t1.id
) as j1
on j1.id = table1.id
set colX = 'valueX';
|
Delete
|
delete from my_table
where column1 = 'value1';
truncate table my_table;
|
|
CREATE TRIGGER MyTrigger AFTER INSERT ON MyTable
FOR EACH ROW
UPDATE AnotherTable
SET Column1 = NEW.Column1
WHERE Column2 = NEW.Column2;
drop trigger MyTrigger;
show triggers
like 'MyTable';
|
Requêtes sur les données
Limiter le nombre de résultats
|
select colonne from ma_table
limit 10
|
Multi select
|
select
'Value1',
(
select count(*) from table1
) as count_table1;
|
|
SELECT year, country, product, profit,
SUM(profit) OVER() AS total_profit,
SUM(profit) OVER(PARTITION BY country) AS country_profit
FROM sales
ORDER BY country, year, product, profit;
|
|
Standard SQL doesn't allow you to refer to a column alias in a WHERE clause.
This restriction is imposed because when the WHERE code is executed, the column value may not yet be determined. (doc) |
|
select Column1 as c1
from MyTable
where c1 > 10
select Column1 as c1
from MyTable
having c1 > 10
|
|
WHERE is applied before GROUP BY, HAVING is applied after. |
|
WITH cte AS
(
SELECT a
FROM table1
WHERE b >= 'c'
)
SELECT *
FROM table2, cte
WHERE table2.c = cte.a;
|
Temporary tables are session specific, they are dropped automatically when the connection is closed.
|
DROP TEMPORARY TABLE IF EXISTS temp1;
CREATE TEMPORARY TABLE temp1 (
column1 VARCHAR(255),
column2 INT
);
CREATE TEMPORARY TABLE temp2
SELECT * FROM table2
LIMIT 0;
INSERT INTO temp1
SELECT 'Value1', 1;
DROP TEMPORARY TABLE temp1;
|
Configuration
|
sudo mysql_secure_installation
|
Pour une utilisation avec php, activez l'un des trois modules:
/etc/php/php.ini
|
extension=mysqli.so
|
|
- mysql : driver de base pour BdD MySQL
- mysqli : nouvelles fonctionnalités par rapport à mysql : OO-API + Support new features of MySQL >= 4.1
- pdo_mysql : même nouvelles fonctionnalités que mysqli + PDO : même API quelque soit le type de BdD utilisé
|
/etc/mysql/my.cnf
|
[client]
port = 3306
skip-networking
[mysqld]
skip-external-locking
max_connections = 200
read_buffer_size = 1M
sort_buffer_size = 1M
key_buffer_size = 512M
|
/etc/mysql/my.cnf
|
innodb_data_home_dir = /var/lib/mysql
innodb_data_file_path = ibdata1:12M:autoextend:max:500M
innodb_log_group_home_dir = /var/lib/mysql
innodb_buffer_pool_size = 1G
innodb_log_file_size = 250M
innodb_log_buffer_size = 8M
innodb_flush_log_at_trx_commit = 1
innodb_lock_wait_timeout = 50
|
|
SELECT (PagesData*PageSize)/POWER(1024,3) DataGB FROM
(SELECT variable_value PagesData
FROM information_schema.global_status
WHERE variable_name='Innodb_buffer_pool_pages_data') A,
(SELECT variable_value PageSize
FROM information_schema.global_status
WHERE variable_name='Innodb_page_size') B;
|
Variables
|
show global status;
show variables;
|
Replication de données de la bdd master vers une bdd slave en asynchrone.
Log
|
journalctl -b | grep mysqld
journalctl -f
sudo systemctl restart mysqld
|
|
PURGE BINARY LOGS BEFORE DATE(NOW() - INTERVAL 3 DAY) + INTERVAL 0 SECOND;
|
/etc/mysql/my.cnf
|
expire_logs_days = 10
max_binlog_size = 100M
innodb_log_file_size = 64M
|
Audit
Permet de loguer toutes les requêtes.
|
SHOW VARIABLES LIKE "general_log%";
SET GLOBAL general_log_file = '/var/run/mysqld/mysqld.log';
SET GLOBAL general_log = 'ON';
SET GLOBAL general_log = 'OFF';
|
|
sudo pacman -S mariadb
sudo mysql_install_db --user=mysql --basedir=/usr --datadir=/var/lib/mysql
sc-start mysqld
sudo mysql_secure_installation
|
|
mysqlcheck -u root -p --check --databases [nom de la base de données]
|
Erreurs
Specified key was too long; max key length is 767 bytes
Les indexes InnoDB ont une taille maximale de 767 octets.
Encoding
|
Nombre d'octets par caractère
|
Exemple
|
latin1 |
1 |
varchar(255) → 255 octets
|
utf8 |
3 |
varchar(255) → 765 octets
|
utf8mb4 |
4 |
varchar(191) → 764 octets
|
Error: 145 Table is marked as crashed and should be repaired
|
check table Ma_Table;
repair table Ma_Table;
|
REPAIR TABLE
|
mysqlcheck MaBaseDeDonnées -u Utilisateur -pMotDePasse
|
mysqlcheck
1 client is using or hasn't closed the table properly
|
myisamchk --silent --fast /var/lib/mysql/Ma_Base_de_Donnée/*.MYI
myisamchk --silent --force --fast --update-state \
--key_buffer_size=64M --sort_buffer_size=64M --read_buffer_size=1M --write_buffer_size=1M /var/lib/mysql/Ma_Base_de_Donnée/*.MYI
|
|
La commande myisamchk doit être lancée avec l'utilisateur root afin d'avoir accès au contenu du dossier /var/lib/mysql |
myisamchk
MySQL Workbench
MySQL Workbench : design de BdD
PK |
Primary Key
|
NN |
Not Null
|
BIN |
Binary (stores data as binary strings. There is no character set so sorting and comparison is based on the numeric values of the bytes in the values.)
|
UN |
Unsigned (non-negative numbers only. so if the range is -500 to 500, instead its 0 - 1000, the range is the same but it starts at 0)
|
UQ |
Create/remove Unique Key
|
ZF |
Zero-Filled (if the length is 5 like INT(5) then every field is filled with 0’s to the 5th value. 12 = 00012, 400 = 00400, etc. )
|
AI |
Auto Increment
|
G |
Generated column. i.e. value generated by a formula based on the other columns
|
|
alter table ma_table engine=InnoDB;
SELECT CONCAT('ALTER TABLE `', table_name, '` ENGINE=InnoDB;') AS sql_statements
FROM information_schema.tables AS tb
WHERE table_schema = 'ma_database'
AND `ENGINE` = 'MyISAM'
AND `TABLE_TYPE` = 'BASE TABLE'
ORDER BY table_name;
|
Windows
- C:\Program Files\MariaDB 11.3\data\my.ini
Allow a connection with the current Windows user name. Equivalent to the UNIX SOCKET.
|
INSTALL SONAME 'auth_named_pipe';
SHOW GLOBAL VARIABLES LIKE 'named_pipe';
CREATE USER [WindowsUser]@localhost IDENTIFIED VIA named_pipe;
|
C:\Program Files\MariaDB 11.3\data\my.ini
|
[mysqld]
enable-named-pipe
socket=MySQL
|
|
mariadb --protocol=PIPE
|
|
echo %USERNAME%
|
|
Connection String: "server=localhost;database=MyDb;user=WindowsUser;protocol=pipe" |
Features by version
Version
|
Features
|
10.6 |
- Implement SQL-standard SELECT ... OFFSET ... FETCH
|
10.2 |
|