- MySQL 基础
- MySQL - 首页
- MySQL - 简介
- MySQL - 特性
- MySQL - 版本
- MySQL - 变量
- MySQL - 安装
- MySQL - 管理
- MySQL - PHP 语法
- MySQL - Node.js 语法
- MySQL - Java 语法
- MySQL - Python 语法
- MySQL - 连接
- MySQL - Workbench
- MySQL 数据库
- MySQL - 创建数据库
- MySQL - 删除数据库
- MySQL - 选择数据库
- MySQL - 显示数据库
- MySQL - 复制数据库
- MySQL - 数据库导出
- MySQL - 数据库导入
- MySQL - 数据库信息
- MySQL 用户
- MySQL - 创建用户
- MySQL - 删除用户
- MySQL - 显示用户
- MySQL - 修改密码
- MySQL - 授权
- MySQL - 显示权限
- MySQL - 收回权限
- MySQL - 锁定用户帐户
- MySQL - 解锁用户帐户
- MySQL 表
- MySQL - 创建表
- MySQL - 显示表
- MySQL - 修改表
- MySQL - 重命名表
- MySQL - 克隆表
- MySQL - 清空表
- MySQL - 临时表
- MySQL - 修复表
- MySQL - 描述表
- MySQL - 添加/删除列
- MySQL - 显示列
- MySQL - 重命名列
- MySQL - 表锁定
- MySQL - 删除表
- MySQL - 派生表
- MySQL 查询
- MySQL - 查询
- MySQL - 约束
- MySQL - 插入查询
- MySQL - 选择查询
- MySQL - 更新查询
- MySQL - 删除查询
- MySQL - 替换查询
- MySQL -忽略插入
- MySQL - 遇到重复键时更新
- MySQL - 将SELECT结果插入
- MySQL 运算符和子句
- MySQL - WHERE 子句
- MySQL - LIMIT 子句
- MySQL - DISTINCT 子句
- MySQL - ORDER BY 子句
- MySQL - GROUP BY 子句
- MySQL - HAVING 子句
- MySQL - AND 运算符
- MySQL - OR 运算符
- MySQL - LIKE 运算符
- MySQL - IN 运算符
- MySQL - ANY 运算符
- MySQL - EXISTS 运算符
- MySQL - NOT 运算符
- MySQL - 不等于运算符
- MySQL - IS NULL 运算符
- MySQL - IS NOT NULL 运算符
- MySQL - BETWEEN 运算符
- MySQL - UNION 运算符
- MySQL - UNION vs UNION ALL
- MySQL - MINUS 运算符
- MySQL - INTERSECT 运算符
- MySQL - INTERVAL 运算符
- MySQL 连接
- MySQL - 使用连接
- MySQL - INNER JOIN
- MySQL - LEFT JOIN
- MySQL - RIGHT JOIN
- MySQL - CROSS JOIN
- MySQL - FULL JOIN
- MySQL - 自连接
- MySQL - 删除连接
- MySQL - 更新连接
- MySQL - UNION vs JOIN
- MySQL 触发器
- MySQL - 触发器
- MySQL - 创建触发器
- MySQL - 显示触发器
- MySQL - 删除触发器
- MySQL - INSERT之前触发器
- MySQL - INSERT之后触发器
- MySQL - UPDATE之前触发器
- MySQL - UPDATE之后触发器
- MySQL - DELETE之前触发器
- MySQL - DELETE之后触发器
- MySQL 数据类型
- MySQL - 数据类型
- MySQL - VARCHAR
- MySQL - BOOLEAN
- MySQL - ENUM
- MySQL - DECIMAL
- MySQL - INT
- MySQL - FLOAT
- MySQL - BIT
- MySQL - TINYINT
- MySQL - BLOB
- MySQL - SET
- MySQL 正则表达式
- MySQL - 正则表达式
- MySQL - RLIKE 运算符
- MySQL - NOT LIKE 运算符
- MySQL - NOT REGEXP 运算符
- MySQL - regexp_instr() 函数
- MySQL - regexp_like() 函数
- MySQL - regexp_replace() 函数
- MySQL - regexp_substr() 函数
- MySQL 函数 & 运算符
- MySQL - 日期和时间函数
- MySQL - 算术运算符
- MySQL - 数值函数
- MySQL - 字符串函数
- MySQL - 聚合函数
- MySQL 其他概念
- MySQL - NULL 值
- MySQL - 事务
- MySQL - 使用序列
- MySQL - 处理重复数据
- MySQL - SQL 注入
- MySQL - 子查询
- MySQL - 注释
- MySQL - 检查约束
- MySQL - 存储引擎
- MySQL - 将表导出到 CSV 文件
- MySQL - 将 CSV 文件导入数据库
- MySQL - UUID
- MySQL - 公共表表达式
- MySQL - ON DELETE CASCADE
- MySQL - Upsert
- MySQL - 水平分区
- MySQL - 垂直分区
- MySQL - 游标
- MySQL - 存储函数
- MySQL - 信号
- MySQL - 重新发送信号
- MySQL - 字符集
- MySQL - 排序规则
- MySQL - 通配符
- MySQL - 别名
- MySQL - ROLLUP
- MySQL - 今日日期
- MySQL - 字面量
- MySQL - 存储过程
- MySQL - EXPLAIN
- MySQL - JSON
- MySQL - 标准差
- MySQL - 查找重复记录
- MySQL - 删除重复记录
- MySQL - 选择随机记录
- MySQL - 显示进程列表
- MySQL - 更改列类型
- MySQL - 重置自动递增
- MySQL - Coalesce() 函数
- MySQL 有用资源
- MySQL - 有用函数
- MySQL - 语句参考
- MySQL - 快速指南
- MySQL - 有用资源
- MySQL - 讨论
MySQL - FLOAT
FLOAT 数据类型是数值数据类型的一部分。数值数据类型用于存储数字,它们可以根据其特性(例如存储大小和精度)分为各种子类型。
MySQL FLOAT 数据类型
MySQL 的FLOAT数据类型是一种浮点数类型,用于存储近似数值。它以4个字节存储近似数值,表示单精度值。
FLOAT 适用于各种数值,但由于 IEEE 754 标准的限制,它以近似方式存储它们。
在 MySQL 8.0.17 之前的版本中,FLOAT 数据类型可以表示数据值的带符号和无符号属性,但在 MySQL 8.0.17 及更高版本中,无符号 FLOAT 已被弃用。
语法
以下是将字段的数据类型设置为 FLOAT 的基本语法:
CREATE TABLE (column_name FLOAT, ...);
示例
在这个例子中,让我们使用 CREATE TABLE 语句创建一个名为“datatype_demo”的新数据库表,其列表示 FLOAT 值:
CREATE TABLE datatype_demo( ID INT, NAME VARCHAR(50), HEIGHT FLOAT, WEIGHT FLOAT );
获得的输出如下:
Query OK, 0 rows affected (0.03 sec)
验证
创建表后,我们可以通过检索表的定义来验证“HEIGHT”和“WEIGHT”字段的数据类型,如下所示:
DESC datatype_demo;
DESC 命令的结果将显示“HEIGHT”和“WEIGHT”字段具有 FLOAT 数据类型:
字段 | 类型 | 空 | 键 | 默认值 | 额外 |
---|---|---|---|---|---|
ID | int | 是 | NULL | ||
NAME | varchar(50) | 是 | NULL | ||
HEIGHT | float | 是 | NULL | ||
WEIGHT | float | 是 | NULL |
为了进一步验证,让我们使用以下 INSERT 语句将一些值插入表中:
INSERT INTO datatype_demo VALUES (1, 'John', 171.3, 65.7), (2, 'Rob', 45, 75), (3, 'Salman', 12.74839, 54.262), (4, 'Arush', NULL, NULL), (5, 'James', 'h', 'w');
获得的输出如下:
ERROR 1265 (01000): Data truncated for column 'HEIGHT' at row 1
正如预期的那样,FLOAT 字段可以接受单精度浮点数而没有任何问题。但是,当尝试将非数值(例如“h”和“w”)插入这些字段时,MySQL 会引发错误,指示数据截断。
最后,要查看已插入表中的数据,我们可以使用 SELECT 语句,如下所示:
SELECT * FROM datatype_demo;
生成的表如下:
ID | NAME | HEIGHT | WEIGHT |
---|---|---|---|
1 | John | 171.3 | 65.7 |
2 | Rob | 45 | 75 |
3 | Salman | 12.7484 | 54.262 |
4 | Arush | NULL | NULL |
MySQL FLOAT 的其他表示
MySQL 提供了一种方法,可以以位的形式指定 FLOAT 数据类型的精度范围(而不是指数)。这些位在关键字 FLOAT 后面的括号中指定,即 FLOAT(p)。
但是,此精度值仅用于确定存储大小,并且最多只能容纳 7 位小数,范围从 0 到 23 位。如果精度位超过 23,则数据类型变为 DOUBLE。
示例
首先,我们将删除现有的“datatype_demo”表:
DROP TABLE datatype_demo;
获得的输出如下:
Query OK, 0 rows affected (0.01 sec)
然后,我们将创建一个新的表“datatype_demo”,为“HEIGHT”列指定 20 位精度:
CREATE TABLE datatype_demo( ID INT, NAME VARCHAR(50), HEIGHT FLOAT(20) );
以上代码的输出如下:
Query OK, 0 rows affected (0.02 sec)
验证
即使我们指定了 20 位精度,“HEIGHT”列仍然会将浮点值存储在单精度范围内,最多包含 7 位小数。要验证表的定义,我们可以使用 DESC 命令,如下所示:
DESC datatype_demo;
生成的表如下:
字段 | 类型 | 空 | 键 | 默认值 | 额外 |
---|---|---|---|---|---|
ID | int | 是 | NULL | ||
NAME | varchar(50) | 是 | NULL | ||
HEIGHT | float | 是 | NULL |
如果精度位超过 23,数据类型将变为 DOUBLE。请看下面的查询:
CREATE TABLE datatype_demo1( ID INT, NAME VARCHAR(50), HEIGHT FLOAT(30) );
我们将获得以下输出:
Query OK, 0 rows affected (0.02 sec)
同样,我们可以使用 DESC 命令验证表的定义:
DESC datatype_demo1;
获得的表如下:
字段 | 类型 | 空 | 键 | 默认值 | 额外 |
---|---|---|---|---|---|
ID | int | 是 | NULL | ||
NAME | varchar(50) | 是 | NULL | ||
HEIGHT | double | 是 | NULL |
使用客户端程序的 Float 数据类型
我们还可以使用客户端程序创建 Float 数据类型的列。
语法
要通过PHP程序创建一个Float数据类型的列,我们需要使用mysqli函数query()执行“CREATE TABLE”语句,如下所示:
$sql = 'CREATE TABLE temp(Id INT AUTO_INCREMENT, Celsius FLOAT, Fahrenheit FLOAT, PRIMARY KEY(Id))'; $mysqli->query($sql);
要通过JavaScript程序创建一个Float数据类型的列,我们需要使用mysql2库的query()函数执行“CREATE TABLE”语句,如下所示:
sql = "CREATE TABLE temp(Id INT AUTO_INCREMENT, Celsius FLOAT, Fahrenheit FLOAT, PRIMARY KEY(Id))"; con.query(sql);
要通过Java程序创建一个Float数据类型的列,我们需要使用JDBC函数execute()执行“CREATE TABLE”语句,如下所示:
String sql = "CREATE TABLE temp(Id INT AUTO_INCREMENT, Celsius FLOAT, Fahrenheit FLOAT, PRIMARY KEY(Id))"; statement.execute(sql);
要通过Python程序创建一个Float数据类型的列,我们需要使用MySQL Connector/Python的execute()函数执行“CREATE TABLE”语句,如下所示:
sql = 'CREATE TABLE datatype_demo(ID INT, NAME VARCHAR(50), HEIGHT FLOAT, WEIGHT FLOAT)'' cursorObj.execute(sql)
示例
以下是程序示例:
$dbhost = 'localhost'; $dbuser = 'root'; $dbpass = 'password'; $dbname = 'TUTORIALS'; $mysqli = new mysqli($dbhost, $dbuser, $dbpass, $dbname); if ($mysqli->connect_errno) { printf("Connect failed: %s
", $mysqli->connect_error); exit(); } //printf('Connected successfully.
'); //creating a table temp where we are inserting the celsius and Fahrenheit values in float $sql = 'CREATE TABLE temp(Id INT AUTO_INCREMENT, Celsius FLOAT, Fahrenheit FLOAT, PRIMARY KEY(Id))'; $result = $mysqli->query($sql); if ($result) { printf("Table created successfully...!\n"); } // insert data into created table $q = " INSERT INTO temp(Celsius, Fahrenheit) VALUES ( 36.2, 97.16), ( 35.8, 96.44), ( 37.32, 99.17), ( 35.89, 96.602);"; if ($res = $mysqli->query($q)) { printf("Data inserted successfully...!\n"); } //now display the table records $s = "SELECT * FROM temp"; if ($r = $mysqli->query($s)) { printf("Table Records: \n"); while ($row = $r->fetch_assoc()) { printf(" ID: %d, Celsius: %f, Fahrenheit: %f", $row["Id"], $row["Celsius"], $row["Fahrenheit"]); printf("\n"); } } else { printf('Failed'); } $mysqli->close();
输出
获得的输出如下:
Table created successfully...! Data inserted successfully...! Table Records: ID: 1, Celsius: 36.200000, Fahrenheit: 97.160000 ID: 2, Celsius: 35.800000, Fahrenheit: 96.440000 ID: 3, Celsius: 37.320000, Fahrenheit: 99.170000 ID: 4, Celsius: 35.890000, Fahrenheit: 96.602000
var mysql = require("mysql2"); var con = mysql.createConnection({ host: "localhost", user: "root", password: "password", }); //Connecting to MySQL con.connect(function (err) { if (err) throw err; // console.log("Connected successfully...!"); // console.log("--------------------------"); sql = "USE TUTORIALS"; con.query(sql); //create a student table, that accepts one column of float type. sql = "CREATE TABLE temp(Id INT AUTO_INCREMENT, Celsius FLOAT, Fahrenheit FLOAT, PRIMARY KEY(Id))"; con.query(sql); //insert data into created table sql = "INSERT INTO temp(Celsius, Fahrenheit) VALUES ( 36.2, 97.16), ( 35.8, 96.44), ( 37.32, 99.17), ( 35.89, 96.602)"; con.query(sql); //select datatypes of salary sql = `SELECT DATA_TYPE FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = 'temp' AND COLUMN_NAME = 'Celsius'`; con.query(sql, function (err, result) { if (err) throw err; console.log(result); }); });
输出
生成的输出如下:
[ { DATA_TYPE: 'float' } ]
import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class Float { public static void main(String[] args) { String url = "jdbc:mysql://127.0.0.1:3306/TUTORIALS"; String username = "root"; String password = "password"; try { Class.forName("com.mysql.cj.jdbc.Driver"); Connection connection = DriverManager.getConnection(url, username, password); Statement statement = connection.createStatement(); System.out.println("Connected successfully...!"); //Float data types...!; String sql = "CREATE TABLE temp(Id INT AUTO_INCREMENT, Celsius FLOAT, Fahrenheit FLOAT, PRIMARY KEY(Id))"; statement.execute(sql); System.out.println("column of a Float type created successfully...!"); ResultSet resultSet = statement.executeQuery("DESCRIBE temp"); while (resultSet.next()){ System.out.println(resultSet.getString(1)+" "+resultSet.getString(2)); } connection.close(); } catch (Exception e) { System.out.println(e); } } }
输出
获得的输出如下所示:
Connected successfully...! column of a Float type created successfully...! Id int Celsius float Fahrenheit float
import mysql.connector # Establishing the connection connection = mysql.connector.connect( host='localhost', user='root', password='password', database='tut' ) # Creating a cursor object cursorObj = connection.cursor() # Create table with float column sql = ''' CREATE TABLE datatype_demo(ID INT, NAME VARCHAR(50), HEIGHT FLOAT, WEIGHT FLOAT ) ''' cursorObj.execute(sql) print("The table is created successfully!") # Data to be inserted data_to_insert = [ (1, 'John', 171.3, 65.7), (2, 'Rob', 45, 75), (3, 'Salman', 12.74839, 54.262), (4, 'Arush', None, None), ] # Insert data into the created table insert_query = "INSERT INTO datatype_demo (ID, NAME, HEIGHT, WEIGHT) VALUES (%s, %s, %s, %s)" cursorObj.executemany(insert_query, data_to_insert) # Commit the changes after the insert operation connection.commit() print("Rows inserted successfully.") # Now display the table records select_query = "SELECT * FROM datatype_demo" cursorObj.execute(select_query) result = cursorObj.fetchall() print("Table Data:") for row in result: print(row) cursorObj.close() connection.close()
输出
以上代码的输出如下:
The table is created successfully! Rows inserted successfully. Table Data: (1, 'John', 171.3, 65.7) (2, 'Rob', 45.0, 75.0) (3, 'Salman', 12.7484, 54.262) (4, 'Arush', None, None)