Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
php_utils
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
bp
php_utils
Commits
b6c535f1
Commit
b6c535f1
authored
Jun 23, 2021
by
yujiwei
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' of
https://git.yidian-inc.com:8021/bp/php_utils
parents
da1104a5
b890a125
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
58 additions
and
1 deletion
+58
-1
GoodsSkuId.php
src/Common/GoodsSkuId.php
+55
-0
Medoo.php
src/Mysql/Medoo.php
+1
-1
MysqlBase.php
src/Mysql/MysqlBase.php
+1
-0
MysqlClusterBase.php
src/Mysql/MysqlClusterBase.php
+1
-0
No files found.
src/Common/GoodsSkuId.php
0 → 100644
View file @
b6c535f1
<?php
namespace
Api\PhpUtils\Common
;
class
GoodsSkuId
{
/**
* 生成加密后的 sku_id
* id 非雪花算法生成的sku_id
* category_1_id 一级分类的id,两位,不足两位在十位补零
* category_2_id 二级分类的id,两位,不足三位在百位补零
* spu 商品类型,1虚拟商品,2实体商品
*
* @param $id
* @param $category1Id
* @param $category2Id
* @param $spuType
* @return string
*/
public
static
function
generateGoodSkuId
(
$id
,
$category1Id
,
$category2Id
,
$spuType
)
{
if
(
strlen
(
$category1Id
)
==
1
)
{
$category1Id
=
"0"
.
$category1Id
;
}
if
(
strlen
(
$category2Id
)
==
2
)
{
$category2Id
=
"0"
.
$category2Id
;
}
$idStr
=
$id
.
$category1Id
.
$category2Id
.
$spuType
;
//转62进制
$tmp
=
BaseConvert
::
decToOther
(
$idStr
);
$len
=
strlen
(
$tmp
);
$len
=
$len
<
6
?
6
:
$len
;
if
(
$len
%
2
==
1
)
{
$tmp
=
'0'
.
$tmp
;
$len
+=
1
;
}
$tmp
=
str_pad
(
strval
(
$tmp
),
$len
<
6
?
6
:
$len
,
'0'
,
STR_PAD_LEFT
);
$sum
=
0
;
for
(
$i
=
0
;
$i
<
$len
/
2
;
$i
++
)
{
$sum
*=
137
;
$sum
+=
ord
(
$tmp
[
$i
])
^
ord
(
$tmp
[
$len
-
$i
-
1
]);
}
$code
=
''
;
$base
=
'0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'
;
for
(
$i
=
2
;
$i
>
0
;
$i
--
)
{
$idx
=
$sum
%
62
;
$sum
=
(
$sum
-
$idx
)
/
62
;
$code
=
$base
[
$idx
]
.
$code
;
}
return
$tmp
.
$code
;
}
}
\ No newline at end of file
src/Mysql/Medoo.php
View file @
b6c535f1
...
...
@@ -1459,7 +1459,7 @@ class Medoo
return
$result
;
}
public
function
insert
(
$table
,
$datas
)
public
function
insert
(
$table
,
$datas
,
$options
=
null
)
{
$stack
=
[];
$columns
=
[];
...
...
src/Mysql/MysqlBase.php
View file @
b6c535f1
...
...
@@ -206,6 +206,7 @@ abstract class MysqlBase
\PDO
::
ATTR_STRINGIFY_FETCHES
=>
false
,
\PDO
::
ATTR_EMULATE_PREPARES
=>
false
,
\PDO
::
ATTR_CASE
=>
\PDO
::
CASE_NATURAL
,
\PDO
::
ATTR_ORACLE_NULLS
=>
\PDO
::
NULL_TO_STRING
,
\PDO
::
ATTR_TIMEOUT
=>
intval
(
self
::
$iniConf
[
'connect_timeout'
]
??
10
)
],
$options
)
];
...
...
src/Mysql/MysqlClusterBase.php
View file @
b6c535f1
...
...
@@ -242,6 +242,7 @@ abstract class MysqlClusterBase
\PDO
::
ATTR_STRINGIFY_FETCHES
=>
false
,
\PDO
::
ATTR_EMULATE_PREPARES
=>
false
,
\PDO
::
ATTR_CASE
=>
\PDO
::
CASE_NATURAL
,
\PDO
::
ATTR_ORACLE_NULLS
=>
\PDO
::
NULL_TO_STRING
,
\PDO
::
ATTR_TIMEOUT
=>
intval
(
self
::
$iniConf
[
'connect_timeout'
]
??
10
)
],
$options
)
];
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment