MySQL 连接


使用mysql二进制方式连接

可以使用MySQL二进制方式进入到mysql命令提示符下来连接MySQL数据库

实例

以下是从命令行连接mysql服务器简单实例

[root@host]# mysql -u root -p
Enter password:******

登录成功后会出现 mysql> 命令提示窗口,你可以在上面执行任何 SQL 语句

以上命令执行后,登录成功输出结果如下:

Welcome to the MySQL monitor.  Commands end with ; or g.
Your MySQL connection id is 2854760 to server version: 5.0.9

Type 'help;' or 'h' for help. Type 'c' to clear the buffer.

在以上实例中,我们使用root用户登录mysql服务器,当然你也可以使用其他mysql用户登录

如果用户权限足够,任何用户都可以在mysql命令提示窗口中进行SQL操作

退出 mysql> 命令提示窗口可以使用 exit 命令如下所示

mysql> exit
Bye

使用 PHP 脚本连接 MySQL

PHP 提供了 mysqli_connect() 函数连接数据库。

函数有 6 个参数,在成功链接到 MySQL 后返回连接标识失败返回 FALSE 。

语法

mysqli_connect(host, username, password, dbname,port, socket);

参数说明

参数 描述
host 可选。规定主机名或 IP 地址
username 可选。规定 MySQL 用户名
password 可选。规定 MySQL 密码
dbname 可选。规定默认使用的数据库
port 可选。规定尝试连接到 MySQL 服务器的端口号
socket 可选。规定 socket 或要使用的已命名 pipe

你可以使用 PHP 的 mysqli_close() 函数断开与 MySQL 数据库链接

函数只有一个参数为 mysqli_connect() 函数创建连接成功返回的 MySQL 连接标识符

语法

bool mysqli_close ( mysqli $link )

本函数关闭指定的连接标识关联的到 MySQL 服务器的非持久连接。如果没有指定 link_identifier,则关闭一个打开的连接。

提示:通常不需要使用 mysqli_close(),因为已打开的非持久连接会在脚本执行完毕后自动关闭

实例

你可以尝试以下实例来连接到你的 MySQL 服务器:

连接 MySQL

<?php $dbhost = 'localhost'; // mysql服务器主机地址 $dbuser = 'root'; // mysql用户名 $dbpass = '123456'; // mysql用户名密码 $conn = mysqli_connect($dbhost, $dbuser, $dbpass); if(! $conn ) { die('Could not connect: ' . mysqli_error()); } echo '数据库连接成功!'; mysqli_close($conn); ?>

MySQL 创建数据库


我们可以在登陆 MySQL 服务后,使用 create 命令创建数据库语法如下:

CREATE DATABASE 数据库名;

以下命令简单演示了创建数据库过程数据名为 RUNOOB:

[root@host]# mysql -u root -p   
Enter password:******  # 登录后进入终端

mysql> create DATABASE RUNOOB;

使用 mysqladmin 创建数据库

使用普通用户,你可能需要特定的权限来创建或者删除 MySQL 数据库

所以我们这边使用root用户登录,root用户拥有最高权限,可以使用 mysql mysqladmin 命令来创建数据库

以下命令简单演示了创建数据库过程数据名为 RUNOOB:

[root@host]# mysqladmin -u root -p create RUNOOB
Enter password:******

以上命令执行成功后会创建 MySQL 数据库 RUNOOB。


使用 PHP脚本 创建数据库

PHP 使用 mysqli_query 函数来创建或者删除 MySQL 数据库

该函数有两个参数,在执行成功时返回 TRUE,否则返回 FALSE。

语法

mysqli_query(connection,query,resultmode);
参数 描述
connection 必需。规定要使用的 MySQL 连接。
query 必需,规定查询字符串
resultmode

可选。一个常量。可以是下列值中的任意一个

实例

以下实例演示了使用PHP来创建一个数据库

创建数据

<?php $dbhost = ‘localhost‘; // mysql服务器主机地址 $dbuser = ‘root’; // mysql用户名 $dbpass = ‘123456’; // mysql用户名密码 $conn = mysqli_connect($dbhost, $dbuser, $dbpass); if(! $conn ) { die(‘连接错误: ‘ . mysqli_error($conn)); } echo ‘连接成功<br />’; $sql = ‘CREATE DATABASE RUNOOB’; $retval = mysqli_query($conn,$sql ); if(! $retval ) { die(‘创建数据失败: ‘ . mysqli_error($conn)); } echo数据库 RUNOOB 创建成功n”; mysqli_close($conn); ?>

执行成功后,返回如下结果

如果数据库已存在执行后,返回如下结果:

网友笔记整理

使用root登录后,可以使用

CREATE DATABASE IF NOT EXISTS RUNOOB DEFAULT CHARSET utf8 COLLATE utf8_general_ci;

创建数据库,该命令的作用

 

MySQL 删除数据库


使用普通用户登陆 MySQL 服务器,你可能需要特定的权限来创建或者删除 MySQL 数据库,所以我们这边使用 root 用户登录,root 用户拥有最高权限

在删除数据库过程中,务必要十分谨慎,因为在执行删除命令后,所有数据将会消失

drop 命令删除数据库

drop 命令格式

drop database <数据库名>;

例如删除名为 RUNOOB 的数据库:

mysql> drop database RUNOOB;

使用 mysqladmin 删除数据库

你也可以使用 mysql mysqladmin 命令在终端执行删除命令。

以下实例删除数据库 RUNOOB(该数据库在前一章节已创建):

[root@host]# mysqladmin -u root -p drop RUNOOB
Enter password:******

执行以上删除数据库命令后,会出现一个提示框,来确认是否真的删除数据库:

Dropping the database is potentially a very bad thing to do.
Any data stored in the database will be destroyed.

Do you really want to drop the 'RUNOOB' database [y/N] y
Database "RUNOOB" dropped

使用PHP脚本删除数据库

PHP使用 mysqli_query 函数来创建或者删除 MySQL 数据库。

该函数有两个参数,在执行成功时返回 TRUE,否则返回 FALSE。

语法

mysqli_query(connection,query,resultmode);
参数 描述
connection 必需。规定要使用的 MySQL 连接。
query 必需,规定查询字符串
resultmode

可选。一个常量。可以是下列值中的任意一个

  • MYSQLI_USE_RESULT(如果需要检索大量数据,请使用这个)
  • MYSQLI_STORE_RESULT(默认

实例

以下实例演示了使用PHP mysqli_query函数来删除数据库:

删除数据库

<?php $dbhost = 'localhost'; // mysql服务器主机地址 $dbuser = 'root'; // mysql用户名 $dbpass = '123456'; // mysql用户名密码 $conn = mysqli_connect($dbhost, $dbuser, $dbpass); if(! $conn ) { die('连接失败: ' . mysqli_error($conn)); } echo '连接成功<br />'; $sql = 'DROP DATABASE RUNOOB'; $retval = mysqli_query( $conn, $sql ); if(! $retval ) { die('删除数据库失败: ' . mysqli_error($conn)); } echo "数据库 RUNOOB 删除成功n"; mysqli_close($conn); ?>

执行成功后,数结果为:

注意: 在使用PHP脚本删除数据库时,不会出现确认是否删除信息,会直接删除指定数据库,所以你在删除数据库时要特别小心。

MySQL 选择数据库

在你连接到 MySQL 数据库后,可能多个可以操作的数据库,所以你需要选择你要操作的数据库。


从命令提示窗口中选择MySQL数据库

在 mysql> 提示窗口中可以很简单的选择特定的数据库。你可以使用SQL命令来选择指定的数据库。

实例

以下实例选取了数据库 RUNOOB:

[root@host]# mysql -u root -p
Enter password:******
mysql> use RUNOOB;
Database changed
mysql>

执行以上命令后,你就已经成功选择了 RUNOOB 数据库,在后续的操作中都会在 RUNOOB 数据库中执行。


使用PHP脚本选择MySQL数据库

PHP 提供了函数 mysqli_select_db 来选取个数据库。函数在执行成功后返回 TRUE ,否则返回 FALSE 。

语法

mysqli_select_db(connection,dbname);
参数 描述
connection 必需。规定要使用的 MySQL 连接。
dbname 必需,规定要使用的默认数据库。

实例

以下实例展示如何使用 mysqli_select_db 函数来选取个数据库:

选择数据库

<?php $dbhost = 'localhost'; // mysql服务器主机地址 $dbuser = 'root'; // mysql用户名 $dbpass = '123456'; // mysql用户名密码 $conn = mysqli_connect($dbhost, $dbuser, $dbpass); if(! $conn ) { die('连接失败: ' . mysqli_error($conn)); } echo '连接成功'; mysqli_select_db($conn, 'RUNOOB' ); mysqli_close($conn); ?>

MySQL 数据类型

MySQL 中定义数据字段类型对你数据库的优化是非常重要的。

MySQL 支持多种类型,大致可以分为三类:数值日期/时间字符串(字符)类型


数值类型

MySQL 支持所有标准 SQL 数值数据类型

这些类型包括严格数值数据类型(INTEGER、SMALLINT、DECIMAL 和 NUMERIC),以及近似数值数据类型(FLOAT、REAL 和 DOUBLE PRECISION)。

关键字INT是INTEGER的同义词关键字DEC是DECIMAL的同义词

BIT数据类型保存字段值,并且支持 MyISAM、MEMORY、InnoDB 和 BDB表。

作为 SQL 标准扩展,MySQL 也支持整数类型 TINYINT、MEDIUMINT 和 BIGINT。下面的表显示需要每个整数类型存储范围

类型 大小 范围(有符号 范围(无符号 用途
TINYINT 1 Bytes (-128,127) (0,255) 整数
SMALLINT 2 Bytes (-32 768,32 767) (0,65 535) 大整数值
MEDIUMINT 3 Bytes (-8 388 608,8 388 607) (0,16 777 215) 大整数值
INT或INTEGER 4 Bytes (-2 147 483 648,2 147 483 647) (0,4 294 967 295) 大整数值
BIGINT 8 Bytes (-9,223,372,036,854,775,808,9 223 372 036 854 775 807) (0,18 446 744 073 709 551 615) 极大整数值
FLOAT 4 Bytes (-3.402 823 466 E+38,-1.175 494 351 E-38),0,(1.175 494 351 E-38,3.402 823 466 351 E+38) 0,(1.175 494 351 E-38,3.402 823 466 E+38) 精度
浮点数
DOUBLE 8 Bytes (-1.797 693 134 862 315 7 E+308,-2.225 073 858 507 201 4 E-308),0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) 0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) 精度
浮点数
DECIMAL 对DECIMAL(M,D) ,如果M>D,为M+2否则为D+2 依赖于M和D的值 依赖于M和D的值 小数

日期时间类型

表示时间值的日期时间类型为DATETIME、DATE、TIMESTAMP、TIME和YEAR。

每个时间类型有一个有效值范围和一个”零”值,当指定不合法的MySQL不能表示的值时使用”零”值。

TIMESTAMP类型有专有的自动更新特性,将在后面描述。

类型 大小
( bytes)
范围 格式 用途
DATE 3 1000-01-01/9999-12-31 YYYY-MM-DD 日期
TIME 3 ‘-838:59:59’/’838:59:59’ HH:MM:SS 时间值或持续时间
YEAR 1 1901/2155 YYYY 年份
DATETIME 8 ‘1000-01-01 00:00:00’ 到 ‘9999-12-31 23:59:59’ YYYY-MM-DD hh:mm:ss 混合日期时间
TIMESTAMP 4

‘1970-01-01 00:00:01’ UTC 到 ‘2038-01-19 03:14:07’ UTC

结束时间是第 2147483647 秒,北京时间 2038-1-19 11:14:07,格林尼治时间 2038年1月19日 凌晨 03:14:07

YYYY-MM-DD hh:mm:ss 混合日期和时间值,时间戳

字符串类型

字符串类型指CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM和SET。该节描述了这些类型如何工作以及如何查询中使用这些类型。

类型 大小 用途
CHAR 0-255 bytes 定长字符串
VARCHAR 0-65535 bytes 变长字符
TINYBLOB 0-255 bytes 不超过 255 个字符二进制字符
TINYTEXT 0-255 bytes 文本字符
BLOB 0-65 535 bytes 二进制形式的长文本数据
TEXT 0-65 535 bytes 文本数据
MEDIUMBLOB 0-16 777 215 bytes 二进制形式的中等长度文本数据
MEDIUMTEXT 0-16 777 215 bytes 中等长度文本数据
LONGBLOB 0-4 294 967 295 bytes 二进制形式的极大文本数据
LONGTEXT 0-4 294 967 295 bytes 极大文本数据

注意char(n) 和 varchar(n) 中括号中 n 代表字符个数,并不代表字节个数比如 CHAR(30) 就可以存储 30 个字符

CHAR 和 VARCHAR 类型类似,但它们保存检索方式不同。它们的最大长度是否尾部空格被保留等方面也不同。在存储或检索过程中不进行大小写转换

BINARY 和 VARBINARY 类似于 CHAR 和 VARCHAR,不同的是它们包含进制字符串而不要非二进制字符串。也就是说,它们包含字节字符串而不是字符字符串。这说明它们没有字符集,并且排序比较基于列值字节的数值值。

BLOB 是一个二进制对象,可以容纳可变数量的数据。有 4 种 BLOB 类型:TINYBLOB、BLOB、MEDIUMBLOB 和 LONGBLOB。它们区别在于可容纳存储范围不同。

有 4 种 TEXT 类型:TINYTEXT、TEXT、MEDIUMTEXT 和 LONGTEXT。对应的这 4 种 BLOB 类型,可存储的最大长度不同,可根据实际情况选择。

网友笔记整理

MySQL 5.0 以上的版本

1、一个汉字多少长度编码有关:

UTF-8:一个汉字=3个字节

GBK:一个汉字=2个字节

2、varchar(n) 表示 n 个字符,无论汉字英文,Mysql 都能存入 n 个字符,仅是实际字节长度有所区别

3、MySQL 检查长度,可用 SQL 语言查看

select LENGTH(fieldname) from tablename

关于 charvarchartext 平时没有太在意,一般来说,可能现在大家都是用 varchar。但是当要存储的内容比较大时,究竟是选择 varchar 还是 text 呢?

三种类型比较

总结起来,有几点:

楼上那个说的有些问题大家需要注意

“在读取数据时,char 类型的数据要进行处理,把后面的空格去除”。 MySQL在存储char的时候,先去掉尾部的空格,若长度不足则用空格填充到相应长度。查询时,返回的数据尾部是没有空格的。

 

FLOAT 与 DOUBLE 差异(单精度与双精度什么区别)

本质的区别:精度,也就是 float ,在 32 位机器上用 4 个字节来存储的;而双精度double是用 8 个字节来存储的,由于存储位不同,他们表示的数值的范围就不同,也就是能准确表示的数的位数就不同。

1、所占的内存不同

精度点数baidu用4个字节(32位)存储空间来存储一个浮点数,包括符号位1位,阶码8位,尾数23位。

而双精度点数使用 8个字节(64位)存储空间来存储一个浮点数,包括符号位1位,阶码11位,尾数52位。

2、所存的数值范围不同

精度浮点数的数值范围为-3.4E38~3.4E38,而双精度浮点数可以表示数字绝对值范围大约是:-2.23E308 ~ 1.79E308。E表示10的多少次方,如3.4E38指的是3.4乘以10的38次方。

3、十进制下的位数不同

单精度浮点数最多有7位十进制有效数字,如果某个数有效数字位数超过7位,当把它定义为单精度变量时,超出部分自动四舍五入。

双精度浮点数可以表示十进制的15或16位有效数字,超出部分也会自动四舍五入。 

原文地址:https://blog.csdn.net/SHADOW_xhx/article/details/134742073

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_42186.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注