TCP port:TCP占用的端口号

1.字符编码与配置文件

1.\s:查看当前MySQL相关信息:当前用户、版本、编码、端口号。
"""  
Server characterset、Db characterset、Client characterset、Conn.characterset每个编码都不一样,我们需要手动改成utf8,注:MySQL5.6及之前的版本编码需要人为统一,之后的版本已经全部默认统一
"""
# 1

2.永久修改步骤:
	2.1默认的配置文件是my-default.ini,拷贝上述文件并重命名为my.ini
	2.2拷贝以下的代码:
	[mysqld]
        character-set-server=utf8mb4
        collation-server=utf8mb4_general_ci
    [client]
        default-character-set=utf8mb4
    [mysql]
        default-character-set=utf8mb4
   """
   PS:
	1.utf8mb4能够存储表情,比utf8功能更强大
	2.utf8与utf-8是有区别的,MySQL中只有utf
	8"""
	2.3修改了配置文件中关于[mysqld]的配置,需要重启服务端

2.数据库存储引擎

1.存储引擎:数据库针对数据采用的多种存取方式。
    
2.查看常见的存储引擎的方式:show engines;

3.需要了解的四个存储引擎:
'''MySQL中忽略大小写'''
	3.1 MyISAM:MySQL5.5之前默认的存储引擎,特点:存储速度快,但是功能较少,安全性较低。
            
	3.2 InnoDB:MySQL5.5之后的存储引擎,支持事务、行锁、外键等操作,存取速度没有MyISAM快,但是安全性更高。
"""
事务:某些操作因为系统原因没有及时更新,例如银行转账转款一端余额减少,收款一段余额未增加,事务有能力让余额回退到操作前的阶段。

行锁:比如共享文档,有人在操作某一行的时候其他人是无法操作的
"""
	3.3 Memory:基于内存存取数据,仅用于临时表数据存取。
       
	3.4 BlackHole:任何写入的数据都会立刻丢失。

3.创建表的完整语法

1.语法:create table 表名(
	字段名 字典类型(数字) 约束条件,
	字段名 字典类型(数字) 约束条件,
	字段名 字典类型(数字) 约束条件
)
	注意:
	1.字段名和字段类型是必须要有的
	2.数字和约束条件是可以没有的
	3.约束条件也可优选多个,空格隔开即可
	4.最后一行结尾不能加括号

4.字段类型之整形

mysql中的整形有以下几种:
	1.tinyint: 大小:1bytes(8个比特位,也就是8位0或1)
'''tinyint可以是正数也可以是负数,有正负号时结果是2**7有128种结果,无正负号时有2**8有256种结果。所以说tinyint表示的整形结果很有限'''
	2.smallint: 大小:2bytes,包含正负号。
'''2个字节是16位0或1,无正负号时可以表示65536种结果,有正负号时可以表示32768种结果'''
	3.int、integer:大小4bytes,包含正负号。
'''4个字节是32位0或1,无正负号可以表示4294967296种结果,有正负号可以表示2147483648种结果。结果无法表示电话号码'''
	4.bigint:大小:8bytes,包含正负号,可以存储电话号码。

image

验证整形是否带正负号:

说明上述整形类型都是带符号的,可正可负。
我们也可以取消正负号,让所有比特位都用来表示数字:
创建方法: create table 表(字段名 tinyint unsigned)

"""
针对上述效果,添加超出范围的数字可以显示范围末端的数字,这种情况在5.7以上版本都会直接报错,而5.6版本需要手动修改
"""

5.严格模式

1.我们在使用数据库当中存储数据在范围外的数字应该直接报错,而不应该是添加一个范围末端的数字。针对上述需求,我们在5.6版本mysql做以下操作:
	1.1首先输入show variables like '%mode%'查看sql_mode,发现里面没有添加任何东西。就是因为我们在新建my.ini配置文件时没有添加上去。

	1.2直接修配置文件,在my.ini中的服务端mysqld中加入:sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES。再重启mysqld服务端(net stop mysql; net start mysql),发现我们再插入数字超出范围的时候会直接报错。

6.字段类型之浮点型

1.float:float(30,20)指总共300个数.小数点后面20个数。

2.double:double(30,20)指总共300个数.小数点后面20个数。

3.decimal:decimal(30,20)指总共300个数.小数点后面20个数。

根据以上操作得出结论,三者不同在于精度,精度decimal>double>float

7.字段类型之字符类型

1.char:也叫定长。
	char(4):最多4个字符,过长就报错,不够四个空格填充至4个。
2.varchar:也叫变长。
	varchar(4):最多4个字符,过长就报错,不够几位则存几位。

"""
经过上述操作验证:长度不足4都是本身的长度,也就是说char(4)并没,没有我们刚才叙述的效果,那么我们换一种方式再来验证。
"""
3.查看长度:select char_length(字段名) from 表名;查看某个字段下数据的长度。

"""
验证得知:char(4)模式字符添加的数据值长度还是原来的长度,并没有填充至4个。这是因为默认情况下MySQL针对char的存储会自动填充空格和删除空格。
"""

4.char与varchar对比:
	char
		优势:整存整取、速度快()
		劣势:浪费存储空间
	'''如果添加字符长度不等的数据,底层会自动将数据补全至定长。取的时候也是按定长来取,存取方便'''
	varchar
 		优势:节省存储空间 
		劣势:存取数据的速度较char慢	
   '''存的时候会自动保留原来的字符长度,节省空间,但是取出的时候不好取,因为字符长度都不一致。取出的时候可以在每个名字前面加上报头,通过把报头解析出每个名字的长度。所以varchar存取数据的速度较char慢'''
	char与varchar的使用需要结合具体应用场景

8.数字的含义

1.数字在很多地方都是用来表示限制存储数据的长度,但是在整型中数字不是用来限制储存数据的长度。

"""
验证发现int后面的数字设置为3,依然可以添加4位的数字。所以整型后面的数字不是用来限制数字长度的
"""
2.通过验证得知,int后面加参数没有什么用而加上zerofill之后int后面的参数就可以控制显示位数。图中不足5位的会自动补全成5位,超过5位不超过int范围几位就是几位。

综上所述,整形后面不用加数字,如果不写数字创建整型的时候系统也会自动补全成11。

9.字段类型之枚举与集合

1.枚举:在生成表的过程中,很多场景需要让用户来选择选项,比如让用户选择性别。语法结构为:字段名 enum(选项1, 选项2, 选项3)。如果被限制的字段名添加的是enum后面括号中的选项时,就会正常添加。如果不是中间的某个选项,就会直接报错。

2.集合:在生成表的过程中,如果某一项内容有多个选项供用户多选,可以用几何来操作。语法结构为:字段名 set(选项1, 选项2, 选项3)。集合中的选项可以多选,也可以单选,多选时候逗号两边不能加空格。

10.字段类型之日期类型

1.日期类型:
	datetime  年月日时分秒
	date	  年月日
	time  	  时分秒
	year	  年
时间类型和python当中类似,目前我们用自定义的时间尝试插入表,后期可以用系统自动生成,无需我们操作。

原文地址:http://www.cnblogs.com/zkz0206/p/16919736.html

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,请务用于商业用途! 3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 如有链接无法下载、失效或广告,请联系管理员处理! 6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员! 8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载 声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性