当前位置:Gxlcms > 数据库问题 > mysql<二>

mysql<二>

时间:2021-07-01 10:21:17 帮助过:5人阅读

-- ########## 01、MySQL的一些基本概念 ########## 2 -- 学习数据库时,应该具备集合论的思想:把数据形成的结果作为一个集合(无序的) 3 -- 关注点在于作为集合的一系列的数据,而不是集合中的单个孤立的数据 4 5 -- 概念描述 物理描述 6 -- Entity实体 -----> table表 7 -- Attribute属性-----> field字段 8 9 -- ########## 02、MySQL的约束 ########## 10 -- 约束:指的是针对字段进行的条件限制 11 12 -- 1、主键约束:描述表中的一个或多个字段为主键,不允许为空 13 -- A:字段后添加 PRIMARY KEY(适用于单一字段作为主键) 14 -- B:表中的字段定义均完成后,添加PRIMARY KEY(需要设置为主键的字段1, 需要设置为主键的字段2, ... 需要设置为主键的字段n)(适用于多个字段作为主键) 15 16 -- 2、非空约束:描述某一个字段的内容不允许为空 17 -- 字段后添加 NOT NULL 18 19 -- 3、唯一性约束:描述某一个字段的内容是唯一的,允许为空,但是只能出现一次空值 20 -- 字段后添加 UNIQUE 21 22 -- 4、默认约束:指定某个字段的内容的默认值 23 -- 字段后添加 DEFAULT 默认值 24 25 -- 注意:和约束经常搭配使用的【属性值自增】(常常用于INT类型的主键字段上) 26 -- 字段后添加 AUTO_INCREMENT 27 28 -- 综合使用上述的约束及自增,制作一个学生信息表 29 CREATE TABLE student 30 ( 31 -- 考虑到通过【学生编号】对学生进行区分,所以设置【学生编号】作为表的主键 32 -- 同时考虑到人脑记忆编号排到多少了比较困难,所以考虑设置【学生编号】为自增 33 studentid INT AUTO_INCREMENT PRIMARY KEY, 34 -- 考虑【学生姓名】不会是空值,所以在【学生姓名】上使用非空约束 35 studentname VARCHAR(20) NOT NULL, 36 -- 考虑【学生性别】上使用默认约束 37 gender VARCHAR(2) DEFAULT ‘女‘, 38 -- 考虑【联系电话】上使用唯一性约束 39 phone VARCHAR(11) UNIQUE 40 ); 41 42 DESC student; 43 44 -- 1、新增数据 45 INSERT INTO student VALUES(NULL, ‘刘备‘, ‘男‘, ‘110‘); 46 -- 测试一下【学生姓名】为null的情况 47 -- 错误代码: 1048 Column ‘studentname‘ cannot be null 48 INSERT INTO student VALUES(NULL, NULL, ‘男‘, ‘120‘); 49 -- 选取表中的非自增字段赋值插入 50 INSERT INTO student(studentname, gender, phone) VALUES(‘关羽‘, ‘男‘, ‘120‘); -- 编号为2 51 -- 测试一下【联系电话】不唯一的情况 52 -- 错误代码: 1062 Duplicate entry ‘110‘ for key ‘phone‘ 53 INSERT INTO student VALUES(NULL, ‘张飞‘, ‘男‘, ‘110‘); 54 -- 测试一下【学生性别】为默认值的情况 55 INSERT INTO student VALUES(NULL, ‘黄月英‘, DEFAULT, ‘119‘); -- 编号为4 56 57 -- 2、修改数据 58 -- 错误代码: 1062 Duplicate entry ‘110‘ for key ‘phone‘ 59 UPDATE student SET phone = ‘110‘ WHERE studentname = ‘黄月英‘; 60 61 -- 3、删除数据 62 -- 删除满足条件的数据 63 DELETE FROM student WHERE studentname = ‘关羽‘; 64 65 -- 删除全部数据(使用DELETE) 66 DELETE FROM student; 67 68 -- 再插入数据 69 INSERT INTO student VALUES(NULL, ‘孙权‘, ‘男‘, ‘110‘); -- 编号为5 70 INSERT INTO student VALUES(NULL, ‘鲁肃‘, ‘男‘, ‘120‘); -- 编号为6 71 INSERT INTO student VALUES(NULL, ‘大乔‘, DEFAULT, ‘114‘), (NULL, ‘周瑜‘, ‘男‘, ‘119‘); -- 编号为7、8 72 73 -- 删除全部数据(使用TRUNCATE) 74 TRUNCATE TABLE student; 75 76 -- 再插入数据 77 INSERT INTO student VALUES(NULL, ‘曹操‘, ‘男‘, ‘110‘); -- 编号为1 78 INSERT INTO student VALUES(NULL, ‘曹丕‘, ‘男‘, ‘120‘); -- 编号为2 79 80 -- 删除全部数据(使用TRUNCATE) 81 TRUNCATE TABLE student; 82 83 INSERT INTO student VALUES(NULL, ‘甄姬‘, DEFAULT, ‘114‘), (NULL, ‘司马懿‘, ‘男‘, ‘119‘); -- 编号为1、2 84 85 -- 注意:DELETE 和 TRUNCATE 删除全部数据后再插入数据的区别 86 -- 对于DELETE,删除数据后再插入数据,使用自增的字段会在删除的数据基础上继续自增 87 -- 对于TRUNCATE,删除数据后再插入数据,从初始值重新开始 88 89 -- 最简单的查询操作 90 SELECT * FROM student; 91 92 -- ########## 03、MySQL的数据类型 ########## 93 -- 数据类型: 94 -- 1、数值类型(使用UNSIGNED关键字修饰无符号整数,即 零 和 正整数) 95 -- A:整数类型: 96 -- tinyint: 1个字节(-128 ~ 127,如果使用UNSIGNED关键字范围变成0~255) 97 -- smallint: 2个字节 98 -- mediumint: 3个字节 99 -- int: 4个字节 100 -- bigint: 8个字节 101 -- B:小数类型: 102 -- 浮点数类型:(小数点后位数不确定) 103 -- float: 104 -- double: 105 -- 精确小数类型:(小数点后位数确定,推荐使用) 106 -- decimal:decimal(最大位数,小数点后数字的位数即精度) 107 -- 2、字符串类型 108 -- char: 定长字符串 109 -- varchar: 变长字符串 110 -- tinytext: 111 -- mediumtext: 112 -- text: 文本类型 113 -- longtext: 114 -- 3、日期类型 115 -- date : 3个字节,格式:YYYY-MM--DD 116 -- time : 3个字节,格式:HH:ii:ss 117 -- year : 1个字节,格式:YYYY 118 -- datetime : 8个字节,格式:YYYY-MM--DD HH:ii:ss 119 -- timestamp : 8个字节,格式:YYYY-MM--DD HH:ii:ss 120 -- 4、复合类型 121 -- enum类型 :枚举类型,只允许从一个集合中取出某一个值,集合最多65535个元素 122 -- set类型 :集合类型,允许从一个集合中取出多个值,集合最多64个元素 123 -- 5、二进制类型(作为了解即可) 124 -- binary 125 -- varbinary 126 -- bit 127 -- tinyblob 128 -- mediumblob 129 -- blob 130 -- longblob 131 -- **************************************************************************** 132 -- 1、数值类型 133 CREATE TABLE test_int 134 ( 135 field1 TINYINT, 136 field2 TINYINT UNSIGNED 137 ); 138 139 -- 插入成功 140 INSERT INTO test_int VALUES(-3, 4); 141 -- 错误代码: 1264 Out of range value for column ‘field2‘ at row 1 142 INSERT INTO test_int VALUES(-3, -4); 143 -- 插入成功 144 INSERT INTO test_int VALUES(-128, 255); 145 -- 错误代码: 1264 Out of range value for column ‘field1‘ at row 1 146 INSERT INTO test_int VALUES(-129, 256); 147 148 SELECT * FROM test_int; 149 150 CREATE TABLE test_numeric 151 ( 152 field1 DECIMAL(10, 2), 153 field2 FLOAT 154 ); 155 156 INSERT INTO test_numeric VALUES(123.456, 987.654); -- field1显示为123.46 157 INSERT INTO test_numeric VALUES(123.454, 987.654); -- field1显示为123.45 158 INSERT INTO test_numeric VALUES(123.455, 987.654); -- field1显示为123.46 159 -- 根据上面的测试,得知,对于decimal类型的数据,小数点位数超过设置位数,但总长度没有超出设置的总位数的,按四舍五入的规则 160 161 TRUNCATE TABLE test_numeric; 162 -- 修改test_numeric表的field1字段 163 ALTER TABLE test_numeric MODIFY field1 DECIMAL(4, 2); 164 DESC test_numeric; 165 166 -- 根据上面的测试,得知,对于decimal类型的数据,小数点位数超过设置位数,但总长度超出设置的总位数的,无法插入成功 167 -- 错误代码: 1264 Out of range value for column ‘field1‘ at row 1 168 INSERT INTO test_numeric VALUES(123.456, 987.654); 169 170 SELECT * FROM test_numeric; 171 172 -- **************************************************************************** 173 -- 2、字符串类型 174 -- CHAR:定长字符串,存储字符时,按照设定好的长度进行存储,存储不足长度的字符时,不足的部分会以空格补足 175 -- VARCHAR:变长字符串,存储字符时,按照放入其中的字符内容的实际长度进行存储 176 -- 注意:MySQL处理时是按照上述的规则进行处理的,但是显示时,定长字符串不足长度的部分的空格不会显示 177 178 CREATE TABLE test_character 179 ( 180 field1 VARCHAR(4), 181 field2 CHAR(4) 182 ); 183 184 -- 左右均无空格 185 INSERT INTO test_character VALUES(‘sb‘, ‘nb‘); 186 -- 左侧有空格 187 INSERT INTO test_character VALUES(‘ sb‘, ‘ nb‘); 188 -- 右侧有空格 189 INSERT INTO test_character VALUES(‘sb ‘, ‘nb ‘); 190 -- 左右均有空格 191 INSERT INTO test_character VALUES(‘ sb ‘, ‘ nb ‘); 192 193 -- 注意: 194 -- 以UTF-8字符集存储,一个汉字3个长度 195 -- 以GBK字符集存储,一个汉字2个长度 196 197 -- MySQL常用的函数: 198 -- LENGTH():长度函数,统计的是标准字符个数(按一个长度计算),非标准字符个数(按字符集的不同有所不同,以UTF-8字符集存储,一个汉字3个长度) 199 -- CHAR_LENGTH():字符长度函数,统计的是字段内容中字符的个数(一个字符按一个长度计算) 200 201 -- 从上面四条测试数据,得知,对于CHAR类型,右侧的空格不算为长度;对于VARCHAR类型,两侧空格都算为长度 202 SELECT LENGTH(field1), LENGTH(field2) FROM test_character; 203 SELECT CHAR_LENGTH(field1), CHAR_LENGTH(field2) FROM test_character; 204 205 SELECT * FROM test_character; 206 207 TRUNCATE TABLE test_character; 208 209 -- 错误代码: 1064 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 ‘field2 char(8)‘ at line 1 210 ALTER TABLE test_character MODIFY field1 VARCHAR(8), field2 CHAR(8); 211 ALTER TABLE test_character MODIFY field1 VARCHAR(8); 212 ALTER TABLE test_character MODIFY field2 CHAR(8); 213 214 DESC test_character; 215 216 217 -- 左右均无空格 218 INSERT INTO test_character VALUES(‘sb朝鲜‘, ‘nb天朝‘); 219 -- 左侧有空格 220 INSERT INTO test_character VALUES(‘ sb朝鲜‘, ‘ nb天朝‘); 221 -- 右侧有空格 222 INSERT INTO test_character VALUES(‘sb朝鲜 ‘, ‘nb天朝 ‘); 223 -- 左右均有空格 224 INSERT INTO test_character VALUES(‘ sb朝鲜 ‘, ‘ nb天朝 ‘); 225 226 227 SELECT LENGTH(field1), LENGTH(field2) FROM test_character; 228 SELECT CHAR_LENGTH(field1), CHAR_LENGTH(field2) FROM test_character; 229 230 -- 错误代码: 1406 Data too long for column ‘field1‘ at row 1 231 -- 定义的field1、field2的长度指的是字符长度 232 INSERT INTO test_character VALUES(‘中华人民共和国万岁‘, ‘中华人民共和国万岁‘); 233 234 SELECT * FROM test_character; 235 236 -- **************************************************************************** 237 -- 3、日期类型 238 CREATE TABLE test_date_time 239 ( 240 field1 DATE, 241 field2 DATETIME 242 ); 243 244 INSERT INTO test_date_time VALUES(‘2016-09-21‘, ‘2016-09-21 10:55:30‘); 245 INSERT INTO test_date_time VALUES(‘20160921‘, ‘20160921105530‘); 246 INSERT INTO test_date_time VALUES(‘1816-09-21‘, ‘1816-09-21 10:55:30‘); 247 -- 错误代码: 1292 Incorrect date value: ‘1816-13-32‘ for column ‘field1‘ at row 1 248 INSERT INTO test_date_time VALUES(‘1816-13-32‘, ‘18161332256162‘); 249 250 -- MySQL常用的函数: 251 -- CURRENT_DATE()函数:获取当前的日期 252 -- CURRENT_TIMESTAMP()函数:获取当前的日期和时间 253 -- NOW()函数:获取当前的日期和时间 254 INSERT INTO test_date_time VALUES(CURRENT_DATE(), CURRENT_TIMESTAMP()); 255 INSERT INTO test_date_time VALUES(CURRENT_DATE(), NOW()); 256 257 SELECT * FROM test_date_time; 258 259 -- **************************************************************************** 260 -- 4、复合类型 261 CREATE TABLE test_enum_set 262 ( 263 field1 ENUM(‘男‘, ‘女‘), 264 field2 SET(‘听音乐‘, ‘玩游戏‘, ‘运动‘, ‘购物‘) 265 ); 266 267 DESC test_enum_set; 268 269 INSERT INTO test_enum_set VALUES(‘男‘, ‘听音乐,玩游戏‘); 270 -- 错误代码: 1265 Data truncated for column ‘field1‘ at row 1 271 INSERT INTO test_enum_set VALUES(‘男,女‘, ‘听音乐,玩游戏‘); 272 -- 错误代码: 1265 Data truncated for column ‘field1‘ at row 1 273 -- 注意:复合类型对于插入的数据内容可以进行限制 274 INSERT INTO test_enum_set VALUES(‘男孩‘, ‘听音乐,玩游戏‘); 275 276 -- 插入SET类型的字段的值和设置的值的顺序不一致,也可以正常插入 277 -- 但是显示时,以设置的值得顺序为准,从中挑选选中的值显示 278 INSERT INTO test_enum_set VALUES(‘女‘, ‘购物,听音乐‘); 279 280 SELECT * FROM test_enum_set; 281 282 -- **************************************************************************** 283 -- 数据库学习中的重点和难点:DQL查询语句 284 285 -- # 查询语句关键字执行顺序图 286 (8)SELECT (9)DISTINCT <select_list> 287 (1)FROM <left_table> 288 (3)<join_type> JOIN <right_table> 289 (2)ON <join_condition> 290 (4)WHERE <where_condition> 291 (5)GROUP BY <group_by_list> 292 (6)WITH {CUBE|ROLLUP} 293 (7)HAVING <having_condition> 294 (10)ORDER BY <order_by_list> 295 (11)LIMIT <limit_number>; 296 297 -- ########## 04、MySQL的基本查询 ########## 298 -- 全能通配符:* 匹配所有的字段 299 SELECT * FROM student; 300 301 -- 注意:在实际工作中,不建议使用*星号通配符,因为效率较低 302 -- 推荐使用指定列的形式(即指明要查询的属性列):SELECT COLUMNLIST FROM 表名; 303 304 -- 查询全部列 305 SELECT studentid, studentname, gender, phone FROM student; 306 307 -- 查询部分列 308 SELECT studentname, gender, phone FROM student; 309 310 -- 注意:表的字段名一般不包含空格,如果字段名中有空格,那么在查询属性列时,需要使用重音符``包在字段名外 311 -- 形如:`有空格的字段名` 312 313 -- ########## 05、MySQL的直接量 ########## 314 -- 直接量:选择特定的值作为一列,该值和表中的数据没有直接的关系 315 316 SELECT ‘China‘; 317 SELECT 123; 318 SELECT ‘中国安徽‘, studentname FROM student; 319 320 -- 注意:在执行表的查询时使用直接量,会在得到的结果行的每一行都重复出现直接量(根据查询的执行顺序) 321 322 -- 算术运算(+-*/%) 323 SELECT 1+2; 324 SELECT 6-4; 325 SELECT 3*5; 326 SELECT 7/3; -- 2.3333 327 SELECT 7%3; -- 1 328 329 -- MySQL的常用函数: 330 -- CONCAT:字符连接函数,用于连接字段,CONCAT(连接内容1, 连接内容2, ... 连接内容n) 331 SELECT CONCAT(‘中国‘, ‘安徽‘); 332 SELECT CONCAT(2, 1, 4); 333 334 -- ########## 06、AS起别名 ########## 335 SELECT * FROM student; 336 337 -- 1、使用AS:给字段起别名,格式:字段名 AS 别名 338 -- 使用场景:字段名难以识别 339 SELECT studentname AS 学生姓名, phone AS 联系电话 FROM student; 340 341 -- 2、使用AS:给表起别名,格式:表名 AS 别名 342 -- 使用场景:表名很长或者需要更清晰的区分表名时或者查询的列存在重名时 343 344 -- 给表起了别名,但是对于字段不使用表的别名(在没有出现重复的字段列时)没有问题 345 SELECT studentname, phone FROM student AS t1; 346 347 -- 给表起了别名,并对字段使用表的别名,在出现重复的字段列时,可以清楚的区分是哪一个表的字段 348 SELECT t1.`studentname`, t1.`phone` FROM student AS t1; 349 350 -- 如下两种写法可以理解为:别名就是表自身 351 SELECT student.`studentname`, student.`phone` FROM student; 352 SELECT student.`studentname`, student.`phone` FROM student AS student; 353 354 -- 可以同时对字段和表使用别名 355 SELECT t1.`studentname` AS 学生姓名, t1.`phone` AS 联系电话 FROM student AS t1; 356 357 -- 对字段和表起别名时,也可以省略掉AS关键字,但是不能省略原名 和 别名 之间的空格 358 SELECT t1.`studentname` 学生姓名, t1.`phone` 联系电话 FROM student t1; 359 360 -- 注意:经过对比,显然使用AS起别名的形式可读性更好,强制使用这种 361 362 -- ########## 07、常用函数 ########## 363 -- 1、字符函数: 364 -- LEFT()、RIGHT()、SUBSTRING()、SUBSTR()、LENGTH()、CHAR_LENGTH()、LTRIM()、RTRIM()、TRIM()、CONCAT()、UPPER()、LOWER() 365 SELECT LEFT(‘java‘, 3) AS 左截取; -- jav 366 SELECT LEFT(‘不明觉厉‘, 3) AS 左截取; -- 不明觉 367 368 SELECT RIGHT(‘java‘, 3) AS 右截取; -- ava 369 SELECT RIGHT(‘不明觉厉‘, 3) AS 右截取; -- 明觉厉 370 371 -- SUBSTRING()函数的第2个参数表示从哪一个位置开始,左侧的起始位置为1 372 SELECT SUBSTRING(‘temptation‘, 3) AS 子串; -- mptation 373 SELECT SUBSTRING(‘temptation‘, 1) AS 子串; -- temptation 374 SELECT SUBSTRING(‘temptation‘, 0) AS 子串; -- 无内容 375 376 SELECT SUBSTRING(‘temptation‘, 3, 5) AS 子串; -- mptat 377 SELECT SUBSTRING(‘temptation‘, 3, 0) AS 子串; -- 无内容 378 SELECT SUBSTRING(‘temptation‘, 3, -1) AS 子串; -- 无内容 379 SELECT SUBSTRING(‘temptation‘, 3, 10) AS 子串; -- mptation 380 381 -- SUBSTR()函数,效果和SUBSTRING()函数一致 382 SELECT SUBSTR(‘temptation‘, 3) AS 子串; -- mptation 383 SELECT SUBSTR(‘temptation‘, 1) AS 子串; -- temptation 384 SELECT SUBSTR(‘temptation‘, 0) AS 子串; -- 无内容 385 386 SELECT SUBSTR(‘temptation‘, 3, 5) AS 子串; -- mptat 387 SELECT SUBSTR(‘temptation‘, 3, 0) AS 子串; -- 无内容 388 SELECT SUBSTR(‘temptation‘, 3, -1) AS 子串; -- 无内容 389 SELECT SUBSTR(‘temptation‘, 3, 10) AS 子串; -- mptation 390 391 -- LENGTH()函数 和 CHAR_LENGTH()函数参见数据类型中的讲解 392 393 SELECT LENGTH(‘ temp tation ‘) AS 原始长度; 394 395 -- LTRIM()函数:去除左侧空格 396 SELECT LTRIM(‘ temp tation ‘) AS 去除左侧空格; 397 SELECT LENGTH(LTRIM(‘ temp tation ‘)) AS 去除左侧空格后的长度; 398 399 -- RTRIM()函数:去除右侧空格 400 SELECT RTRIM(‘ temp tation ‘) AS 去除右侧空格; 401 SELECT LENGTH(RTRIM(‘ temp tation ‘)) AS 去除右侧空格后的长度; 402 403 -- 需求:去除两侧空格 404 -- 写法1、综合使用LTRIM()函数 和 RTRIM()函数 405 SELECT LTRIM(RTRIM(‘ temp tation ‘)) AS 去除两侧空格; 406 SELECT LENGTH(LTRIM(RTRIM(‘ temp tation ‘))) AS 去除两侧空格后的长度; 407 -- 写法2、使用TRIM()函数 408 SELECT TRIM(‘ temp tation ‘) AS 去除两侧空格; 409 SELECT LENGTH(TRIM(‘ temp tation ‘)) AS 去除两侧空格后的长度; 410 411 -- UPPER()函数:全部大写 412 SELECT UPPER(‘Temptation‘) AS 全部大写; 413 414 -- LOWER()函数:全部小写写 415 SELECT LOWER(‘TempTation‘) AS 全部小写; 416 417 -- 2、日期/时间函数 418 -- NOW()、CURRENT_DATE()、CURRENT_TIME()、CURRENT_TIMESTAMP()、DATE_FORMART()、DATEDIFF() 419 SELECT CURRENT_DATE() AS 当前日期; -- 2016-09-21 420 SELECT CURRENT_TIME() AS 当前时间; -- 15:20:48 421 SELECT CURRENT_TIMESTAMP() AS 当前日期和时间; -- 2016-09-21 15:20:48 422 SELECT NOW() AS 当前日期和时间; -- 2016-09-21 15:20:48 423 424 -- DATE_FORMART()对日期时间进行格式化 425 -- DATE_FORMART()常用格式: 426 SELECT DATE_FORMAT(NOW(), ‘%y‘) AS 年份; -- 16 427 SELECT DATE_FORMAT(NOW(), ‘%m‘) AS 月份; -- 09 428 SELECT DATE_FORMAT(NOW(), ‘%d‘) AS 天; -- 21 429 SELECT DATE_FORMAT(NOW(), ‘%Y‘) AS 完整年份; -- 2016 430 SELECT DATE_FORMAT(NOW(), ‘%M‘) AS 英文月份; -- September 431 SELECT DATE_FORMAT(NOW(), ‘%D‘) AS 天的序数词; -- 21st 432 433 SELECT DATE_FORMAT(NOW(), ‘%h‘) AS 小时(12小时制); -- 03 434 SELECT DATE_FORMAT(NOW(), ‘%i‘) AS 分钟; -- 25 435 SELECT DATE_FORMAT(NOW(), ‘%s‘) AS 秒; -- 32 436 SELECT DATE_FORMAT(NOW(), ‘%H‘) AS 小时(24小时制); -- 15 437 SELECT DATE_FORMAT(NOW(), ‘%I‘) AS 分钟; -- 没有这种形式 438 SELECT DATE_FORMAT(NOW(), ‘%S‘) AS 秒; -- 53 439 440 -- DATEDIFF()函数计算间隔天数,结果 = 第1个参数 - 第2个参数 441 SELECT DATEDIFF(NOW(), ‘2016-09-20‘) AS 间隔天数; -- 1 442 SELECT DATEDIFF(NOW(), ‘2016-09-22‘) AS 间隔天数; -- -1 443 SELECT DATEDIFF(NOW(), ‘2016-09-10‘) AS 间隔天数; -- 11 444 SELECT DATEDIFF(NOW(), ‘2015-02-14‘) AS 间隔天数; -- 585 445 SELECT DATEDIFF(NOW(), ‘2016-09-21‘) AS 间隔天数; -- 0 446 447 -- 3、数值函数 448 -- ROUND()、RAND()、PI() 449 450 -- ROUND()函数:获取四舍五入的结果 451 -- A:只有一个参数,那么按照整数部分进行四舍五入 452 -- B:有两个参数,那么小数部分按照第2个参数的位数进行四舍五入,如果小数部分计算完毕就推到整数部分进行计算 453 SELECT ROUND(123); -- 123 454 SELECT ROUND(125); -- 125 455 SELECT ROUND(123.456); -- 123 456 SELECT ROUND(123.567); -- 124 457 SELECT ROUND(123.678); -- 124 458 459 SELECT ROUND(123.456, 3); -- 123.456 460 SELECT ROUND(123.456, 2); -- 123.46 461 SELECT ROUND(123.455, 2); -- 123.46 462 SELECT ROUND(123.454, 2); -- 123.45 463 SELECT ROUND(123.456, 1); -- 123.5 464 SELECT ROUND(123.456, 0); -- 123 465 SELECT ROUND(123.456, -1); -- 120 466 467 -- RAND()函数:每次随机出不同的值,范围在0~1之间 468 SELECT RAND(); 469 -- RAND(参数)函数:范围在0~1之间,但是每次随机出的是相同的那个随机数 470 SELECT RAND(123); -- 0.9277428611440052 471 SELECT RAND(120); -- 0.17719353286288075 472 473 -- PI()函数:获取圆周率 474 SELECT PI(); -- 3.141593 475 476 -- 需求:如何获取圆周率的小数点后两位,形如:3.14 477 SELECT ROUND(PI(), 2) AS 获取圆周率的小数点后两位; 478 SELECT SUBSTRING(PI(), 1, 4) AS 获取圆周率的小数点后两位; 479 SELECT SUBSTR(PI(), 1, 4) AS 获取圆周率的小数点后两位; 480 SELECT LEFT(PI(), 4) AS 获取圆周率的小数点后两位; 481 482 -- 4、转换函数 483 -- CAST()、IFNULL() 484 485 -- CAST()函数:将某个表达式转换为某种类型,格式:CAST(Expression AS DataType) 486 SELECT ‘2016-09-21‘ AS 日期, CAST(‘2016-09-21‘ AS DATETIME) AS 日期和时间; -- 2016-09-21 2016-09-21 00:00:00 487 SELECT CAST(‘2016ABCD‘ AS DATETIME) AS 日期和时间; -- (NULL) 488 489 -- IFNULL()函数:判断字段内容为NULL时做什么处理,格式:IFNULL(字段名, 替换值) 490 DESC student; 491 SELECT * FROM student; 492 -- 查看一下student表,电话可以为NULL 493 INSERT INTO student VALUES(NULL, ‘荀彧‘, ‘男‘, NULL); 494 495 SELECT studentname AS 学生姓名, IFNULL(phone, ‘未知号码‘) AS 联系电话 FROM student;

 

mysql<二>

标签:express   表达式   rom   signed   音乐   min   row   substring   cube   

人气教程排行