【ThinkPHP6 - 连接 SQLite 及遇到的一些问题】

简易小项目,需要做个人员报道表格,后台需要查看与导出,这时就想到不用 MySQL 了,直接使用 SQLite

一、 连接配置

以下是 ThinkPHP6 的数据库连接配置

<?php

return [
    // 默认使用的数据库连接配置
    'default'         => 'sqlite',

    // 自定义时间查询规则
    'time_query_rule' => [],

    // 自动写入时间戳字段
    // true为自动识别类型 false关闭
    // 字符串则明确指定时间字段类型 支持 int timestamp datetime date
    'auto_timestamp'  => true,

    // 时间字段取出后的默认时间格式
    'datetime_format' => 'Y-m-d H:i:s',

    // 时间字段配置 配置格式:create_time,update_time
    'datetime_field'  => '',

    // 数据库连接配置信息
    'connections'     => [
        'sqlite' => [
            // 数据库类型
            'type' => 'sqlite',

            // 数据库名 # 这里替换成自己的 SQLite 数据库文件路径
            'dsn'  => 'sqlite:/doc/sql/sqlite.db',
            
			// 表前缀
            'prefix'          => 'um_',
        ],

        // 更多的数据库配置信息
    ],
    'mysql' => [
    		// 替换为自己的配置值, 用 env 进行配置,参考写法 'charset' => env('database.charset', 'utf8'),
    		
            // 数据库类型
            'type'            => mysql,
            // 服务器地址
            'hostname'        => '1.1.1.1',
            // 数据库名
            'database'        => 'datebase_name',
            // 用户名
            'username'        => 'root',
            // 密码
            'password'        => 'wiS@8!ID*@!AUA!DFW231',
            // 端口
            'hostport'        => '3306',
            // 数据库连接参数
            'params'          => [],
            // 数据库编码默认采用utf8
            'charset'         => 'utf8',
            // 数据库表前缀
            'prefix'          => 'sg_',

            // 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
            'deploy'          => 0,
            // 数据库读写是否分离 主从式有效
            'rw_separate'     => false,
            // 读写分离后 主服务器数量
            'master_num'      => 1,
            // 指定从服务器序号
            'slave_no'        => '',
            // 是否严格检查字段是否存在
            'fields_strict'   => true,
            // 是否需要断线重连
            'break_reconnect' => false,
            // 监听SQL
            'trigger_sql'     => true,
            // 开启字段缓存
            'fields_cache'    => false,
        ],
];


二、问题解决

8 attempt to write a readonly database


将你的数据库文件设置为可读可写可执行,777

14 unable to open database file


将你的数据库存放文件的路径也要设置可读可写可执行,777

设置自增id ,创建表

CREATE TABLE "um_user_record" (
 "id" INTEGER NOT NULL, -- 自增id
 "sn" INTEGER(11) NOT NULL, -- 批次号
 "declare_unit" VARCHAR(255) NOT NULL, -- 申报单位
 "unit_contact" VARCHAR(50) NOT NULL, -- 申报单位联系人
 "unit_phone" VARCHAR(16) NOT NULL, -- 申报单位联系电话
 "image" TEXT NOT NULL, -- 申报记录图片
 "created_at" INTEGER(11) NOT NULL, -- 新增时间
 PRIMARY KEY ("id")
);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
thinkphp Access-Control-Allow-Origin 报错是由于跨域访问时没有正确设置 Access-Control-Allow-Origin 头部字段引起的。在给定的 PHP 代码中,Access-Control-Allow-Origin 被设置为绑定 `$origin_arr` 数组内的域名。 根据给定的代码片段,Access-Control-Allow-Origin 的值是根据请求中的 Origin 头部字段判断的。如果 Origin 头部字段的值在 `$origin_arr` 数组中,则允许跨域访问并将 Access-Control-Allow-Origin 设置为该值。 然而,需要注意的是,在引用中提到的 Access-Control-Allow-Origin 一般情况下只能绑定一个值。但是,根据给定的代码,通过在 `$origin_arr` 数组中添加多个域名,可以实现绑定多个值的效果。这是因为在代码中使用了 in_array() 函数来检查是否存在匹配的域名。 因此,如果 thinkphp Access-Control-Allow-Origin 报错,可能有以下几个原因导致: 1. `$origin_arr` 数组中的域名没有匹配到请求中的 Origin 头部字段的值。 2. `$origin_arr` 数组中的域名格式不正确,或者存在拼写错误。 3. 请求中没有包含 Origin 头部字段。 为了解决这个问题,你可以按照以下步骤进行排查和修复: 1. 确保 `$origin_arr` 数组中包含与请求中的 Origin 头部字段值匹配的域名,且格式正确。 2. 检查请求中是否包含 Origin 头部字段,并确保该头部字段的值与预期的域名匹配。 3. 如果你使用的是 thinkphp 框架,可以在应用的配置文件中设置 Access-Control-Allow-Origin 头部字段的值。例如,可以在 config.php 文件中添加以下代码: ```php 'header' => [ 'Access-Control-Allow-Origin' => implode(',', self::$origin_arr), 'Access-Control-Allow-Methods' => 'POST, GET', 'Access-Control-Allow-Credentials' => true, 'Access-Control-Allow-Headers' => 'token, Content-Type, Authorization, Accept, Range, Origin, Token, language', ], ``` 这样可以确保在每个请求中都正确设置了相应的头部字段。 综上所述,如果 thinkphp Access-Control-Allow-Origin 报错,你可以检查以上提到的原因并进行相应的修复。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

后端木木

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值