This is the 19th day of my participation in the Genwen Challenge

Wechat public number search [program yuan xiaozhuang], pay attention to the halfway program yuan how to rely on Python development to support the family ~

preface

Data storage is not the purpose, the purpose is to be able to take out or find out the stored data, and to be able to add, delete, change and check the data. This paper will introduce the operation of adding, deleting, changing and checking the records in the table in detail. The operation of records belongs to DML database operation language, and the operation of data can be realized through SQL, including inserting data into a table (INSERT), updating data in a table (update data), deleting data in a table (DELETE) and querying data (SELECT).

Add – insert

Table preparation

create table info ( 
	id int primary key auto_increment, 
	name varchar(6), 
	age int, 
	gender enum ( 'male'.'female' ) defaule 'male' 
	);
Copy the code

The most standard insert statement

INSERT INTO table name (INSERT INTO table name, INSERT INTO table name, INSERT INTO table name) VALUES (VALUES for field 1, VALUES for field 2...) ;
mysql> insert into info(name, age, gender) values ('xu'.18.'male');

mysql> select * from info;
+----+------+------+--------+
| id | NAME | age  | gender |
+----+------+------+--------+
|  1 | xu   |   18 | male   |
+----+------+------+--------+
1 row in set (0.00 sec)
Copy the code

Easy to write, insert data in order of all fields

INSERT INTO VALUES (1, 1, 2) ;
mysql> insert into info values (2.'lili'.20.'female');
Query OK, 1 row affected (0.00 sec)

mysql> select * from info;
+----+------+------+--------+
| id | NAME | age  | gender |
+----+------+------+--------+
|  1 | xu   |   18 | male   |
|  2 | lili |   20 | female |
+----+------+------+--------+
2 rows in set (0.00 sec)
 
Copy the code

Targeted data entry

INSERT INTO table name (select * from table 1) VALUES (VALUES for field 1, VALUES for field 2...)
mysql> insert into info (name, age) values ('jack'.30);
Query OK, 1 row affected (0.00 sec)

mysql> select * from info;
+----+------+------+--------+
| id | NAME | age  | gender |
+----+------+------+--------+
|  1 | xu   |   18 | male   |
|  2 | lili |   20 | female |
|  3 | jack |   30 | male   |
+----+------+------+--------+
3 rows in set (0.00 sec)
Copy the code

Enter multiple lines of data simultaneously

INSERT INTO table name (select * from table 1) VALUES (VALUES for field 1, VALUES for field 2...) (The corresponding value of field 1, the corresponding value of field 2...) . ;
mysql> insert into info (name, age) values ('python'.30), ('java'.40), ('go'.50);
Query OK, 3 rows affected (0.00 sec)
Records: 3  Duplicates: 0  Warnings: 0

mysql> select * from info;
+----+--------+------+--------+
| id | NAME   | age  | gender |
+----+--------+------+--------+
|  1 | xu     |   18 | male   |
|  2 | lili   |   20 | female |
|  3 | jack   |   30 | male   |
|  4 | python |   30 | male   |
|  5 | java   |   40 | male   |
|  6 | go     |   50 | male   |
+----+--------+------+--------+
6 rows in set (0.00 sec)

Copy the code

Delete – delete

Delete operation must carefully carefully again carefully !!!!

Drop all data in the table, but primary key increment does not stop
delete fromThe name of the table.Clear the table data and reset the primary key
truncateThe name of the table.-- Delete one or more entries from a table: delete from table name where condition; (The WHERE condition will be covered in more detail when we introduce queries.)
mysql> delete from info where id=1;
Query OK, 1 row affected (0.00 sec)

mysql> select * from info;
+----+--------+------+--------+
| id | NAME   | age  | gender |
+----+--------+------+--------+
|  2 | lili   |   20 | female |
|  3 | jack   |   30 | male   |
|  4 | python |   30 | male   |
|  5 | java   |   40 | male   |
|  6 | go     |   50 | male   |
+----+--------+------+--------+
5 rows in set (0.00 sec)

mysql> delete from info where age=30;
Query OK, 2 rows affected (0.00 sec)

mysql> select * from info;
+----+------+------+--------+
| id | NAME | age  | gender |
+----+------+------+--------+
|  2 | lili |   20 | female |
|  5 | java |   40 | male   |
|  6 | go   |   50 | male   |
+----+------+------+--------+
3 rows in set (0.00 sec)
Copy the code

Change – update

Modify records that already exist in the table.

Select * from table_name where table_name = 1 and table_name = 1 where table_name = 1 and table_name = 1;
Alter table 'where'; alter table 'where
mysql> update info set name='xxx', age=100;
Query OK, 3 rows affected (0.00 sec)
Rows matched: 3  Changed: 3  Warnings: 0

mysql> select * from info;
+----+------+------+--------+
| id | NAME | age  | gender |
+----+------+------+--------+
|  2 | xxx  |  100 | female |
|  5 | xxx  |  100 | male   |
|  6 | xxx  |  100 | male   |
+----+------+------+--------+
3 rows in set (0.00 sec)

Use the WHERE condition if you don't want to modify all records
mysql> update info set name='test', age=10 where id=2;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> select * from info;
+----+------+------+--------+
| id | NAME | age  | gender |
+----+------+------+--------+
|  2 | test |   10 | female |
|  5 | xxx  |  100 | male   |
|  6 | xxx  |  100 | male   |
+----+------+------+--------+
3 rows in set (0.00 sec)
Copy the code

Check – select

Tables are sometimes related to each other, especially in the same project, so query data is divided into single-table queries and multi-table queries. MySQL > select * from ‘mysql.sql’ where ‘world.sql’ = ‘mysql.sql’;

-- source. SQL file path
mysql> source  C:\Users\12801\Desktop\world.sql

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| book_manage        |
| mysql              |
| performance_schema |
| stu                |
| test               |
| world              |
+--------------------+
7 rows in set (0.00 sec)
Copy the code

Single table query

Query of the standard usage is need select cooperate with other clause in the query, because in the actual project development is not always need to query all of the data, but need some filter for filtering, query the needed data, and is not recommended in actual development all data query, because if too much data in a table, Memory may be insufficient oh ~ will cause the computer to freeze…

Select/FROM/WHERE /group by/having/order by/limit the order of these clauses is the default SQL order.

From clause

Which table to query data from.

-- select column name from table name;

- Scan all tables to query all data in the country table. Do not perform this operation because the computer may freeze if there is too much data
mysql>select * from country;  

Select * from country; select * from country; select * from country
mysql> select code, name from country;
Copy the code

The where clause

The WHERE clause needs to be used in conjunction with filter conditions, such as = > < <= >=! = and or not like in (between and)

-- Query all cities in China
select * from city where countrycode='CHN';

-- Information on cities with a population greater than 1 million in China
select * from city countrycode='CHN' and population>5000000; 

Select % from '%', '%', '%', '%', '%', '%';
select * from city where district like 'guang%';

-- Query all cities in China and the United States
select * from city where countrycode in ('CHN' ,'USA');

-- Query information about cities with a population greater than 100 million and less than 200 million
select * from city where population >1000000 and population <2000000;

-- Query information about cities with a population greater than 100 million and less than 200 million
select * from city where population between 1000000 and 2000000;
Copy the code

The group by clause

Group by is a group query. Depending on whether the WHERE filter condition is needed, group BY generally needs to be used together with aggregation function. The general logic of group BY is to take out the data of group and aggregation function parameters, sort them according to the grouping criteria, and de-duplicate the grouping criteria after sorting. Because the MySQL database does not allow one row of data to correspond to multiple rows of data (only_full_group_by strict mode), you need to use the aggregation function to consolidate multiple rows of data into one data corresponding to the grouping basis.

Aggregation function has a Max min sum () () () avg () – the average count () – count group_concat () – column turned, etc.

Count the total population of every country in the world
select countrycode ,sum(population) from  city  group by countrycode;

-- Count the population of each province in China
select district,sum(Population) from city  where countrycode='chn' group by district;

-- Count the name of each province in China, the number of people, the number of cities, and the name of each city.
select district, sum(population), count(id), group_concat(name) from world.city where countrycode='chn' group by district;
Copy the code

Having clause

The HAVING clause is similar to the WHERE clause except that having filters the grouped data.

-- Count the total population of each province in China, only print the total population less than 100
select district,sum(Population) from city where countrycode='chn'group by district having sum(Population) < 1000000 ;
Copy the code

order by

Output results in the specified order. The default value is from small to large, and desc is from large to small.

-- Count the total population of each province in China, print only the total population less than 100, ranked from the largest to the smallest.
select district,sum(Population) from city where countrycode='chn'
group by district having sum(Population) < 1000000 order by sum(population) desc;
Copy the code

limit

Display the results in pages, usually with order by

-- LIMIT N, M; -- Skip N lines and display M lines
-- LIMIT M OFFSET N; -- Skip N lines and display M lines
select district,sum(Population) from city where countrycode='chn'group by district having sum(Population) < 1000000 order by sum(population) desc limit 5 6; -- Count the total population of each province in China, only print the total population less than 100, from the largest to the smallest, only display the first 6 to 11.
Copy the code

Multi-table query

The required data comes from multiple tables, which cannot be satisfied by a single table. In fact, the data associated with multiple tables is merged into a new table to perform operations such as where group by clauses in the new table.

There are roughly three types of multi-table join query types, namely cartesian product, inner join, and outer join.

Cartesian product join

It is not recommended to merge data from multiple tables into a large table.

select * from teacher join course; 
Copy the code

Inner join

Inner join B on A.x =B.x; inner join B on A.x =B.x;

Select tno from teacher where tNO = course where tNO = course
select * from teacher (inner) join course on(where) teacher.tno=course.tno;
Copy the code

Left join/right join

Left JOIN All data in the left table is displayed, and only data associated with the left table is displayed in the right table. Right Join All data in the right table are displayed, while the left table displays only data associated with the right table. If no corresponding item is displayed, it is identified by NULL.

The effect is to force the table driver to reduce the number of next loops by using smaller tables (results sets with fewer results from queries) as the driver table.

select city.name, cpuntry.name, city.population from city left join country on city.countrycode=country.code and city.poplation<100;
Copy the code

The principle of driving tables

join… on… Realization principle: get one of the tables as the driver table, use the association condition (on condition) to compare with another table (inner cycle), if the two tables of the data will be spliced. When there is a large difference in the number of rows between the two tables, the small table (the result set with fewer results from the query) can be used as the driver table to optimize the query and reduce the number of next loops. For the inner join, there is no control over who is driving the table, which is entirely determined by the optimizer. If human intervention is needed to drive the table, it can be achieved through the outer join.

The driver table in a left JOIN is the left table, similar to the outer loop of a two-layer for loop, which forces the left table to be the driver table.

conclusion

The article was first published on the wechat public account Program Yuan Xiaozhuang, and synchronized with nuggets and Zhihu.

The code word is not easy, reprint please explain the source, pass by the little friends of the lovely little finger point like and then go (╹▽╹)