又看到这样的一段话:
主键用整型会极大的提高查询效率,而字符型的比较开销要比整型的比较开销大很多,用字符型数据作主键会使数据插入、更新与查询的效率降低。数据量小的时候这点降低可能不会被注意,可是当数据量大的时候,小的改进也能够提高系统的响应速度。
我做了一个实验,用MSSQL企业管理器建立两张表TInt和TStr,
TInt
{
intId int PRIMARY KEY
intValue int
}
TStr
{
strId varchar(20) PRIMARY KEY
strValue varchar(20)
}
往这两张表数据分别为intId = intValue = 1 ~ 300000,strId = strValue = '1' ~ '300000'。然后用mfc封装的odbc分别执行
intRslt.Open(CRecordset::dynaset,"SELECT * FROM TInt WHERE intId = 123456",CRecordset::readOnly);
和
strRslt.Open(CRecordset::dynaset,"SELECT * FROM TSTR WHERE strId = '123456'",CRecordset::readOnly);
一千次。