封面
版权信息
前言
第1章 数据库系统与SQL语言概述
1.1 数据库系统与数据模型
1.1.1 基本术语
1.1.2 数据库技术的发展
1.1.3 数据模型
1.2 数据库系统的体系结构
1.2.1 数据库系统的三级模式结构
1.2.2 数据库管理系统(DBMS)
1.2.3 数据库系统的工作流程
1.3 关系数据库的简单介绍
1.3.1 关系数据库的基本特性
1.3.2 关系数据库的设计规范
1.4 SQL语言概述
1.4.1 SQL语言的发展
1.4.2 SQL语言的功能
1.4.3 SQL语言的执行形式
1.4.4 SQL语句结构
1.4.5 SQL的环境
1.4.6 SQL DBMS的客户机/服务器模型
1.4.7 SQL语言的扩展
1.5 小结
第2章 Transact-SQL与SQL Server 2005
2.1 SQL Server 2005及其简单应用
2.1.1 SQL Server 2005的版本
2.1.2 SQL Server Management Studio
2.1.3 使用Management Studio创建数据库
2.1.4 使用Management Studio创建、查看、编辑表
2.1.5 使用Management Studio编辑、运行T-SQL语言
2.2 Transact-SQL语言
2.2.1 Transact-SQL概述
2.2.2 Transact-SQL的标识符
2.2.3 对象命名规则
2.2.4 Transact-SQL的主要组成
2.2.5 Transact-SQL的其他一些常用命令
2.3 Transact-SQL在SQL Server中的执行
2.3.1 解析Transact-SQL语句
2.3.2 编译Transact-SQL语句
2.3.3 执行Transact-SQL语句
2.4 小结
第3章 数据库与表的操作
3.1 创建、修改和删除数据库
3.1.1 SQL Server数据库的组成
3.1.2 创建数据库——CREATE DATABASE
3.1.3 修改数据库——ALTER DATABASE
3.1.4 查看数据库信息——sp_helpdb、sp_spaceused
3.1.5 删除数据库——DROP DATABASE
3.2 SQL Server中的表
3.2.1 表的结构及设计
3.2.2 Transact-SQL对表的要求
3.2.3 表的类型
3.3 SQL Server 2005中的数据类型
3.3.1 数字类型
3.3.2 时间和日期类型
3.3.3 字符数据类型
3.3.4 二进制数据类型
3.3.5 其他数据类型
3.3.6 用户自定义数据类型
3.3.7 数据类型同义词
3.4 创建表(CREATE TABLE)
3.4.1 实例表设计
3.4.2 创建基本表——CREATE TABLE
3.4.3 指定值非空——NOT NULL
3.4.4 指定列的默认值——DEFAULT
3.5 编辑表结构(ALTER TABLE)
3.5.1 添加列或约束——ADD
3.5.2 修改列的定义——ALTER COLUMN
3.5.3 删除列——DROP COLUMN
3.6 重命名、删除表
3.6.1 改变表的名字——sp_rename
3.6.2 删除基本表——DROP TABLE
3.7 小结
第4章 基本的查询
4.1 SELECT语句的结构与执行
- APP免费
4.1.1 SELECT语句的语法结构
- APP免费
4.1.2 SELECT各子句的顺序及功能
- APP免费
4.1.3 SELECT语句各子句的执行
- APP免费
4.2 最简单的查询
- APP免费
4.2.1 向实例表中添加数据
- APP免费
4.2.2 查询表中列的数据——FROM子句
- APP免费
4.2.3 去除结果的重复信息——DISTINCT
- APP免费
4.2.4 查询所有列——“*”
- APP免费
4.2.5 进行无数据源检索
- APP免费
4.2.6 返回查询的部分数据——TOP
- APP免费
4.3 带有搜索条件的查询
- APP免费
4.3.1 简单的选择查询——WHERE
- APP免费
4.3.2 使用比较表达式
- APP免费
4.3.3 使用基本的逻辑表达式——NOT、AND、OR
- APP免费
4.3.4 空值(NULL)的判断——IS [NOT] NULL
- APP免费
4.3.5 限定数据范围——BETWEEN
- APP免费
4.3.6 限制检索数据的范围——IN
- APP免费
4.3.7 模糊查询——LIKE
- APP免费
4.4 排序查询结果
- APP免费
4.4.1 基本排序——ORDER BY
- APP免费
4.4.2 对多列进行排序
- APP免费
4.5 小结
- APP免费
第5章 查询中表达式与函数的使用
- APP免费
5.1 SQL Server中的运算符
- APP免费
5.1.1 算术运算符
- APP免费
5.1.2 位运算符
- APP免费
5.1.3 比较运算符
- APP免费
5.1.4 逻辑运算符
- APP免费
5.1.5 字符串连接符
- APP免费
5.1.6 赋值运算符
- APP免费
5.1.7 运算符的优先级
- APP免费
5.2 SELECT子句中表达式的使用
- APP免费
5.2.1 使用连接符连接列——“+”
- APP免费
5.2.2 操作查询的列名——“=”、“AS”
- APP免费
5.2.3 对重命名列的操作
- APP免费
5.2.4 算术表达式的使用
- APP免费
5.3 数学函数的使用
- APP免费
5.3.1 三角函数
- APP免费
5.3.2 计算函数
- APP免费
5.3.3 近似函数
- APP免费
5.4 字符处理函数的使用
- APP免费
5.4.1 SQL Server 2005中的字符处理函数
- APP免费
5.4.2 字符的转换处理函数
- APP免费
5.4.3 字符串的提取函数
- APP免费
5.4.4 其他字符串处理函数
- APP免费
5.5 日期、时间处理函数的使用
- APP免费
5.5.1 SQL Server 2005中的日期处理函数
- APP免费
5.5.2 获取当前时间——GETDATE、GETUTCDATE、CURRENT_TIMESTAMP
- APP免费
5.5.3 增加、减少时间——DATEADD
- APP免费
5.5.4 获取时间间隔——DATEDIFF
- APP免费
5.5.5 获取时间整数值——DAY、MONTH、YEAR、DATEPART
- APP免费
5.5.6 获取时间的字符串——DATENAME
- APP免费
5.5.7 常用的时间计算
- APP免费
5.6 类型转换函数的使用
- APP免费
5.6.1 类型转换——CAST
- APP免费
5.6.2 类型转换——CONVERT
- APP免费
5.7 小结
- APP免费
第6章 系统函数、聚合函数与分组查询
- APP免费
6.1 系统函数的使用
- APP免费
6.1.1 信息查询相关系统函数
- APP免费
6.1.2 判断、分类系统函数
- APP免费
6.1.3 统计系统函数
- APP免费
6.2 聚合函数的使用
- APP免费
6.2.1 聚合函数的种类
- APP免费
6.2.2 计数函数——COUNT
- APP免费
6.2.3 求和函数——SUM
- APP免费
6.2.4 均值函数——AVG
- APP免费
6.2.5 最大值/最小值函数——MAX/MIN
- APP免费
6.2.6 统计函数——STDEV、STDEVP、VAR、VARP
- APP免费
6.2.7 聚合函数的重值处理——ALL、DISTINCT
- APP免费
6.2.8 聚合函数的执行机理
- APP免费
6.3 分组查询
- APP免费
6.3.1 简单分组——GROUP BY
- APP免费
6.3.2 多列分组
- APP免费
6.3.3 分组查询中NULL值的处理
- APP免费
6.3.4 汇总数据运算符——CUBE、ROLLUP
- APP免费
6.3.5 区分不同的NULL值——GROUPING
- APP免费
6.3.6 筛选分组结果——HAVING
- APP免费
6.3.7 多级分类汇总——COMPUTE
- APP免费
6.3.8 对分组聚合结果进行聚合分析
- APP免费
6.4 小结
- APP免费
第7章 数据连接与多表查询
- APP免费
7.1 多表连接的基本概念与实现
- APP免费
7.1.1 连接的概念
- APP免费
7.1.2 连接的类型与实现
- APP免费
7.1.3 创建实例表ReaderInfo
- APP免费
7.2 简单多表查询的实现
- APP免费
7.2.1 使用FROM子句实现多表查询
- APP免费
7.2.2 使用WHERE子句指定连接条件
- APP免费
7.2.3 使用别名作为表名的简写
- APP免费
7.2.4 自连接表进行查询
- APP免费
7.3 使用JOIN关键字实现表的连接
- APP免费
7.3.1 基本连接语法
- APP免费
7.2.2 内部连接——INNER JOIN
- APP免费
7.3.3 外部连接——OUTER JOIN
- APP免费
7.3.4 交叉连接——CROSS JOIN
- APP免费
7.3.5 连接与空值
- APP免费
7.3.6 表的连接与聚合分析
- APP免费
7.4 集合运算
- APP免费
7.4.1 关系的集合运算
- APP免费
7.4.2 集合并运算——UNION
- APP免费
7.4.3 多表的UNION操作
- APP免费
7.4.4 UNION与JOIN的区别
- APP免费
7.4.5 集合差/集合交运算——EXCEPT/INTERSECT
- APP免费
7.4.6 集合运算在Transact-SQL语句中的使用原则
- APP免费
7.5 小结
- APP免费
第8章 数据库数据操作
- APP免费
8.1 向表中添加数据——INSERT
- APP免费
8.1.1 INSERT命令的基本语法
- APP免费
8.1.2 整行插入数据
- APP免费
8.1.3 INSERT操作中NULL值的处理
- APP免费
8.1.4 INSERT操作中默认值的处理
- APP免费
8.1.5 INSERT操作中唯一值的处理
- APP免费
8.1.6 使用INSERT…SELECT插入数据
- APP免费
8.2 修改和更新表中的数据——UPDATE
- APP免费
8.2.1 UPDATE命令的基本语法
- APP免费
8.2.2 使用UPDATE更新数据行
- APP免费
8.2.3 使用FROM和WHERE子句根据多表连接更新数据
- APP免费
8.2.4 大值数据类型字段值的更新
- APP免费
8.2.5 使用OPENROWSET和BULK来操作大型数据对象
- APP免费
8.3 删除表中的数据——DELETE
- APP免费
8.3.1 DELETE命令的基本语法
- APP免费
8.3.2 使用DELETE删除行
- APP免费
8.3.3 使用TRUNCATE TABLE删除表中的所有数据
- APP免费
8.4 BLOB(text、ntext和image)数据处理
- APP免费
8.4.1 写入BLOB数据——WRITETEXT
- APP免费
8.4.2 更新BLOB数据——UPDATETEXT
- APP免费
8.4.3 TEXTSIZE选项和@@TEXTSIZE函数
- APP免费
8.5 OUTPUT子句
- APP免费
8.5.1 基本语法
- APP免费
8.5.2 OUTPUT子句的使用
- APP免费
8.6 表中数据的复制和导入、导出操作
- APP免费
8.6.1 复制表中数据——SELECT…INTO
- APP免费
8.6.2 导入、导出数据——BCP工具
- APP免费
8.7 小结
- APP免费
第9章 子查询及FOR XML子句的使用
- APP免费
9.1 子查询基础
- APP免费
9.1.1 相关子查询与非相关子查询
- APP免费
9.1.2 子查询的组成
- APP免费
9.1.3 子查询的使用方式及限制
- APP免费
9.2 比较运算符引入返回单值的子查询
- APP免费
9.2.1 比较运算符引入子查询
- APP免费
9.2.2 在子查询中使用聚合函数返回单值
- APP免费
9.3 IN或修改的比较运算符引入返回多值的子查询
- APP免费
9.3.1 使用[NOT]IN引入子查询
- APP免费
9.3.2 使用修改的比较运算符引入返回多值的子查询
- APP免费
9.4 EXISTS引入的存在测试子查询
- APP免费
9.4.1 使用EXISTS的子查询
- APP免费
9.4.2 EXISTS子查询的使用
- APP免费
9.4.3 使用EXISTS子查询检查表中的重复行
- APP免费
9.5 子查询的其他应用
- APP免费
9.5.1 在子查询中使用TOP关键字
- APP免费
9.5.2 在SELECT子句中使用子查询
- APP免费
9.5.3 在HAVING子句中使用子查询
- APP免费
9.5.4 在数据操作语言(DML)中使用子查询
- APP免费
9.6 FOR XML子句
- APP免费
9.6.1 FOR XML子句的基本语法
- APP免费
9.6.2 FOR XML RAW模式及使用
- APP免费
9.6.3 FOR XML AUTO模式及使用
- APP免费
9.6.4 FOR XML EXPLICIT模式及使用
- APP免费
9.6.5 FOR XML PATH模式及使用
- APP免费
9.6.6 使用TYPE指令返回xml数据类型
- APP免费
9.6.7 在数据操作语言(DML)中使用FOR XML子句
- APP免费
9.7 小结
- APP免费
第10章 表的约束、索引与视图
- APP免费
10.1 表键及其使用
- APP免费
10.1.1 表约束的种类
- APP免费
10.1.2 约束的创建
- APP免费
10.1.3 主键约束——PRIMARY KEY
- APP免费
10.1.4 外键约束——FOREIGN KEY
- APP免费
10.1.5 外键与级联引用完整性约束
- APP免费
10.1.6 标识符列——IDENTITY属性
- APP免费
10.1.7 查看、更改标识值——DBCC CHECKIDENT
- APP免费
10.2 表的约束
- APP免费
10.2.1 唯一性约束——UNIQUE
- APP免费
10.2.2 校验约束——CHECK
- APP免费
10.2.3 约束的删除、修改和禁用
- APP免费
10.3 索引及其操作
- APP免费
10.3.1 索引的基本知识
- APP免费
10.3.2 创建索引——CREATE INDEX
- APP免费
10.3.3 非聚集索引的创建和使用——NONCLUSTERED
- APP免费
10.3.4 聚集索引的创建和使用——CLUSTERED
- APP免费
10.3.5 聚集索引和非聚集索引的使用
- APP免费
10.3.6 查看、修改和删除索引
- APP免费
10.3.7 索引的使用准则
- APP免费
10.4 视图及其应用
- APP免费
10.4.1 视图的基本知识
- APP免费
10.4.2 创建视图——CREATE VIEW
- APP免费
10.4.3 查询视图的定义和相关信息
- APP免费
10.4.4 修改、更新和删除视图
- APP免费
10.4.5 通过视图修改表中记录
- APP免费
10.4.6 索引视图及其使用
- APP免费
10.5 小结
- APP免费
第11章 存储过程与用户自定义函数
- APP免费
11.1 理解存储过程
- APP免费
11.1.1 存储过程的基本概念
- APP免费
11.1.2 存储过程的优点
- APP免费
11.1.3 存储过程的种类
- APP免费
11.2 程序流控制语句
- APP免费
11.2.1 SQL Server中的程序流控制语句
- APP免费
11.2.2 IF…ELSE条件选择结构
- APP免费
11.2.3 BEGIN…END语句块
- APP免费
11.2.4 CASE结构
- APP免费
11.2.5 WHILE循环结构
- APP免费
11.2.6 WAITFOR等待语句
- APP免费
11.3 存储过程的创建和使用
- APP免费
11.3.1 系统存储过程
- APP免费
11.3.2 创建存储过程——CREATE PROCEDURE
- APP免费
11.3.3 存储过程的创建实例
- APP免费
11.3.4 执行存储过程——EXECUTE
- APP免费
11.3.5 查看、修改和删除存储过程
- APP免费
11.4 用户自定义函数的创建和使用
- APP免费
11.4.1 创建标量型自定义函数
- APP免费
11.4.2 创建内联表值自定义函数
- APP免费
11.4.3 创建多语句表值自定义函数
- APP免费
11.4.4 调用用户自定义函数
- APP免费
11.4.5 修改、查询和删除自定义函数
- APP免费
11.5 小结
- APP免费
第12章 触发器与错误处理
- APP免费
12.1 触发器的基本概念
- APP免费
12.1.1 触发器简介
- APP免费
12.1.2 触发器的类型
- APP免费
12.1.3 触发器的作用及使用
- APP免费
12.1.4 触发器的执行环境
- APP免费
12.2 创建和使用DML触发器
- APP免费
12.2.1 AFTER DML触发器的创建语法
- APP免费
12.2.2 AFTER DML触发器的创建实例
- APP免费
12.2.3 测试对指定列的UPDATE操作
- APP免费
12.2.4 INSTEAD OF DML触发器的创建和使用
- APP免费
12.2.5 嵌套触发器
- APP免费
12.2.6 递归触发器
- APP免费
12.2.7 查询DML触发器的相关信息
- APP免费
12.3 创建和使用DDL触发器
- APP免费
12.3.1 DDL触发器的创建语法
- APP免费
12.3.2 DDL触发器的创建实例
- APP免费
12.3.3 查询DDL触发器的相关信息
- APP免费
12.4 触发器的管理
- APP免费
12.4.1 使用系统存储过程查询触发器的相关信息
- APP免费
12.4.2 修改触发器——ALTER TRIGGER
- APP免费
12.4.3 禁用/启用触发器——DISABLE/ENABLE TRIGGER
- APP免费
12.4.4 设置触发器的激发顺序——sp_settriggerorder
- APP免费
12.4.5 删除触发器——DROP TRIGGER
- APP免费
12.5 错误的获取与处理
- APP免费
12.5.1 查询错误消息——sys.messages
- APP免费
12.5.2 使用用户自定义错误消息——sp_addmessage/sp_dropmessage
- APP免费
12.5.3 激发错误消息——RAISERROR
- APP免费
12.5.4 获取错误消息——TRY…CATCH/@@ERROR
- APP免费
12.6 小结
- APP免费
第13章 安全性管理——主体、权限、安全对象
- APP免费
13.1 SQL Server 2005安全模式
- APP免费
13.1.1 主体(Principals)
- APP免费
13.1.2 安全对象(Securables)
- APP免费
13.1.3 权限(Permissions)
- APP免费
13.2 创建与管理Windows级别的主体
- APP免费
13.2.1 创建Windows认证登录用户(组)——CREATE LOGIN
- APP免费
13.2.2 查看Windows认证登录用户
- APP免费
13.2.3 修改Windows认证登录用户——ALTER LOGIN
- APP免费
13.2.4 删除Windows认证登录用户——DROP LOGIN
- APP免费
13.3 创建与管理SQL Server级别的主体
- APP免费
13.3.1 创建SQL Server认证登录用户——CREATE LOGIN
- APP免费
13.3.2 修改SQL Server认证登录用户——ALTER LOGIN
- APP免费
13.3.3 查询服务器角色信息
- APP免费
13.3.4 管理服务器角色信息
- APP免费
13.4 创建与管理数据库级别的主体
- APP免费
13.4.1 创建数据库用户——CREATE USER
- APP免费
13.4.2 修改、删除数据库用户——ALTER/DROP USER
- APP免费
13.4.3 管理数据库用户
- APP免费
13.4.4 管理固定数据库角色
- APP免费
13.4.5 管理用户自定义数据库角色
- APP免费
13.4.6 管理应用程序角色
- APP免费
13.5 安全对象与权限
- APP免费
13.5.1 SQL Server的内置权限
- APP免费
13.5.2 服务器范围的安全对象及其权限管理
- APP免费
13.5.3 数据库范围的安全对象及其权限管理
- APP免费
13.5.4 架构范围的安全对象及其权限管理
- APP免费
13.5.5 对象类安全对象及其权限管理
- APP免费
13.6 主体、安全对象和权限的管理
- APP免费
13.6.1 评估当前用户对安全对象的有效权限——Has_perms_by_name
- APP免费
13.6.2 查询当前用户对安全对象的有效权限——fn_my_permissions
- APP免费
13.6.3 创建凭据——CREATE CREDENTIAL
- APP免费
13.7 小结
- APP免费
第14章 事务控制和并发处理
- APP免费
14.1 事务控制的基本概念
- APP免费
14.1.1 事务控制的必要性
- APP免费
14.1.2 事务的ACID特性及实现
- APP免费
14.1.3 事务的状态
- APP免费
14.1.4 Transact-SQL中事务的执行
- APP免费
14.2 SQL Server中事务的实现
- APP免费
14.2.1 启动事务——BEGIN TRANSACTION
- APP免费
14.2.3 提交事务——COMMIT TRANSACTION
- APP免费
14.2.3 回滚事务——ROLLBACK TRANSACTION
- APP免费
14.2.4 设置事务的保存点——SAVE TRANSACTION
- APP免费
14.3 并发控制及其实现
- APP免费
14.3.1 并发访问的问题
- APP免费
14.3.2 SQL Server中的锁
- APP免费
14.3.3 锁的使用
- APP免费
14.3.4 显示数据库中活跃的事务和锁信息——DBCC OPENTRAN
- APP免费
14.3.5 事务隔离级别
- APP免费
14.3.6 设置事务隔离级别——SET TRANSATION
- APP免费
14.3.7 不同事务隔离级别实现并发控制实例
- APP免费
14.3.8 事务阻塞及其解决方法
- APP免费
14.3.9 死锁及其预防
- APP免费
14.4 小结
- APP免费
第15章 游标与全文检索
- APP免费
15.1 游标的基本概念
- APP免费
15.1.1 游标的概念
- APP免费
15.1.2 游标的实现及应用过程
- APP免费
15.2 基本游标的创建和使用
- APP免费
15.2.1 创建游标——DECLARE CURSOR
- APP免费
15.2.2 打开游标——OPEN
- APP免费
15.2.3 检索游标数据——FETCH
- APP免费
15.2.4 关闭/删除游标——CLOSE/DEALLOCATE
- APP免费
15.2.5 遍历游标结果集——@@FETCH_STATUS
- APP免费
15.2.6 使用游标修改、删除数据
- APP免费
15.3 Transact-SQL扩展游标与游标的管理
- APP免费
15.3.1 Transact-SQL扩展游标语法
- APP免费
15.3.2 使用游标变量
- APP免费
15.3.3 事务中游标的使用
- APP免费
15.3.4 游标的管理
- APP免费
15.4 全文检索基础
- APP免费
15.4.1 全文索引和全文目录
- APP免费
15.4.2 创建全文目录——CREATE FULLTEXT CATALOG
- APP免费
15.4.3 创建全文索引——CREATE FULLTEXT INDEX
- APP免费
15.5 使用全文谓词和全文函数进行全文检索
- APP免费
15.5.1 使用CONTAINS谓词进行全文检索
- APP免费
15.5.2 使用FREETEXT谓词进行全文检索
- APP免费
15.5.3 使用全文函数——CONTAINSTABLE、FREETEXTTABLE
- APP免费
15.6 小结
- APP免费
第16章 服务器和数据库的配置与管理
- APP免费
16.1 管理服务器配置选项
- APP免费
16.1.1 查询服务器配置选项
- APP免费
16.1.2 更改服务器配置选项
- APP免费
16.2 管理数据库配置选项
- APP免费
16.2.1 查询数据库信息
- APP免费
16.2.2 自动选项及其设置
- APP免费
16.2.3 ANSI SQL选项及其设置
- APP免费
16.2.4 外部数据源对数据库的访问选项
- APP免费
16.2.5 游标选项及其设置
- APP免费
16.2.6 数据库恢复选项和磁盘I/O错误检查
- APP免费
16.2.7 控制数据库的状态和属性
- APP免费
16.2.8 数据库磁盘空间管理
- APP免费
16.3 数据库的维护
- APP免费
16.3.1 检查磁盘空间分配结构的一致性——DBCC CHECKALLOC
- APP免费
16.3.2 检查数据库对象的结构和逻辑完整性——DBCC CHECKDB
- APP免费
16.3.3 检查文件组分配和结构完整性——DBCC CHECKFILEGROUP
- APP免费
16.3.4 检查页和结构的完整性——DBCC CHECKTABLE
- APP免费
16.3.5 检查约束的完整性——DBCC CHECKCONSTRAINTS
- APP免费
16.4 数据库的备份与恢复
- APP免费
16.4.1 数据库备份与恢复的基本概念
- APP免费
16.4.2 备份操作相关的Transact-SQL语句
- APP免费
16.4.3 完整备份——BACKUP DATABASE
- APP免费
16.4.4 创建逻辑备份设备——sp_addumpdevice
- APP免费
16.4.5 事务日志备份——BACKUP LOG
- APP免费
16.4.6 差异备份——DIFFERENTIAL
- APP免费
16.4.7 文件备份
- APP免费
16.4.8 部分备份——READ_WRITE_FILEGROUPS
- APP免费
16.4.9 查询备份集的元数据
- APP免费
16.4.10 数据库还原——RESTORE DATABASE
- APP免费
16.5 信息架构视图
- APP免费
16.5.1 信息架构视图简介
- APP免费
16.5.2 TABLES信息架构视图
- APP免费
16.5.3 VIEWS信息架构视图
- APP免费
16.5.4 COLUMNS信息架构视图
- APP免费
16.5.5 ROUTINES信息架构视图
- APP免费
16.6 小结
- APP免费
附录A 标准的SQL语句
- APP免费
附录B SQL Server的全局变量
- APP免费
附录C SET语句及功能
更新时间:2019-03-01 23:21:11