问题描述
我使用 R 中的 DBI
库建立到 MS Access DB(在本例中称为“db”)的连接,然后使用 DBI dbGetQuery()
函数传递 MS Access sql 查询见下。如果我在不尝试定义格式的情况下运行此示例代码段,它会按预期创建一个新表。我无法确定的是是否可以在同一查询中定义数据类型的格式?如果可能,在 CREATE TABLE 语句中定义格式的语法是什么。
不尝试格式化:
dbGetQuery(db,"CREATE TABLE MyTable
(
Table_ID AutoIncrement PRIMARY KEY,Location CHAR NOT NULL,Event_Date DATE NOT NULL,Species_Code CHAR NOT NULL,Length DOUBLE,Weight DOUBLE,Sex CHAR
)")
尝试格式化日期会导致语法错误:
dbGetQuery(db,Event_Date DATE NOT NULL FORMAT \"yyyy/mm/dd\",Sex CHAR
)")
解决方法
据我所知,Access 中的 DATETIME 字段默认为 mm/dd/yyyy 格式。我不知道您是否可以使用 SQL 命令修改格式 - 您可以使用表的设计视图来更改它。
当我想要一个字段具有特殊的日期格式时,我使用 CHAR 数据类型(或短文本,在 Access 用语中),然后我使用 FORMAT() 函数根据我的喜好设置日期值的格式,每当我插入一个新日期.这为日期提供了更大的灵活性。