找到关于数据库的6705篇文章

我们如何检查服务器上所有 MySQL 数据库的默认字符集?

Nikitha N
更新于 2020年1月30日 06:21:34

78 次查看

下面的查询将返回数据库名称及其默认字符集:mysql> SELECT SCHEMA_NAME 'Database', default_character_set_name 'charset' FROM information_schema.SCHEMATA; +--------------------+---------+ | Database           | Charset | +--------------------+---------+ | information_schema | utf8    | | gaurav             | latin1  | | menagerie          | latin1  | | mysql              | latin1  | | performance_schema | utf8    | | sample             | latin1  | | test               | latin1  | | tutorial           | latin1  | +--------------------+---------+ 8 rows in set (0.00 sec)

我们如何从 MySQL 表中删除一行?

Akshaya Akki
更新于 2020年6月20日 07:31:48

323 次查看

我们可以使用 DELETE 语句以及 WHERE 子句来删除 MySQL 表中的一行,WHERE 子句标识该特定行。示例 mysql> Select * from names; +------+-----------+ | id   | name      | +------+-----------+ | 1    | Rahul     | | 2    | Gaurav    | | 3    | Raman     | | 4    | Aarav     | | 5    | Ram       | +------+-----------+ 5 rows in set (0.00 sec) mysql> DELETE from names where id = 4; Query OK, 1 row affected (0.07 sec) 以上查询将删除表‘names’中id = 4 的一行。mysql> Select * from names; +------+-----------+ | id   | name      | +------+-----------+ | 1    | Rahul     | | 2    | Gaurav    | | 3    | Raman     | | 5    | Ram       | +------+-----------+ 4 rows in set (0.00 sec)

我们如何在 MySQL 结果集中获取所有唯一行?

Vikyath Ram
更新于 2020年6月20日 07:09:52

220 次查看

使用 SELECT 语句中的 DISTINCT 关键字,我们可以获取 MySQL 结果集中唯一行。示例 mysql> Select * from names; +------+-----------+ | id   | name      | +------+-----------+ | 1    | Rahul     | | 2    | Gaurav    | | 3    | Raman     | | 4    | Aarav     | | 5    | Ram       | | 5    | Ram       | | 5    | Ram       | +------+-----------+ 7 rows in set (0.00 sec) 如我们所见,表‘names’有三行重复的行,借助以下查询,我们可以得到结果集,其中只有唯一行。mysql> Select DISTINCT * from names; +------+-----------+ | id   | name      | +------+-----------+ | 1    | Rahul     | | 2    | Gaurav    | | 3    | Raman     | | 4    | Aarav     | | 5    | Ram       | +------+-----------+ 5 rows in set (0.00 sec)

了解 MySQL 支持的所有字符集的查询是什么?

vanithasree
更新于 2020年1月30日 06:23:43

93 次查看

借助以下查询,我们可以查看 MySQL 支持的所有字符集: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   ... 阅读更多

如果用于在 UPDATE 语句的 SET 子句中赋值的子查询返回多行,MySQL 会返回什么?

karthikeya Boyini
更新于 2020年6月20日 07:07:57

235 次查看

在这种情况下,MySQL 将返回一条错误消息,因为我们知道,如果使用子查询在 UPDATE 语句的 SET 子句中赋值,则它必须为与 WHERE 子句匹配的更新表中的每一行返回恰好一行。示例 mysql> insert into info(id, remarks) values(5, 'average'); Query OK, 1 row affected (0.06 sec) mysql> select * from info; +------+-----------+ | id   | remarks   | +------+-----------+ | 1    | Good      | | 2    | Good      | | 3    | Excellent | | 4   ... 阅读更多

在 MySQL 中,SERIAL 和 AUTO_INCREMENT 之间的区别是什么?

Srinivas Gorla
更新于 2020年6月20日 07:09:26

3K+ 次查看

在 MySQL 中,SERIAL 和 AUTO_INCREMENT 都用于将序列定义为字段的默认值。但它们在技术上彼此不同。AUTO_INCREMENT 属性受所有数字数据类型支持,但 BIT 和 DECIMAL 除外。每个表只能有一个 AUTO_INCREMENT 字段,并且一个表中 AUTO_INCREMENT 字段生成的序列不能用于任何其他表。此属性要求在该字段上存在唯一索引,以确保序列没有重复项。序列默认从 1 开始,每次插入都会递增 1。示例 mysql> ... 阅读更多

如何将定长字符串和变长字符串存储在同一个 MySQL 表中?

Jennifer Nicholas
更新于 2020年6月20日 07:08:50

492 次查看

我们知道 CHAR 用于存储定长字符串,VARCHAR 用于存储变长字符串。因此,我们可以通过将一个列声明为 CHAR,另一个列声明为 VARCHAR 来在同一表中存储定长字符串和变长字符串。示例 mysql> Create Table Employees(FirstName CHAR(10), LastName VARCHAR(10)); Query OK, 0 rows affected (0.64 sec) mysql> Desc Employees; +-----------+-------------+------+-----+---------+-------+ | Field     | Type        | Null | Key | Default | Extra | +-----------+-------------+------+-----+---------+-------+ | FirstName | char(10)    | YES  |     | NULL    |   ... 阅读更多

如果用于在 UPDATE 语句的 SET 子句中赋值的子查询不返回任何行,MySQL 会返回什么?

Kumar Varma
更新于 2020年6月20日 07:07:27

117 次查看

在这种情况下,MySQL 将为 SET 子句提供 NULL 值。以下示例将演示它:示例 mysql> Select * from student; +----+---------+-----------+ | Id | Name    | grade     | +----+---------+-----------+ | 1  | Rahul   | Good      | | 2  | Gaurav  | Good      | | 3  | Raman   | Excellent | | 4  | Harshit | Average   | | 5  | Aarav   | Best      | | 6  | Ram     | average   | +----+---------+-----------+ 6 rows in set (0.00 sec) ... 阅读更多

我们如何搜索 MySQL 表中具有日期作为值的记录?

Nitya Raut
更新于 2020年1月30日 06:29:55

103 次查看

可以通过以下示例来理解,我们在名为“detail_bday”的表中使用以下数据:
mysql> Select * from detail_bday;
+----+---------+------------+
| Sr | Name | Birth_Date |
+----+---------+------------+
| 1 | Saurabh | 1990-05-12 |
| 2 | Raman | 1993-06-11 |
| 3 | Gaurav | 1984-01-17 |
| 4 | Rahul | 1993-06-11 |
+----+---------+------------+
4 rows in set (0.00 sec)
现在,我们可以通过以下两种方式使用日期搜索记录:
mysql> Select * from detail_bday Where Birth_Date = '1993-06-11';
+----+-------+------------+
| Sr | ... 阅读更多

ALLOW_INVALID_DATES SQL模式有什么作用?

Abhinanda Shri
更新于 2020年6月20日 07:06:28

2K+ 次浏览

顾名思义,启用ALLOW_INVALID_DATES SQL模式将允许我们在表中存储无效日期。以下是一个示例:
示例
mysql> SET sql_mode = ALLOW_INVALID_DATES;
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> Insert Into detail_bday(Name, Birth_Date) values('Sonia', '1993-11-31');
Query OK, 1 row affected (0.09 sec)
mysql> Insert Into detail_bday(Name, Birth_Date) values('Ram', '0000-00-00');
Query OK, 1 row affected (0.10 sec)
mysql> Select * from detail_bday;
+----+---------+------------+
| Sr | Name | Birth_Date |
+----+---------+------------+
| 1 | Saurabh | 1990-05-12 |
| 2 | Raman | 1993-06-11 | ... 阅读更多

广告