tp执行的sql
A. TP框架中如何看到错误的sql语句
遇到的情景:TP框架中,如果一个
SQL语句
是错误的,当执行该SQL时页面就会报错结束执行,所以也就无法用$this->getLastSql()打印出错误的语句。
问题:想要查看那条错误的SQL语句是怎样的
解决方法:如图,在Driver.class.php中parseSql函数中加上一句
echo
$sql.'
';
就可以在页面中打印出所有执行的SQL语句(不管是正确的还是错误的都会打印出来)
B. tp5 开启事务后执行三条sql 最后一个sql报错 回滚 但是前两条还是执行成功了 是为什么
Db::startTrans();
try{
Db::commit();
}catch(Exception$exception){
Db::rollback();
}
C. 在TP框架中,使用原生SQL有什么弊端
TP的查询语法是支持跨数据库的,如果原生的话,可能就不能跨数据库支持了,另外一个就是在安全过滤这块需要自己把关了,优势是性能上省去了SQL组装的开销。
D. tp3.2.3 这么执行sql语句创建mysql表
MySql创建数据库表,请参考下列创建表的SQL语句:
CREATE TABLE `students` (
`sid` char(10) PRIMARY KEY,
`sname` varchar(50) NOT NULL,
`sex` char(1) NOT NULL,
`dob` date NOT NULL,
`phone` varchar(30));
E. 在TP框架中,使用原生SQL有什么弊端
TP的查询语法是支持跨数据库的,如果原生的话,可能就不能跨数据库支持了,另外一个就是在安全过滤这块需要自己把关了,优势是性能上省去了SQL组装的开销。
F. 为啥TP日志无法记录运行的SQL语句
可以在config.php中进行设置,默认为关闭状态。
'APP_DEBUG'
=> true
打开\ThinkPHP\Common\debug.php文件可以查看debug的默认设置如下:
return
array(
'LOG_RECORD'=>true, //
进行日志记录
'LOG_RECORD_LEVEL'
=>
array('EMERG','ALERT','CRIT','ERR','WARN','NOTIC','INFO','DEBUG','SQL'),
// 允许记录的日志级别
'DB_FIELDS_CACHE'=> false, //数据库字段缓存
'SHOW_RUN_TIME'=>true,
// 运行时间显示
'SHOW_ADV_TIME'=>true,
// 显示详细的运行时间
'SHOW_DB_TIMES'=>true,
// 显示数据库查询和写入次数
'SHOW_CACHE_TIMES'=>true,
// 显示缓存操作次数
'SHOW_USE_MEM'=>true,
// 显示内存开销
'SHOW_PAGE_TRACE'=>true,
// 显示页面Trace信息 由Trace文件定义和Action操作赋值
'APP_FILE_CASE'
=> true, //
是否检查文件的大小写 对Windows平台有效
);
模型调试:显示SQL语句
$User=new Model('User');
$User->find(1);
echo
$User->getLastSql();//输出最后执行的一条SQL语句
G. TP框架中如何看到错误的SQL语句
遇到的情景:TP框架中,如果一个SQL语句是错误的,当执行该SQL时页面就会报错结束执行,所以也就无法用$this->getLastSql()打印出错误的语句。
问题:想要查看那条错误的SQL语句是怎样的
解决方法:如图,在Driver.class.php中parseSql函数中加上一句 echo $sql.'<br />'; 就可以在页面中打印出所有执行的SQL语句(不管是正确的还是错误的都会打印出来)
H. TP怎么批量执行sql语句
TP怎么批量执行sql语句
如下:
1、打开cmd,切换到mysql的bin目录下 (这个需要根据自己电脑mysql安装位置查找,下面是我的电脑上mysql安装目录)
2、 C:\Program Files(x86)\MySQL5.6\bin>mysqld.exe -install
Service successfully installed.
3、 C:\Program Files(x86)\MySQL5.6\bin>net start mysqlMySQL 服务已经启动成功
4.现在打开服务列表,就可以看到mysql服务了。
I. TP5在执行SQL语句时老是服这个错误怎么回事
抛出异常,没有有错误讯息,是因为你在catch中没有记录, 如果要有错误信息,就修改catch中的语句, catch(Exception ex) { MessageBox.Show(ex.Message); }