当前位置: 首页 > news >正文

板凳-------Mysql cookbook学习 (三)

1.22 使长输出行更具可读性

mysql> show full columns from limbs;
+-------+-------------+--------------------+------+-----+---------+-------+---------------------------------+---------+
| Field | Type        | Collation          | Null | Key | Default | Extra | Privileges                      | Comment |
+-------+-------------+--------------------+------+-----+---------+-------+---------------------------------+---------+
| thing | varchar(20) | utf8mb4_0900_ai_ci | YES  |     | NULL    |       | select,insert,update,references |         |
| legs  | int         | NULL               | YES  |     | NULL    |       | select,insert,update,references |         |
| arms  | int         | NULL               | YES  |     | NULL    |       | select,insert,update,references |         |
+-------+-------------+--------------------+------+-----+---------+-------+---------------------------------+---------+
3 rows in set (0.11 sec)mysql> show full columns from limbs\g
+-------+-------------+--------------------+------+-----+---------+-------+---------------------------------+---------+
| Field | Type        | Collation          | Null | Key | Default | Extra | Privileges                      | Comment |
+-------+-------------+--------------------+------+-----+---------+-------+---------------------------------+---------+
| thing | varchar(20) | utf8mb4_0900_ai_ci | YES  |     | NULL    |       | select,insert,update,references |         |
| legs  | int         | NULL               | YES  |     | NULL    |       | select,insert,update,references |         |
| arms  | int         | NULL               | YES  |     | NULL    |       | select,insert,update,references |         |
+-------+-------------+--------------------+------+-----+---------+-------+---------------------------------+---------+
3 rows in set (0.01 sec)

1.23 控制mysql的繁冗级别

D:\software\MySql\bin>echo "select now()" | mysql -u root -proot
mysql: [Warning] Using a password on the command line interface can be insecure.
ERROR 1064 (42000) at line 1: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '"select now()"' at line 1

这个错误是因为在 Windows 的 echo 命令中,双引号被直接传递给了 MySQL,导致语法错误

D:\software\MySql\bin>echo select now() | mysql -u root -proot
mysql: [Warning] Using a password on the command line interface can be insecure.
now()
2025-05-18 09:54:49D:\software\MySql\bin>mysql -u root -proot -e "select now()"
mysql: [Warning] Using a password on the command line interface can be insecure.
+---------------------+
| now()               |
+---------------------+
| 2025-05-18 09:56:46 |
+---------------------+-v, --verbose       Write more. (-v -v -v gives the table output format).
D:\software\MySql\bin>echo select now() | mysql -u root -proot -v
mysql: [Warning] Using a password on the command line interface can be insecure.
--------------
select now()
--------------now()
2025-05-18 09:59:14D:\software\MySql\bin>echo select now() | mysql -u root -proot -vv
mysql: [Warning] Using a password on the command line interface can be insecure.
--------------
select now()
--------------now()
2025-05-18 09:59:27
1 row in setByeD:\software\MySql\bin>echo select now() | mysql -u root -proot -vvv
mysql: [Warning] Using a password on the command line interface can be insecure.
--------------
select now()
--------------+---------------------+
| now()               |
+---------------------+
| 2025-05-18 09:59:36 |
+---------------------+
1 row in set (0.00 sec)Bye
-s, --silent        Be more silent. Print results with a tab as separator,each row on new line.
D:\software\MySql\bin>echo select now() | mysql -u root -proot -s
mysql: [Warning] Using a password on the command line interface can be insecure.
2025-05-18 10:05:11D:\software\MySql\bin>echo select now() | mysql -u root -proot -sss
mysql: [Warning] Using a password on the command line interface can be insecure.
2025-05-18 10:05:18

1.24 记录交互式的mysql会话

  --tee=name          Append everything into outfile. See interactive help (\h)also. Does not work in batch mode. Disable with--disable-tee. This option is disabled by default.

————————————————
–tee=D:\sql\Mysql_learning\tmp.out
作用:开启 日志记录功能,将客户端的输入(SQL 语句)和输出(查询结果、错误信息等)实时写入指定文件 tmp.out。
细节:
文件路径:需确保路径存在且当前用户有写入权限。
日志内容:包括连接成功后的所有操作记录,常用于调试、审计或学习复盘(如本例中用于记录 MySQL 学习过程)。
关闭日志:可执行 notee 命令停止记录,或退出客户端自动终止。 \T或 \t 来开启或关闭 tee的输出。
开启日志记录:将后续所有操作及结果保存到 D:\sql\Mysql_learning\tmp.out 文件中。
进入交互模式:等待用户输入 SQL 语句,执行后显示结果并记录到日志文件。
典型使用场景
学习与调试:记录 SQL 练习过程,方便复盘和排查错误。
审计与追溯:在生产环境中记录关键操作,用于合规性检查或问题追溯(需注意权限和安全性)。
批量操作记录:配合脚本执行批量 SQL 时,保存执行过程和结果。

D:\software\MySql\bin>mysql -u root -proot --tee=D:\sql\Mysql_learning\tmp.out cookbook
mysql: [Warning] Using a password on the command line interface can be insecure.
Logging to file 'D:\sql\Mysql_learning\tmp.out'
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 74
Server version: 8.0.40 MySQL Community Server - GPLCopyright (c) 2000, 2024, Oracle and/or its affiliates.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> \T D:\sql\Mysql_learning\tmp.out
Logging to file 'D:\sql\Mysql_learning\tmp.out'
mysql> \t D:\sql\Mysql_learning\tmp.out

Outfile disabled.

mysql  Ver 8.0.40 for Win64 on x86_64 (MySQL Community Server - GPL)Connection id:          74
Current database:       cookbook
Current user:           root@localhost
SSL:                    Cipher in use is TLS_AES_256_GCM_SHA384
Using delimiter:        ;
Server version:         8.0.40 MySQL Community Server - GPL
Protocol version:       10
Connection:             localhost via TCP/IP
Server characterset:    utf8mb4
Db     characterset:    utf8mb4
Client characterset:    gbk
Conn.  characterset:    gbk
TCP port:               3306
Binary data as:         Hexadecimal
Uptime:                 8 days 13 hours 28 min 20 sec

Threads: 3 Questions: 17190 Slow queries: 0 Opens: 1319 Flush tables: 4 Open tables: 37 Queries per second avg: 0.023

ERROR:
Unknown command ‘\M’.
Outfile disabled.
-> \c
1.25 以之前执行的语句创建mysql脚本
通过在mysql中使用–tee命令选项或\T命令可以记录mysql 会话的所有或部分。
开启日志:\T /path/to/new_logfile.log
关闭日志:\t(小写 t)

mysql> \T C:\mysql\part1.log      -- 开始记录到 part1.log
mysql> SELECT * FROM users;       -- 查询会被记录
mysql> \T C:\mysql\part2.log      -- 切换到新日志文件
mysql> INSERT INTO orders ...     -- 此操作记录到 part2.log
mysql> \t                         -- 停止记录

两者的核心区别
特性 --tee 选项 \T 命令
生效时机 客户端启动时一次性设置 会话中随时启用 / 禁用
日志文件切换 无法中途更换文件 可随时切换到新文件
适用场景 完整记录整个会话 分段记录或选择性记录
命令形式 命令行参数(非 SQL 语法) SQL 会话中的命令(以 \ 开头)

\o 命令 -o, --one-database  Ignore statements except those that occur while thedefault database is the one named at the command line.
将后续输出仅写入文件,不显示在终端(与 --tee/  \T 的区别在于不显示到屏幕)。
sql
mysql> \o C:\mysql\silent_output.log
mysql> SELECT * FROM large_table;  -- 结果只写入文件,不显示
system 命令
在不退出 MySQL 会话的情况下执行系统命令(如查看日志文件大小)。
sql
mysql> system ls -lh /var/log/mysql/

1.26 在sql语句中使用用户自定义的变量管理customers表。

  1. 创建customers表
    首先,你需要一个customers表。以下是一个创建表的示例SQL语句:
mysql> CREATE TABLE IF NOT EXISTS customers (->     cust_id VARCHAR(255) NOT NULL,->     first_name VARCHAR(100) DEFAULT NULL,->     last_name VARCHAR(100) DEFAULT NULL,->     email VARCHAR(255) UNIQUE DEFAULT NULL,->     phone_number VARCHAR(20) DEFAULT NULL,->     address_line_1 VARCHAR(255) DEFAULT NULL,->     address_line_2 VARCHAR(255) DEFAULT NULL,->     city VARCHAR(100) DEFAULT NULL,->     state_province VARCHAR(100) DEFAULT NULL,->     postal_code VARCHAR(20) DEFAULT NULL,->     country VARCHAR(100) DEFAULT NULL,->     created_at DATETIME DEFAULT CURRENT_TIMESTAMP,->     updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,->     PRIMARY KEY (cust_id)-> );
Query OK, 0 rows affected (0.11 sec)mysql> -- 向 Customers 表中插入示例数据
mysql> INSERT INTO `Customers` (`cust_id`, `first_name`, `last_name`, `email`, `phone_number`, `address_line_1`, `city`, `state_province`, `postal_code`, `country`) VALUES-> ('CUST001', 'John', 'Doe', 'john.doe@example.com', '+1-800-123-4567', '123 Main St.', 'Springfield', 'IL', '62704', 'USA'),-> ('CUST002', 'Jane', 'Smith', 'jane.smith@example.com', '+1-800-987-6543', '456 Elm St.', 'Shelbyville', 'KY', '40065', 'USA'),-> ('CUST003', 'Alice', 'Johnson', 'alice.johnson@example.com', '+1-800-555-1212', '789 Oak Ave.', 'Capital City', 'TX', '76101', 'USA');
Query OK, 3 rows affected (0.02 sec)
Records: 3  Duplicates: 0  Warnings: 0

代替

CREATE TABLE customers (customer_id INT AUTO_INCREMENT PRIMARY KEY,first_name VARCHAR(50) NOT NULL,last_name VARCHAR(50) NOT NULL,email VARCHAR(100) NOT NULL,phone VARCHAR(20),address VARCHAR(255),city VARCHAR(50),state VARCHAR(50),zip_code VARCHAR(10),created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
  1. 插入数据到customers表
    向表中插入数据可以使用以下SQL命令:
INSERT INTO customers (first_name, last_name, email, phone, address, city, state, zip_code) 
VALUES ('John', 'Doe', 'john.doe@example.com', '123-456-7890', '123 Main St', 'Anytown', 'CA', '12345');
  1. 查询customers表中的数据
    查询所有客户:

SELECT * FROM customers;
查询特定条件的客户,例如按城市查询:

SELECT * FROM customers WHERE city = ‘Anytown’;
4. 更新customers表中的数据
更新特定客户的邮箱:

UPDATE customers SET email = ‘new.email@example.com’ WHERE customer_id = 1;
5. 删除customers表中的数据
删除特定客户:

DELETE FROM customers WHERE customer_id = 1;

mysql> select @max_limbs := MAX(arms+legs) from limbs;
+------------------------------+
| @max_limbs := MAX(arms+legs) |
+------------------------------+
|                          100 |
+------------------------------+
1 row in set, 1 warning (0.01 sec)mysql> SELECT LAST_INSERT_ID() AS new_customer_id;
+-----------------+
| new_customer_id |
+-----------------+
|               1 |
+-----------------+
1 row in set (0.00 sec)mysql> SELECT MAX(customer_id) FROM customers;
+------------------+
| MAX(customer_id) |
+------------------+
|                1 |
+------------------+
1 row in set (0.00 sec)mysql> SELECT customer_id FROM customers-> WHERE first_name = 'John' AND last_name = 'Doe';
+-------------+
| customer_id |
+-------------+
|           1 |
+-------------+
1 row in set (0.00 sec)mysql> SELECT @john_id := customer_id FROM customers-> WHERE first_name = 'John' AND last_name = 'Doe';
+-------------------------+
| @john_id := customer_id |
+-------------------------+
|                       1 |
+-------------------------+
1 row in set, 1 warning (0.00 sec)

完整的示例:

mysql> -- 插入新客户
mysql> INSERT INTO customers (first_name, last_name, email)-> VALUES ('Jane', 'Smith', 'jane.smith@example.com');
Query OK, 1 row affected (0.01 sec)mysql>
mysql> -- 获取新插入的ID
mysql> SET @new_id = LAST_INSERT_ID();
Query OK, 0 rows affected (0.00 sec)mysql>
mysql> -- 使用变量查询
mysql> SELECT * FROM customers WHERE customer_id = @new_id;
+-------------+------------+-----------+------------------------+-------+---------+------+-------+----------+---------------------+
| customer_id | first_name | last_name | email                  | phone | address | city | state | zip_code | created_at          |
+-------------+------------+-----------+------------------------+-------+---------+------+-------+----------+---------------------+
|           2 | Jane       | Smith     | jane.smith@example.com | NULL  | NULL    | NULL | NULL  | NULL     | 2025-05-18 11:26:49 |
+-------------+------------+-----------+------------------------+-------+---------+------+-------+----------+---------------------+
1 row in set (0.00 sec)
Windows10系统安装perl命令
https://blog.csdn.net/m0_37542524/article/details/130095555
mysql> select @name := thing from limbs where legs = 0;
+----------------+
| @name := thing |
+----------------+
| squid          |
| octopus        |
| fish           |
| phonograph     |
| fish           |
| phonograph     |
| squid          |
+----------------+
7 rows in set, 1 warning (0.00 sec)mysql> select @name;
+-------+
| @name |
+-------+
| squid |
+-------+
1 row in set (0.00 sec)mysql> select @name2 := thing from limbs where legs < 0;
Empty set, 1 warning (0.00 sec)mysql> select @name2;
+--------+
| @name2 |
+--------+
| NULL   |
+--------+
1 row in set (0.00 sec)mysql> set @sum = 4 + 7;
Query OK, 0 rows affected (0.00 sec)mysql> select @sum;
+------+
| @sum |
+------+
|   11 |
+------+
1 row in set (0.00 sec)mysql> set @max_limbs = (select max(arms + legs) from limbs);
Query OK, 0 rows affected (0.00 sec)mysql> select @max_limbs;
+------------+
| @max_limbs |
+------------+
|        100 |
+------------+
1 row in set (0.00 sec)mysql> set @x = 1, @x = 2; select @x, @x;
Query OK, 0 rows affected (0.00 sec)+------+------+
| @x   | @x   |
+------+------+
|    2 |    2 |
+------+------+
1 row in set (0.00 sec)

1.27 为查询输出行计数

mysql -u root -proot --skip-column-names -e "select thing, arms from limbs cookbook" | cat -n
其中的 cat -n 是 Linux/macOS 系统用于显示文件内容并添加行号的命令,Windows 系统不支持。
使用 Windows 等效命令 more +n
mysql -u root -proot --skip-column-names -e "select thing, arms from limbs" cookbook | more +n
more +n:显示内容并添加行号(+n 表示从第 n 行开始显示,省略则默认从第 1 行开始)。

– 假设limbs是表名,cookbook是数据库名,应在连接时指定数据库:

D:\software\MySql\bin>mysql -u root -proot --skip-column-names -e "select thing, arms from limbs" cookbook | more +1
mysql: [Warning] Using a password on the command line interface can be insecure.
insect  0
squid   10
octopus 8
fish    0
centipede       0
table   0
armchair        2
phonograph      1
tripod  0
Peg Leg Pete    2
space alien     NULL
armchair        2
centipede       0
fish    0
human   2
insect  0
Peg Leg Pete    2
phonograph      1
space alien     NULL
squid   10
table   0
tripod  0-D, --database=name Database to use.--default-character-set=nameSet the default character set.--delimiter=name    Delimiter to be used.--enable-cleartext-pluginEnable/disable the clear text authentication plugin.
————————————————
bash
mysql -u root -proot --skip-column-names -D cookbook -e "select thing, arms from limbs"
D:\software\MySql\bin>mysql -u root -proot --skip-column-names -D cookbook -e "select thing, arms from limbs"
mysql: [Warning] Using a password on the command line interface can be insecure.
+--------------+------+
|        human | 2    |
|       insect | 0    |
|        squid | 10   |
|      octopus | 8    |
|         fish | 0    |
|    centipede | 0    |
|        table | 0    |
|     armchair | 2    |
|   phonograph | 1    |
|       tripod | 0    |
| Peg Leg Pete | 2    |
|  space alien | NULL |
|     armchair | 2    |
|    centipede | 0    |
|         fish | 0    |
|        human | 2    |
|       insect | 0    |
| Peg Leg Pete | 2    |
|   phonograph | 1    |
|  space alien | NULL |
|        squid | 10   |
|        table | 0    |
|       tripod | 0    |
+--------------+------+

只需查看结果的行号,可在 SQL 中直接实现:

mysql> SELECT @row:=@row+1 AS row_num, thing, arms-> FROM limbs, (SELECT @row:=0) AS t;
+---------+--------------+------+
| row_num | thing        | arms |
+---------+--------------+------+
|       1 | human        |    2 |
|       2 | insect       |    0 |
|       3 | squid        |   10 |
|       4 | octopus      |    8 |
|       5 | fish         |    0 |
|       6 | centipede    |    0 |
|       7 | table        |    0 |
|       8 | armchair     |    2 |
|       9 | phonograph   |    1 |
|      10 | tripod       |    0 |
|      11 | Peg Leg Pete |    2 |
|      12 | space alien  | NULL |
|      13 | armchair     |    2 |
|      14 | centipede    |    0 |
|      15 | fish         |    0 |
|      16 | human        |    2 |
|      17 | insect       |    0 |
|      18 | Peg Leg Pete |    2 |
|      19 | phonograph   |    1 |
|      20 | space alien  | NULL |
|      21 | squid        |   10 |
|      22 | table        |    0 |
|      23 | tripod       |    0 |
+---------+--------------+------+
23 rows in set, 2 warnings (0.01 sec)

使用用户变量,表达式对于查询的每一行都进行计算。

mysql> set @n = 0;
Query OK, 0 rows affected (0.00 sec)mysql> select @n := @n+1 as rownum, thing, arms, legs from limbs;
+--------+--------------+------+------+
| rownum | thing        | arms | legs |
+--------+--------------+------+------+
|      1 | human        |    2 |    2 |
|      2 | insect       |    0 |    6 |
|      3 | squid        |   10 |    0 |
|      4 | octopus      |    8 |    0 |
|      5 | fish         |    0 |    0 |
|      6 | centipede    |    0 |  100 |
|      7 | table        |    0 |    4 |
|      8 | armchair     |    2 |    4 |
|      9 | phonograph   |    1 |    0 |
|     10 | tripod       |    0 |    3 |
|     11 | Peg Leg Pete |    2 |    1 |
|     12 | space alien  | NULL | NULL |
|     13 | armchair     |    2 |    4 |
|     14 | centipede    |    0 |   99 |
|     15 | fish         |    0 |    0 |
|     16 | human        |    2 |    2 |
|     17 | insect       |    0 |    6 |
|     18 | Peg Leg Pete |    2 |    1 |
|     19 | phonograph   |    1 |    0 |
|     20 | space alien  | NULL | NULL |
|     21 | squid        |   10 |    0 |
|     22 | table        |    0 |    4 |
|     23 | tripod       |    0 |    3 |
+--------+--------------+------+------+
23 rows in set, 1 warning (0.00 sec)1.28 将mysql用作计算器
mysql> select(17 + 23) / sqrt(64);
+----------------------+
| (17 + 23) / sqrt(64) |
+----------------------+
|                    5 |
+----------------------+
1 row in set (0.00 sec)mysql> select 'ABC'= 'abc';
+--------------+
| 'ABC'= 'abc' |
+--------------+
|            1 |
+--------------+
1 row in set (0.00 sec)mysql> set @daily_room_charge = 100.00;
Query OK, 0 rows affected (0.00 sec)mysql> set @num_of_nights = 3;
Query OK, 0 rows affected (0.00 sec)mysql> set @tax_precent = 8;
Query OK, 0 rows affected (0.00 sec)mysql> set @total_room_charge = @daily_room_charge * @num_of_nights;
Query OK, 0 rows affected (0.00 sec)mysql> set @tax = (@total_room_charge * @tax_precent)/100;
Query OK, 0 rows affected (0.00 sec)mysql> set @total = @total_room_charge + @tax;
Query OK, 0 rows affected (0.00 sec)mysql> select @total;
+---------------+
| @total        |
+---------------+
| 324.000000000 |
+---------------+
1 row in set (0.00 sec)

1.29 在shell脚本中使用mysql
Windows 系统不支持 Linux 命令(如grep)导致的。
D:\software\MySql\bin>mysql -u root -proot -e status | grep “^uptime”
‘grep’ 不是内部或外部命令,也不是可运行的程序
或批处理文件。

D:\software\MySql\bin>mysql -u root -proot -e "status" | findstr /B "Uptime"
mysql: [Warning] Using a password on the command line interface can be insecure.
Uptime:                 8 days 18 hours 37 min 16 secD:\software\MySql\bin>mysql -u root -proot -e "SHOW GLOBAL STATUS LIKE 'Uptime';"
mysql: [Warning] Using a password on the command line interface can be insecure.
+---------------+--------+
| Variable_name | Value  |
+---------------+--------+
| Uptime        | 758359 |
+---------------+--------+
1.使用 PowerShell(最简单)
按 Win + X 选择 PowerShell(管理员)。
PS D:\software\MySql\bin> .\mysql -u root -proot -Bse "SHOW GLOBAL STATUS LIKE 'Uptime';" | ForEach-Object { [regex]::Match($_, "\d+").Value }
mysql: [Warning] Using a password on the command line interface can be insecure.
758695
2.使用 CMD 纯命令(无需额外工具)
D:\software\MySql\bin>mysql -u root -proot -e "SHOW GLOBAL STATUS LIKE 'Uptime';" | findstr /C:"Uptime" | findstr /r "[0-9]"
mysql: [Warning] Using a password on the command line interface can be insecure.
Uptime  758881

3.将 MySQL 的 bin 目录添加到系统环境变量(推荐)
这样可以在任意目录直接使用mysql命令,无需每次指定路径:
右键点击 “此电脑” → 属性 → 高级系统设置 → 环境变量。
在系统变量中找到Path,点击编辑。
新建并添加 MySQL 的bin目录路径:D:\software\MySql\bin。
确认保存,重启 PowerShell。
(!未操作成功,以待日后来处理 20250518)

使用完整路径
使用 & 符号作为调用操作符,告诉 PowerShell 将后面的内容作为命令执行。

PS C:\windows\system32> &D:\software\MySql\bin\mysql -u root -proot -Bse "SHOW GLOBAL STATUS LIKE 'Uptime';" | ForEach-Object { [regex]::Match($_, "\d+").Value }
mysql: [Warning] Using a password on the command line interface can be insecure.
761228
PS C:\windows\system32> # 交互式输入密码(不显示在命令历史中)
PS C:\windows\system32> &D:\software\MySql\bin\mysql -u root -p -Bse "SHOW GLOBAL STATUS LIKE 'Uptime';" | ForEach-Object { [regex]::Match($_, "\d+").Value }
Enter password: ****
761426
# 查看 MySQL 版本
PS C:\windows\system32> &D:\software\MySql\bin\mysql -u root -p -Bse "SELECT VERSION();"
Enter password: ****
8.0.40
# 获取服务器负载信息
PS C:\windows\system32> &D:\software\MySql\bin\mysql -u root -p -Bse "SHOW GLOBAL STATUS LIKE 'Threads_running';"
Enter password: ****
Threads_running 2
mysql> select count(*) as 'new log entries:'-> from log_tbl-> where date_added = date_sub(curdate(), interval 1 day);
ERROR 1146 (42S02): Table 'cookbook.log_tbl' doesn't exist

这个错误表明您正在尝试查询一个不存在的表 log_tbl。让我们一步步解决这个问题:

解决方案

  1. 首先确认数据库中存在的表
    sql
    SHOW TABLES;
  2. 如果您确实需要 log_tbl 表,请先创建它
sql
CREATE TABLE IF NOT EXISTS log_tbl (id INT AUTO_INCREMENT PRIMARY KEY,log_message TEXT,date_added DATE,-- 其他您需要的字段INDEX (date_added)  -- 为日期字段添加索引提高查询性能
);
  1. 如果您想查询其他日志表
    如果您实际想查询的是其他日志表(比如 app_log),可以修改查询:
sql
SELECT COUNT(*) AS 'new log entries:'
FROM app_log  -- 替换为实际的日志表名
WHERE date_added = DATE_SUB(CURDATE(), INTERVAL 1 DAY);
  1. 如果您想创建每日日志统计
sql
-- 创建日志统计表
CREATE TABLE IF NOT EXISTS daily_log_stats (stat_date DATE PRIMARY KEY,entry_count INT,last_updated TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
);

– 插入昨日日志统计

INSERT INTO daily_log_stats (stat_date, entry_count)
SELECT DATE_SUB(CURDATE(), INTERVAL 1 DAY) AS stat_date,COUNT(*) AS entry_count
FROM app_log  -- 使用您实际的日志表
WHERE date_added = DATE_SUB(CURDATE(), INTERVAL 1 DAY)
ON DUPLICATE KEY UPDATE entry_count = VALUES(entry_count);

关键点说明
错误原因:ERROR 1146 表示表不存在

日期函数:

CURDATE() 获取当前日期

DATE_SUB() 用于日期计算

索引建议:日志表应该为日期字段添加索引

预防措施
在查询前总是检查表是否存在:

sql
SELECT TABLE_NAME 
FROM information_schema.TABLES 
WHERE TABLE_SCHEMA = 'cookbook' AND TABLE_NAME = 'log_tbl';
使用事务确保数据一致性:sql
START TRANSACTION;
-- 您的查询语句
COMMIT;
D:\software\MySql\bin>mysql -u root -p  p72/951 Sunday, May 18, 2025

相关文章:

板凳-------Mysql cookbook学习 (三)

1.22 使长输出行更具可读性 mysql> show full columns from limbs; ------------------------------------------------------------------------------------------------------------- | Field | Type | Collation | Null | Key | Default | Extra | Pri…...

济南国网数字化培训班学习笔记-第三组-2-电力通信光缆网认知

电力通信光缆网认知 光缆网架构现状 基础底座 电路系统是高度复杂&#xff0c;实时性、安全性、可靠性要求极高的巨系统&#xff0c;必须建设专用通信网 相伴相生 电力系统是由发电、输电、变电、配电、用电等一次设施&#xff0c;及保障其正常运行的保护、自动化、通信等…...

黑灰产业链深度解析

黑灰产业链深度解析 大家好&#xff0c;欢迎来到「黑产档案」。本频道专注于反诈教育宣传&#xff0c;通过深度拆解黑灰产业链的运作逻辑&#xff0c;帮助公众识别骗局、规避风险。本节课将聚焦产业链的核心环节&#xff0c;揭示其背后的灰色生态。 一、黑灰产的定义与范畴 要…...

golang选项设计模式

选项设计模式 有时候一个函数会有很多参数&#xff0c;为了方便函数的使用&#xff0c;我们会给希望给一些参数设定默认值&#xff0c;调用时只需要传与默认值不同的参数即可&#xff0c;类似于 python 里面的默认参数和字典参数&#xff0c;虽然 golang 里面既没有默认参数也…...

方案精读:104页DeepSeek金融银行核算流程场景部署建设方案【附全文阅读】

DeepSeek,金融银行核算流程的革新方案! 这份方案专为金融银行从业者打造,旨在解决传统核算流程的难题。当下,金融银行核算面临效率低、错误率高、合规压力大等挑战,DeepSeek 方案正是应对之策。 该方案运用人工智能和大数据技术,实现数据采集、清洗自动化,智能核算对账,…...

【MySQL】02.数据库基础

1. 数据库的引入 之前存储数据用文件就可以了&#xff0c;为什么还要弄个数据库? 文件存储存在安全性问题&#xff0c;文件不利于数据查询和管理&#xff0c;文件不利于存储海量数据&#xff0c;文件在程序中控制不方便。而为了解决上述问题&#xff0c;专家们设计出更加利于…...

STM32项目实战:ADC采集

STM32F103C8T6的ADC配置。PB0对应的是ADC1的通道8。在标准库中&#xff0c;需要初始化ADC&#xff0c;设置通道&#xff0c;时钟&#xff0c;转换模式等。需要配置GPIOB的第0脚为模拟输入模式&#xff0c;然后配置ADC1的通道8&#xff0c;设置转换周期和触发方式。 接下来是I2C…...

《AI语音模型:MiniMax Speech-02》

开场&#xff1a;AI 语音界的震撼弹 在 AI 语音技术的激烈竞争赛道上&#xff0c;MiniMax Speech - 02 的出现宛如一颗震撼弹&#xff0c;瞬间引爆了整个行业。不久前&#xff0c;一则消息在全球 AI 领域引起轩然大波&#xff1a;MiniMax 的新一代语音大模型 Speech - 02&#…...

基于LabVIEW的双音多频系统设计

目录 1 系统设计概述 双音多频(Dual-Tone Multi-Frequency, DTMF)信号是一种广泛应用于电话系统中的音频信号,通过不同的频率组合表示不同的按键。每个按键对应两个频率,一个低频和一个高频,共同组成独特的信号。在虚拟仪器技术快速发展的背景下,利用LabVIEW等图形化编程…...

快速生成角色背景设定:基于Next.js的AI辅助工具开发实践

引言 在游戏开发、小说创作和角色扮演&#xff08;RP&#xff09;中&#xff0c;角色背景设定&#xff08;Headcanon&#xff09;的构建往往耗时耗力。传统方法依赖手动编写&#xff0c;容易陷入思维定式。本文将分享如何利用Next.js和Tailwind CSS开发一个高效的AI角色设定生…...

轻量级视频剪辑方案:FFmpeg图形化工具体验

FFmpeg小白助手是基于开源FFmpeg开发的本地化视频处理软件&#xff0c;采用绿色免安装设计&#xff0c;解压后即可直接运行。该工具主要面向普通用户的日常音视频处理需求&#xff0c;通过简洁的图形界面降低了FFmpeg的使用门槛。 功能特性 基础编辑功能 格式转换&#xff1a;…...

主成分分析的应用之sklearn.decomposition模块的PCA函数

主成分分析的应用之sklearn.decomposition模块的PCA函数 一、模型建立整体步骤 二、数据 2297.86 589.62 474.74 164.19 290.91 626.21 295.20 199.03 2262.19 571.69 461.25 185.90 337.83 604.78 354.66 198.96 2303.29 589.99 516.21 236.55 403.92 730.05 438.41 225.80 …...

Java基于数组的阻塞队列实现详解

在多线程编程中&#xff0c;阻塞队列是一种非常有用的工具&#xff0c;它可以在生产者和消费者之间提供一个缓冲区&#xff0c;使得生产者可以往队列中添加数据&#xff0c;而消费者可以从队列中取出数据。当队列满时&#xff0c;生产者会被阻塞直到有空间可用&#xff1b;当队…...

ngx_http_random_index_module 模块概述

一、使用场景 随机内容分发 当同一目录下存放多份等价内容&#xff08;如多张轮播图、不同版本静态页面等&#xff09;时&#xff0c;可通过随机索引实现负载均衡或流量分散。A/B 测试 通过目录请求自动随机分配用户到不同测试组&#xff0c;无需后端逻辑参与。动态“首页”选…...

你引入的lodash充分利用了吗?

#开发中&#xff0c;发现自己只有cloneDeep的时候才想起来用这个库的便利&#xff0c;搜索了项目内代码&#xff0c;发现大家基本也是这样&#xff0c;其实我们错过了很多好东西# cloneDeep 深拷贝 var objects [{ a: 1 }, { b: 2 }];var deep _.cloneDeep(objects); conso…...

Python爬虫基础

本篇内容中&#xff0c;我们主要分享一些爬虫的前置知识&#xff0c;主要知识点有&#xff1a; 爬虫的概念和作用爬虫的流程【重要】http相关的复习 http和https概念和区别浏览器访问一个网址的过程爬虫中常用的请求头、响应头常见的响应状态码 浏览器自带开发者工具的使用 爬…...

飞帆控件:on_post_get 接口配置

在网页中写一个接口是很基础的要求。 今天我们介绍一个工具&#xff0c;不用写代码&#xff0c;配置即可。 先上链接&#xff1a; on_post_gethttps://fvi.cn/798来看看控件的配置&#xff1a; 使用这个控件&#xff0c;在网页中写 post/get 接口可以告别代码。或许能做到初…...

C++笔试题(金山科技新未来训练营):

题目分布&#xff1a; 17道单选&#xff08;每题3分&#xff09;3道多选题&#xff08;全对3分&#xff0c;部分对1分&#xff09;2道编程题&#xff08;每一道20分&#xff09;。 不过题目太多&#xff0c;就记得一部分了&#xff1a; 单选题&#xff1a; static变量的初始…...

Selenium-Java版(css表达式)

css表达式 前言 根据 tag名、id、class 选择元素 tag名 #id .class 选择子元素和后代元素 定义 语法 根据属性选择 验证CSS Selector 组选择 按次序选择子节点 父元素的第n个子节点 父元素的倒数第n个子节点 父元素的第几个某类型的子节点 父元素的…...

19. 结合Selenium和YAML对页面实例化PO对象改造

19. 结合Selenium和YAML对页面实例化PO对象改造 一、架构升级核心思路 1.1 改造核心目标 # 原始PO模式&#xff1a;显式定义元素定位 username (id, ctl00_MainContent_username)# 改造后PO模式&#xff1a;动态属性访问 self.username.send_keys(Tester) # 自动触发元素定…...

MySQL——5、基本查询

表的增删改查 1、Create1.1、单行数据全列插入1.2、多行数据指定列插入1.3、插入否则更新1.4、替换 2、Retrieve2.1、select列2.2、where条件2.3、结果排序2.4、筛选分页结果 3、Update4、Delete4.1、删除数据4.2、截断表 5、插入查询结果6、聚合函数7、group by子句的使用8、实…...

ngx_http_referer_module 模块概述

一、使用场景 防盗链 仅允许本站或特定域名的页面直接引用图片、视频等资源&#xff0c;拒绝第三方网站直接嵌入。流量控制 阻止来自社交媒体、搜索引擎或未知来源的大量自动化抓取。安全审计 简易记录并过滤可疑 Referer&#xff0c;以减少非法请求。 注意 Referer 头可被伪造…...

Go语言--语法基础5--基本数据类型--类型转换

Go 编程语言中 if 条件语句的语法如下&#xff1a; 1、基本形式 if 布尔表达式 { /* 在布尔表达式为 true 时执行 */ } If 在布尔表达式为 true 时&#xff0c;其后紧跟的语句块执行&#xff0c;如果为 false 则 不执行。 package main import "fmt" …...

用golang实现二叉搜索树(BST)

目录 一、概念、性质二、二叉搜索树的实现1. 结构2. 查找3. 插入4. 删除5. 中序遍历 中序前驱/后继结点 一、概念、性质 二叉搜索树&#xff08;Binary Search Tree&#xff09;&#xff0c;简写BST&#xff0c;又称为二叉查找树 它满足&#xff1a; 空树是一颗二叉搜索树对…...

基于FPGA的电子万年历系统开发,包含各模块testbench

目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 5.完整工程文件 1.课题概述 基于FPGA的电子万年历系统开发,包含各模块testbench。主要包含以下核心模块&#xff1a; 时钟控制模块&#xff1a;提供系统基准时钟和计时功能。 日历计算模块&#xff1a…...

上位机知识篇---Web

文章目录 前言 前言 本文简单介绍了Web。...

2025 ISCC 练武赛Pwn-wp(含附件)

前言 去年个人赛报名了忘记打了(笑), 所以这应该算是我第一次参加ISCC, 体验也是非常非常非常非常的cha(第四声)!!! 主办方也是非常幽默&#xff0c;pwn和web都是公用容器&#xff0c;那web最后都被当成玩具玩坏了 下面是这次练武题的pwn所有附件 通过网盘分享的文件&#xf…...

LeetCode Hot100刷题——除自身以外数组的乘积

238. 除自身以外数组的乘积 给你一个整数数组 nums&#xff0c;返回 数组 answer &#xff0c;其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。 请 不要使用除法&a…...

IDEA - Windows IDEA 代码块展开与折叠(基础折叠操作、高级折叠操作)

一、基础折叠操作 折叠当前代码块&#xff1a;Ctrl - # 操作方式按下 【Ctrl】 键&#xff0c;再按下 【-】 键展开当前代码块&#xff1a;Ctrl # 操作方式按下 【Ctrl】 键&#xff0c;再按下 【】 键折叠所有代码块&#xff1a;Ctrl Shift - # 操作方式按下 【Ctrl】…...

javaSE.Map

Map存储映射关系。键值对。key-value 左边值映射着右边的值&#xff0c;左边相当于钥匙&#xff0c;开到右边的门获取得到信息。 get&#x1f447;put 是否存在该key&#x1f447;containsKey() map.values&#x1f447; entrySet&#x1f447; entrySet()获取map中所有的键…...

Python Requests库完全指南:从入门到精通

引言 在Python的生态系统中&#xff0c;requests库以其简洁优雅的API设计和强大的功能&#xff0c;成为HTTP请求处理领域的标杆工具。无论是数据爬虫开发、API接口调用&#xff0c;还是自动化测试场景&#xff0c;requests都能将复杂的网络交互简化为几行可读性极高的代码。相…...

1.QPushBotton 以及 对象树

目录 1. 创建第一个Qt程序 1.1 初始化设置 ​&#x1f350; 选择存储位置 &#x1f34a; Kit &#x1f34b; 类信息 &#x1f34c; 项目管理 1.2 代码 &#x1f349; main.cpp &#x1f347;widget.h &#x1f353; widget.cpp 1.3 .pro文件 &#x1f348; 常见模块…...

GO语言语法---For循环、break、continue

文章目录 1. 基本for循环&#xff08;类似其他语言的while&#xff09;2. 经典for循环&#xff08;初始化;条件;后续操作&#xff09;3. 无限循环4. 使用break和continue5 . 带标签的循环&#xff08;可用于break/continue指定循环&#xff09;1、break带标签2、continue带标签…...

网络编程-select(二)

一、I/O多路复用 1、为什么要多路复用 之前开启多线程能实时接收数据&#xff0c;并且也不是一次性连接服务。但毕竟是一请求一连接&#xff0c;每有一个客户端向服务端发起请求&#xff0c;就会创建一个线程&#xff0c;当请求达到上千上万&#xff0c;就会创建上千上万的线…...

2025年PMP 学习十九 第12章 项目采购管理

2025年PMP 学习十九 第12章 项目采购管理 序号过程过程组1规划采购管理规划2实施采购执行3控制采购监控4合同管理- 文章目录 2025年PMP 学习十九 第12章 项目采购管理12 项目采购管理建立战略合作伙伴关系的意义&#xff1a;细化采购步骤 12.1 规划采购管理1. **定义与作用**2…...

10.11 LangGraph多角色Agent开发实战:生产级AI系统架构与性能优化全解析

LangGraph 项目:High-level API for Multi-actor Agents 关键词:LangGraph 多角色 Agent, 状态管理, 持久化机制, 工作流编排, 生产级 AI 系统 1. LangGraph 设计哲学与架构演进 LangGraph 是 LangChain 生态中首个面向 多角色协作 Agent 的高阶 API 框架,其核心设计思想可…...

计算机网络概要

⽹络相关基础知识 协议 两设备之间使⽤光电信号传输信息数据 要想传递不同信息 那么⼆者ᳵ就需要约定好的数据格式 层 封装 继承 多态是计算机的性质 它们⽀持了软硬件分层的实现 同层协议可以ᳵ接通信 同层协议ᳵ不直接通信 是各⾃调⽤下层提供的结构能⼒完成通信 分层…...

Visual Studio已更新为17.14+集成deepseek实现高效编程

01 Visual Studio 2022 v17.14。 此更新侧重于全面提供出色的开发人员体验&#xff0c;侧重于稳定性和安全性以及 AI 改进。 02 GPT-4o代码完成模式 我们非常高兴地宣布&#xff0c;新的 GPT-4o Copilot 代码完成模型现已在 Visual Studio 17.14 中为 GitHub Copilot 用户…...

axios的基本使用

1. Axios概述 Axios 是一个基于 Promise 的 HTTP 客户端库&#xff0c;专为浏览器和 Node.js 设计&#xff0c;用来发送AJAX请求。可以通过npm install -g axios安装axios库。Axios有以下特征&#xff1a; 跨平台兼容性&#xff1a;同一套代码可运行于浏览器和 Node.js。在浏…...

【第三十六周】LoRA 微调方法

LoRA 摘要Abstract文章信息引言方法LoRA的原理LoRA在Transformer中的应用补充其他细节 实验与分析LoRA的使用论文实验结果分析 总结 摘要 本篇博客介绍了LoRA&#xff08;Low-Rank Adaptation&#xff09;&#xff0c;这是一种面向大规模预训练语言模型的参数高效微调方法&…...

fcQCA模糊集定性比较分析法-学习笔记

模糊集定性比较分析&#xff08;fsQCA&#xff0c;Fuzzy-set Qualitative Comparative Analysis&#xff09; 是一种结合了定性和定量元素的研究方法&#xff0c;用于分析中小样本数据中的复杂因果关系。 1. 理解基础概念 QCA的核心思想&#xff1a; 基于集合论和布尔代数&a…...

基于WebRTC的实时语音对话系统:从语音识别到AI回复

基于WebRTC的实时语音对话系统&#xff1a;从语音识别到AI回复 在当今数字化时代&#xff0c;实时语音交互已成为人机界面的重要组成部分。本文将深入探讨一个基于WebRTC技术的实时语音对话系统&#xff0c;该系统集成了语音识别(ASR)、大语言模型(LLM)和语音合成(TTS)技术&am…...

Text2SQL:自助式数据报表开发---0517

Text2SQL技术 早期阶段&#xff1a;依赖于人工编写的规则模板来匹配自然语言和SQL语句之间的对应关系 机器学习阶段&#xff1a;采用序列到序列模型等机器学习方法来学习自然语言与SQL之间的关系 LLM阶段&#xff1a;借助LLM强大的语言理解和代码生成能力&#xff0c;利用提示…...

关于 Web 漏洞原理与利用:1. SQL 注入(SQLi)

一、原理&#xff1a; 拼接 SQL 语句导致注入 SQL 注入的根本原因是&#xff1a;开发者将用户的输入和 SQL 语句直接拼接在一起&#xff0c;没有任何过滤或校验&#xff0c;最终被数据库“当作语句”执行了。 这就像是我们给数据库写了一封信&#xff0c;结果攻击者在我们的…...

【NLP 75、如何通过API调用智谱大模型】

事事忘记&#xff0c;事事等待&#xff0c;事事自愈 —— 25.5.18 一、调用智谱大模型 zhipuai.model_api.invoke()&#xff1a;调用智谱 AI 的大模型&#xff08;如 ChatGLM&#xff09;进行文本生成或推理&#xff0c;支持同步请求。 参数列表 参数名类型是否必需默认值说…...

【RabbitMQ】 RabbitMQ高级特性(二)

文章目录 一、重试机制1.1、重试配置1.2、配置交换机&队列1.3、发送消息1.4、消费消息1.5、运行程序1.6、 手动确认 二、TTL2.1、设置消息的TTL2.2、设置队列的TTL2.3、两者区别 三 、死信队列6.1 死信的概念3.2 代码示例3.2.1、声明队列和交换机3.2.2、正常队列绑定死信交…...

EMQX开源版安装指南:Linux/Windows全攻略

EMQX开源版安装教程-linux/windows 因最近自己需要使用MQTT&#xff0c;需要搭建一个MQTT服务器&#xff0c;所以想到了很久以前用到的EMQX。但是当时的EMQX使用的是开源版的&#xff0c;在官网可以直接下载。而现在再次打开官网时发现怎么也找不大开源版本了&#xff0c;所以…...

MySQL 数据库备份与还原

作者&#xff1a;IvanCodes 日期&#xff1a;2025年5月18日 专栏&#xff1a;MySQL教程 思维导图 备份 (Backup) 与 冗余 (Redundancy) 的核心区别: &#x1f3af; 备份是指创建数据的副本并将其存储在不同位置或介质&#xff0c;主要目的是在发生数据丢失、损坏或逻辑错误时进…...

【数据结构】2-3-4 单链表的建立

数据结构知识点合集 尾插法建立单链表 建立链表时总是将新节点插入到链表的尾部&#xff0c;将新插入的节点作为链表的尾节点 /*尾插法建立链表L*/ LinkList List_TailInsert(LinkList &L) { int x; /*建立头节点*/ L (LNode *)malloc(sizeof(LNode)); /*…...

JVM如何处理多线程内存抢占问题

目录 1、堆内存结构 2、运行时数据 3、内存分配机制 3.1、堆内存结构 3.2、内存分配方式 1、指针碰撞 2、空闲列表 4、jvm内存抢占方案 4.1、TLAB 4.2、CAS 4.3、锁优化 4.4、逃逸分析与栈上分配 5、问题 5.1、内存分配竞争导致性能下降 5.2、伪共享&#xff08…...